168 lines
6.3 KiB
Bash
168 lines
6.3 KiB
Bash
#!/bin/bash
|
|
|
|
# ---------------------------------------------------------------------------+
|
|
# |
|
|
# Thanks to Alexander Korznikov |
|
|
# http://www.korznikov.com/2014/12/bash-tab-completion-for-awesome-tool.html |
|
|
# |
|
|
# ---------------------------------------------------------------------------+
|
|
|
|
if command -v sqlmap > /dev/null; then
|
|
|
|
_sqlmap()
|
|
{
|
|
local cur prev
|
|
|
|
COMPREPLY=()
|
|
cur=$(_get_cword)
|
|
prev=$(_get_pword)
|
|
|
|
case $prev in
|
|
|
|
# List directory content
|
|
--tamper)
|
|
COMPREPLY=( $( compgen -W "$tamper" -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--output-dir|-t|-l|-m|-r|--load-cookies|--proxy-file|--sql-file|--shared-lib|--file-write)
|
|
_filedir
|
|
return 0
|
|
;;
|
|
-c)
|
|
_filedir ini
|
|
return 0
|
|
;;
|
|
--method)
|
|
COMPREPLY=( $( compgen -W 'GET POST PUT' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--auth-type)
|
|
COMPREPLY=( $( compgen -W 'Basic Digest NTLM PKI' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--tor-type)
|
|
COMPREPLY=( $( compgen -W 'HTTP SOCKS4 SOCKS5' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
-v)
|
|
COMPREPLY=( $( compgen -W '1 2 3 4 5 6' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--dbms)
|
|
COMPREPLY=( $( compgen -W 'mysql mssql access postgres' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--level|--crawl)
|
|
COMPREPLY=( $( compgen -W '1 2 3 4 5' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--risk)
|
|
COMPREPLY=( $( compgen -W '0 1 2 3' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
--technique)
|
|
COMPREPLY=( $( compgen -W 'B E U S T Q' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
-s)
|
|
_filedir sqlite
|
|
return 0
|
|
;;
|
|
--dump-format)
|
|
COMPREPLY=( $( compgen -W 'CSV HTML SQLITE' -- "$cur" ) )
|
|
return 0
|
|
;;
|
|
-x)
|
|
_filedir xml
|
|
return 0
|
|
;;
|
|
esac
|
|
|
|
if [[ "$cur" == * ]]; then
|
|
COMPREPLY=( $( compgen -W '-h --help -hh --version -v -d -u --url -l -x -m -r -g -c --method \
|
|
--data --param-del --cookie --cookie-del --load-cookies \
|
|
--drop-set-cookie --user-agent --random-agent --host --referer \
|
|
--headers --auth-type --auth-cred --auth-private --ignore-401 \
|
|
--proxy --proxy-cred --proxy-file --ignore-proxy --tor --tor-port \
|
|
--tor-type --check-tor --delay --timeout --retries --randomize \
|
|
--safe-url --safe-freq --skip-urlencode --csrf-token --csrf-url \
|
|
--force-ssl --hpp --eval -o --predict-output --keep-alive \
|
|
--null-connection --threads -p --skip --dbms --dbms-cred \
|
|
--os --invalid-bignum --invalid-logical --invalid-string \
|
|
--no-cast --no-escape --prefix --suffix --tamper --level \
|
|
--risk --string --not-string --regexp --code --text-only \
|
|
--titles --technique --time-sec --union-cols --union-char \
|
|
--union-from --dns-domain --second-order -f --fingerprint \
|
|
-a --all -b --banner --current-user --current-db --hostname \
|
|
--is-dba --users --passwords --privileges --roles --dbs --tables \
|
|
--columns --schema --count --dump --dump-all --search --comments \
|
|
-D -T -C -X -U --exclude-sysdbs --where --start --stop \
|
|
--first --last --sql-query --sql-shell --sql-file --common-tables \
|
|
--common-columns --udf-inject --shared-lib --file-read --file-write \
|
|
--file-dest --os-cmd --os-shell --os-pwn --os-smbrelay --os-bof \
|
|
--priv-esc --msf-path --tmp-path --reg-read --reg-add --reg-del \
|
|
--reg-key --reg-value --reg-data --reg-type -s -t --batch \
|
|
--charset --crawl --csv-del --dump-format --eta --flush-session \
|
|
--forms --fresh-queries --hex --output-dir --parse-errors \
|
|
--pivot-column --save --scope --test-filter --update \
|
|
-z --alert --answers --beep --check-waf --cleanup \
|
|
--dependencies --disable-coloring --gpage --identify-waf \
|
|
--mobile --page-rank --purge-output --smart \
|
|
--sqlmap-shell --wizard' -- "$cur" ) )
|
|
# this removes any options from the list of completions that have
|
|
# already been specified somewhere on the command line, as long as
|
|
# these options can only be used once (in a word, "options", in
|
|
# opposition to "tests" and "actions", as in the find(1) manpage).
|
|
onlyonce=' -h --help -hh --version -v -d -u --url -l -x -m -r -g -c \
|
|
--drop-set-cookie --random-agent \
|
|
--ignore-401 \
|
|
--ignore-proxy --tor \
|
|
--check-tor \
|
|
--skip-urlencode \
|
|
--force-ssl --hpp -o --predict-output --keep-alive \
|
|
--null-connection -p \
|
|
--invalid-bignum --invalid-logical --invalid-string \
|
|
--no-cast --no-escape \
|
|
--text-only \
|
|
--titles \
|
|
-f --fingerprint \
|
|
-a --all -b --banner --current-user --current-db --hostname \
|
|
--is-dba --users --passwords --privileges --roles --dbs --tables \
|
|
--columns --schema --count --dump --dump-all --search --comments \
|
|
-D -T -C -X -U --exclude-sysdbs \
|
|
--sql-shell --common-tables \
|
|
--common-columns --udf-inject \
|
|
--os-shell --os-pwn --os-smbrelay --os-bof \
|
|
--priv-esc --reg-read --reg-add --reg-del \
|
|
-s -t --batch \
|
|
--eta --flush-session \
|
|
--forms --fresh-queries --hex --parse-errors \
|
|
--save --update \
|
|
-z --beep --check-waf --cleanup \
|
|
--dependencies --disable-coloring --identify-waf \
|
|
--mobile --page-rank --purge-output --smart \
|
|
--sqlmap-shell --wizard '
|
|
COMPREPLY=( $( \
|
|
(while read -d ' ' i; do
|
|
[[ -z "$i" || "${onlyonce/ ${i%% *} / }" == "$onlyonce" ]] &&
|
|
continue
|
|
# flatten array with spaces on either side,
|
|
# otherwise we cannot grep on word boundaries of
|
|
# first and last word
|
|
COMPREPLY=" ${COMPREPLY[@]} "
|
|
# remove word from list of completions
|
|
COMPREPLY=( ${COMPREPLY/ ${i%% *} / } )
|
|
done
|
|
printf '%s ' "${COMPREPLY[@]}") <<<"${COMP_WORDS[@]}"
|
|
) )
|
|
|
|
# else
|
|
# _filedir bat
|
|
fi
|
|
}
|
|
|
|
|
|
complete -F _sqlmap sqlmap
|
|
|
|
fi
|