mirror of
https://github.com/pre-commit/pre-commit-hooks.git
synced 2026-04-07 20:26:54 +00:00
Adding check-iam check
This commit is contained in:
parent
5191f112df
commit
bf42103d47
2 changed files with 46 additions and 0 deletions
|
|
@ -46,6 +46,12 @@
|
||||||
entry: check-json
|
entry: check-json
|
||||||
language: python
|
language: python
|
||||||
types: [json]
|
types: [json]
|
||||||
|
- id: check-iam
|
||||||
|
name: check IAM
|
||||||
|
description: checks terraform files for parseable IAM syntax.
|
||||||
|
entry: check-iam
|
||||||
|
language: python
|
||||||
|
types: [tf]
|
||||||
- id: check-shebang-scripts-are-executable
|
- id: check-shebang-scripts-are-executable
|
||||||
name: check that scripts with shebangs are executable
|
name: check that scripts with shebangs are executable
|
||||||
description: ensures that (non-binary) files with a shebang are executable.
|
description: ensures that (non-binary) files with a shebang are executable.
|
||||||
|
|
|
||||||
40
pre_commit_hooks/check_iam.py
Normal file
40
pre_commit_hooks/check_iam.py
Normal file
|
|
@ -0,0 +1,40 @@
|
||||||
|
import argparse
|
||||||
|
import hcl2
|
||||||
|
# from typing import Any
|
||||||
|
from typing import Sequence
|
||||||
|
|
||||||
|
|
||||||
|
def main(argv: Sequence[str] | None = None) -> int:
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument('filenames', nargs='*', help='Filenames to check.')
|
||||||
|
args = parser.parse_args(argv)
|
||||||
|
|
||||||
|
retval = 0
|
||||||
|
for filename in args.filenames:
|
||||||
|
if filename == "iam.tf":
|
||||||
|
continue
|
||||||
|
with open(filename, 'rb') as f:
|
||||||
|
try:
|
||||||
|
dict = hcl2.load(f)
|
||||||
|
except ValueError as exc:
|
||||||
|
print(f'{filename}: Failed to hcl decode ({exc})')
|
||||||
|
retval = 1
|
||||||
|
resources = data.get('resource')
|
||||||
|
if resources:
|
||||||
|
for item in resources:
|
||||||
|
for keys in item:
|
||||||
|
if key.startswith("aws_iam"):
|
||||||
|
print(f'{filename}: Has {key} resource')
|
||||||
|
retval = 1
|
||||||
|
resources = data.get('data')
|
||||||
|
if resources:
|
||||||
|
for item in resources:
|
||||||
|
for keys in item:
|
||||||
|
if key.startswith("aws_iam"):
|
||||||
|
print(f'{filename}: Has {key} data resource')
|
||||||
|
retval = 1
|
||||||
|
return retval
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
raise SystemExit(main())
|
||||||
Loading…
Add table
Add a link
Reference in a new issue