mirror of
https://github.com/pre-commit/pre-commit-hooks.git
synced 2026-04-05 19:46:54 +00:00
add pre-commit hook for checking for talkative/verbose cURL commands in any file type
This commit is contained in:
parent
f0bf512dbb
commit
ce1c73b3a6
5 changed files with 140 additions and 0 deletions
|
|
@ -112,6 +112,12 @@
|
||||||
entry: detect-private-key
|
entry: detect-private-key
|
||||||
language: python
|
language: python
|
||||||
types: [text]
|
types: [text]
|
||||||
|
- id: detect-verbose-curl
|
||||||
|
name: Detect Verbose CURL
|
||||||
|
description: Detects the presence of verbose options in cURL commands.
|
||||||
|
entry: detect-verbose-curl
|
||||||
|
language: python
|
||||||
|
types: [text]
|
||||||
- id: double-quote-string-fixer
|
- id: double-quote-string-fixer
|
||||||
name: Fix double quoted strings
|
name: Fix double quoted strings
|
||||||
description: This hook replaces double quoted strings with single quoted strings
|
description: This hook replaces double quoted strings with single quoted strings
|
||||||
|
|
|
||||||
|
|
@ -93,6 +93,9 @@ The following arguments are available:
|
||||||
#### `detect-private-key`
|
#### `detect-private-key`
|
||||||
Checks for the existence of private keys.
|
Checks for the existence of private keys.
|
||||||
|
|
||||||
|
#### `detect-verbose-curl`
|
||||||
|
Checks for the existence of files with verbose cURL commands.
|
||||||
|
|
||||||
#### `double-quote-string-fixer`
|
#### `double-quote-string-fixer`
|
||||||
This hook replaces double quoted strings with single quoted strings.
|
This hook replaces double quoted strings with single quoted strings.
|
||||||
|
|
||||||
|
|
|
||||||
45
pre_commit_hooks/detect_verbose_curl.py
Normal file
45
pre_commit_hooks/detect_verbose_curl.py
Normal file
|
|
@ -0,0 +1,45 @@
|
||||||
|
import argparse
|
||||||
|
import re
|
||||||
|
from typing import Optional
|
||||||
|
from typing import Sequence
|
||||||
|
|
||||||
|
CURL_VERBOSE_PATTERN = re.compile(
|
||||||
|
br'^(.+)?curl(.+)?((\-v\s)|(\--verbose)|(-w)|(\-\-trace))(.+)?',
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def _get_file_verbose_occurrences(filename: str) -> int:
|
||||||
|
file_verbose_occurrences = 0
|
||||||
|
with open(filename, 'rb') as f:
|
||||||
|
for i, line in enumerate(f, 1):
|
||||||
|
if CURL_VERBOSE_PATTERN.search(line):
|
||||||
|
print(
|
||||||
|
'Talkative/Verbose cURL command found: '
|
||||||
|
'{filename}:{i}:{line}',
|
||||||
|
)
|
||||||
|
file_verbose_occurrences += 1
|
||||||
|
return file_verbose_occurrences
|
||||||
|
|
||||||
|
|
||||||
|
def main(argv: Optional[Sequence[str]] = None) -> int:
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument('filenames', nargs='*', help='File names to check')
|
||||||
|
args = parser.parse_args(argv)
|
||||||
|
|
||||||
|
verbose_command_count = 0
|
||||||
|
for filename in args.filenames:
|
||||||
|
verbose_command_count += _get_file_verbose_occurrences(filename)
|
||||||
|
|
||||||
|
if verbose_command_count > 0:
|
||||||
|
print(
|
||||||
|
f'Number of talkative/verbose cURL commands:'
|
||||||
|
f' {verbose_command_count}',
|
||||||
|
)
|
||||||
|
return verbose_command_count
|
||||||
|
else:
|
||||||
|
print('No talkative/verbose cURL commands found!')
|
||||||
|
return 0
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
exit(main())
|
||||||
|
|
@ -45,6 +45,7 @@ console_scripts =
|
||||||
debug-statement-hook = pre_commit_hooks.debug_statement_hook:main
|
debug-statement-hook = pre_commit_hooks.debug_statement_hook:main
|
||||||
detect-aws-credentials = pre_commit_hooks.detect_aws_credentials:main
|
detect-aws-credentials = pre_commit_hooks.detect_aws_credentials:main
|
||||||
detect-private-key = pre_commit_hooks.detect_private_key:main
|
detect-private-key = pre_commit_hooks.detect_private_key:main
|
||||||
|
detect-verbose-curl = pre_commit_hooks.detect_verbose_curl:main
|
||||||
double-quote-string-fixer = pre_commit_hooks.string_fixer:main
|
double-quote-string-fixer = pre_commit_hooks.string_fixer:main
|
||||||
end-of-file-fixer = pre_commit_hooks.end_of_file_fixer:main
|
end-of-file-fixer = pre_commit_hooks.end_of_file_fixer:main
|
||||||
file-contents-sorter = pre_commit_hooks.file_contents_sorter:main
|
file-contents-sorter = pre_commit_hooks.file_contents_sorter:main
|
||||||
|
|
|
||||||
85
tests/detect_verbose_curl_test.py
Normal file
85
tests/detect_verbose_curl_test.py
Normal file
|
|
@ -0,0 +1,85 @@
|
||||||
|
from pre_commit_hooks.detect_verbose_curl import main
|
||||||
|
|
||||||
|
|
||||||
|
def test_trivial(tmpdir):
|
||||||
|
f = tmpdir.join('f.sh').ensure()
|
||||||
|
assert not main((str(f),))
|
||||||
|
|
||||||
|
|
||||||
|
def test_passing(tmpdir):
|
||||||
|
f = tmpdir.join('f.sh')
|
||||||
|
f.write_binary(
|
||||||
|
b'#!/usr/bin/env bash\n'
|
||||||
|
# setup
|
||||||
|
b'url=https://api.somesite.com\n'
|
||||||
|
# api call 1
|
||||||
|
b'curl -X GET ${url} -H "X-Custom-Header: pytest-test"\n'
|
||||||
|
# api call 2
|
||||||
|
b'curl -d "{key1:value1, key2:value2}" -H '
|
||||||
|
b'"Content-Type: application/json" -X POST ${url} \n'
|
||||||
|
# test comments
|
||||||
|
b'# None of these commands have curl verbose - '
|
||||||
|
b'this comment should NOT be recognised as -- is missing\n'
|
||||||
|
b'# The "trace" amd other options should also not be picked up.\n '
|
||||||
|
# list the version of curl - should not be picked up. Only
|
||||||
|
b'curl --version\n'
|
||||||
|
b'curl -V\n',
|
||||||
|
)
|
||||||
|
assert main((str(f),)) == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_failing(tmpdir, capsys):
|
||||||
|
with tmpdir.as_cwd():
|
||||||
|
tmpdir.join('f.sh').write_binary(
|
||||||
|
b'#!/usr/bin/env bash\n'
|
||||||
|
# setup
|
||||||
|
b'url=https://api.somesite.com\n'
|
||||||
|
# Talkative cURL HTTP calls
|
||||||
|
b'curl -v -X GET ${url} -H "X-Custom-Header: pytest-test"\n'
|
||||||
|
b'curl -X GET ${url} -H '
|
||||||
|
b'"X-Custom-Header: pytest-test" --verbose\n'
|
||||||
|
b'curl --write-out output.txt -X GET ${url} '
|
||||||
|
b'-H "X-Custom-Header: pytest-test"\n',
|
||||||
|
)
|
||||||
|
tmpdir.join('f.groovy').write_binary(
|
||||||
|
b'#!/usr/bin/env bash\n'
|
||||||
|
# setup
|
||||||
|
b'url=https://api.somesite.com\n'
|
||||||
|
# Talkative cURL HTTP calls
|
||||||
|
b'curl -d "{key1:value1, key2:value2}" -w output.txt '
|
||||||
|
b'-H "Content-Type: application/json" -X POST ${url}\n'
|
||||||
|
b'curl --trace-ascii ascii.txt -d "{key1:value1, key2:value2}" '
|
||||||
|
b'-H "Content-Type: application/json" -X POST ${url}\n'
|
||||||
|
b'curl -d "{key1:value1, key2:value2}" -X POST ${url} '
|
||||||
|
b'--trace trace.txt -H "Content-Type: application/json"\n',
|
||||||
|
)
|
||||||
|
|
||||||
|
assert main(('f.sh', 'f.groovy')) == 6
|
||||||
|
|
||||||
|
out, _ = capsys.readouterr()
|
||||||
|
assert out == (
|
||||||
|
"Talkative/Verbose cURL command found: f.sh:3:b\'curl -v -X GET"
|
||||||
|
" ${url} -H \"X-Custom-Header: pytest-test\"\\n\'\n"
|
||||||
|
"Talkative/Verbose cURL command found: f.sh:4:b\'curl -X GET "
|
||||||
|
"${url} -H \"X-Custom-Header: pytest-test\" --verbose\\n\'\n"
|
||||||
|
'Talkative/Verbose cURL command found: '
|
||||||
|
"f.sh:5:b\'curl --write-out output.txt"
|
||||||
|
" -X GET ${url} -H \"X-Custom-Header: pytest-test\"\\n\'\n"
|
||||||
|
|
||||||
|
"Talkative/Verbose cURL command found: f.groovy:3:b\'curl "
|
||||||
|
"-d \"{key1:value1, key2:value2}\""
|
||||||
|
" -w output.txt -H \"Content-Type: application/json\""
|
||||||
|
" -X POST ${url}\\n\'\n"
|
||||||
|
'Talkative/Verbose cURL command found:'
|
||||||
|
" f.groovy:4:b\'curl "
|
||||||
|
'--trace-ascii ascii.txt '
|
||||||
|
"-d \"{key1:value1, key2:value2}\""
|
||||||
|
" -H \"Content-Type: application/json\" "
|
||||||
|
"-X POST ${url}\\n\'\n"
|
||||||
|
"Talkative/Verbose cURL command found: f.groovy:5:b\'curl "
|
||||||
|
"-d \"{key1:value1, key2:value2}\""
|
||||||
|
'-X POST ${url} --trace trace.txt '
|
||||||
|
" -H \"Content-Type: application/json\"\\n\'\n"
|
||||||
|
|
||||||
|
'Number of talkative/verbose cURL commands: 6\n'
|
||||||
|
)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue