Some checks failed
Detach Plugins / check (FlyGrep.vim) (push) Has been cancelled
Detach Plugins / check (GitHub.vim) (push) Has been cancelled
Detach Plugins / check (JavaUnit.vim) (push) Has been cancelled
Detach Plugins / check (SourceCounter.vim) (push) Has been cancelled
Detach Plugins / check (cpicker.nvim) (push) Has been cancelled
Detach Plugins / check (dein-ui.vim) (push) Has been cancelled
Detach Plugins / check (git.vim) (push) Has been cancelled
Detach Plugins / check (iedit.vim) (push) Has been cancelled
Detach Plugins / check (scrollbar.vim) (push) Has been cancelled
Detach Plugins / check (vim-chat) (push) Has been cancelled
Detach Plugins / check (vim-cheat) (push) Has been cancelled
Detach Plugins / check (vim-todo) (push) Has been cancelled
Detach Plugins / check (xmake.vim) (push) Has been cancelled
test / Linux (nvim, nightly) (push) Has been cancelled
test / Linux (nvim, v0.3.8) (push) Has been cancelled
test / Linux (nvim, v0.4.0) (push) Has been cancelled
test / Linux (nvim, v0.4.2) (push) Has been cancelled
test / Linux (nvim, v0.4.3) (push) Has been cancelled
test / Linux (nvim, v0.4.4) (push) Has been cancelled
test / Linux (nvim, v0.5.0) (push) Has been cancelled
test / Linux (nvim, v0.5.1) (push) Has been cancelled
test / Linux (nvim, v0.6.0) (push) Has been cancelled
test / Linux (nvim, v0.6.1) (push) Has been cancelled
test / Linux (nvim, v0.7.0) (push) Has been cancelled
test / Linux (nvim, v0.7.2) (push) Has been cancelled
test / Linux (nvim, v0.8.0) (push) Has been cancelled
test / Linux (nvim, v0.8.1) (push) Has been cancelled
test / Linux (nvim, v0.8.2) (push) Has been cancelled
test / Linux (nvim, v0.8.3) (push) Has been cancelled
test / Linux (nvim, v0.9.0) (push) Has been cancelled
test / Linux (nvim, v0.9.1) (push) Has been cancelled
test / Linux (true, vim, v7.4.052) (push) Has been cancelled
test / Linux (true, vim, v7.4.1689) (push) Has been cancelled
test / Linux (true, vim, v7.4.629) (push) Has been cancelled
test / Linux (true, vim, v8.0.0027) (push) Has been cancelled
test / Linux (true, vim, v8.0.0183) (push) Has been cancelled
test / Linux (vim, nightly) (push) Has been cancelled
test / Linux (vim, v8.0.0184) (push) Has been cancelled
test / Linux (vim, v8.0.1453) (push) Has been cancelled
test / Linux (vim, v8.1.2269) (push) Has been cancelled
test / Linux (vim, v8.2.2434) (push) Has been cancelled
test / Linux (vim, v8.2.3995) (push) Has been cancelled
test / Windows (nvim, nightly) (push) Has been cancelled
test / Windows (nvim, v0.3.8) (push) Has been cancelled
test / Windows (nvim, v0.4.2) (push) Has been cancelled
test / Windows (nvim, v0.4.3) (push) Has been cancelled
test / Windows (nvim, v0.4.4) (push) Has been cancelled
test / Windows (nvim, v0.5.0) (push) Has been cancelled
test / Windows (nvim, v0.5.1) (push) Has been cancelled
test / Windows (nvim, v0.6.0) (push) Has been cancelled
test / Windows (nvim, v0.6.1) (push) Has been cancelled
test / Windows (nvim, v0.7.0) (push) Has been cancelled
test / Windows (nvim, v0.7.2) (push) Has been cancelled
test / Windows (nvim, v0.8.0) (push) Has been cancelled
test / Windows (nvim, v0.8.1) (push) Has been cancelled
test / Windows (nvim, v0.8.2) (push) Has been cancelled
test / Windows (nvim, v0.8.3) (push) Has been cancelled
test / Windows (nvim, v0.9.0) (push) Has been cancelled
test / Windows (nvim, v0.9.1) (push) Has been cancelled
test / Windows (vim, nightly) (push) Has been cancelled
test / Windows (vim, v7.4.1185) (push) Has been cancelled
test / Windows (vim, v7.4.1689) (push) Has been cancelled
test / Windows (vim, v8.0.0027) (push) Has been cancelled
test / Windows (vim, v8.0.1453) (push) Has been cancelled
test / Windows (vim, v8.1.2269) (push) Has been cancelled
test / Windows (vim, v8.2.2434) (push) Has been cancelled
test / Windows (vim, v8.2.3995) (push) Has been cancelled
docker / docker (push) Has been cancelled
mirror / check (coding) (push) Has been cancelled
mirror / check (gitee) (push) Has been cancelled
mirror / check (gitlab) (push) Has been cancelled
88 lines
2.4 KiB
VimL
88 lines
2.4 KiB
VimL
" Description: tfsec for Terraform files
|
|
"
|
|
" See: https://www.terraform.io/
|
|
" https://github.com/aquasecurity/tfsec
|
|
|
|
call ale#Set('terraform_tfsec_options', '')
|
|
call ale#Set('terraform_tfsec_executable', 'tfsec')
|
|
|
|
let s:separator = has('win32') ? '\' : '/'
|
|
|
|
function! ale_linters#terraform#tfsec#Handle(buffer, lines) abort
|
|
let l:output = []
|
|
let l:json = ale#util#FuzzyJSONDecode(a:lines, {})
|
|
|
|
" if there's no warning, 'result' is `null`.
|
|
if empty(get(l:json, 'results'))
|
|
return l:output
|
|
endif
|
|
|
|
for l:result in get(l:json, 'results', [])
|
|
if l:result.severity is# 'LOW'
|
|
let l:type = 'I'
|
|
elseif l:result.severity is# 'CRITICAL'
|
|
let l:type = 'E'
|
|
else
|
|
let l:type = 'W'
|
|
endif
|
|
|
|
call add(l:output, {
|
|
\ 'filename': l:result.location.filename,
|
|
\ 'lnum': l:result.location.start_line,
|
|
\ 'end_lnum': l:result.location.end_line,
|
|
\ 'text': l:result.description,
|
|
\ 'code': l:result.long_id,
|
|
\ 'type': l:type,
|
|
\})
|
|
endfor
|
|
|
|
return l:output
|
|
endfunction
|
|
|
|
" Construct command arguments to tfsec with `terraform_tfsec_options`.
|
|
function! ale_linters#terraform#tfsec#GetCommand(buffer) abort
|
|
let l:cmd = '%e'
|
|
|
|
let l:config = ale_linters#terraform#tfsec#FindConfig(a:buffer)
|
|
|
|
if !empty(l:config)
|
|
let l:cmd .= ' --config-file ' . l:config
|
|
endif
|
|
|
|
let l:opts = ale#Var(a:buffer, 'terraform_tfsec_options')
|
|
|
|
if !empty(l:opts)
|
|
let l:cmd .= ' ' . l:opts
|
|
endif
|
|
|
|
let l:cmd .= ' --format json'
|
|
|
|
return l:cmd
|
|
endfunction
|
|
|
|
" Find the nearest configuration file of tfsec.
|
|
function! ale_linters#terraform#tfsec#FindConfig(buffer) abort
|
|
let l:config_dir = ale#path#FindNearestDirectory(a:buffer, '.tfsec')
|
|
|
|
if !empty(l:config_dir)
|
|
" https://aquasecurity.github.io/tfsec/v1.28.0/guides/configuration/config/
|
|
for l:basename in ['config.yml', 'config.json']
|
|
let l:config = ale#path#Simplify(join([l:config_dir, l:basename], s:separator))
|
|
|
|
if filereadable(l:config)
|
|
return ale#Escape(l:config)
|
|
endif
|
|
endfor
|
|
endif
|
|
|
|
return ''
|
|
endfunction
|
|
|
|
call ale#linter#Define('terraform', {
|
|
\ 'name': 'tfsec',
|
|
\ 'executable': {b -> ale#Var(b, 'terraform_tfsec_executable')},
|
|
\ 'cwd': '%s:h',
|
|
\ 'command': function('ale_linters#terraform#tfsec#GetCommand'),
|
|
\ 'callback': 'ale_linters#terraform#tfsec#Handle',
|
|
\})
|