Merge pull request #1195 from sdknudsen/master
Warn about invalid arguments to sudo
This commit is contained in:
commit
8873a1732b
|
@ -1,5 +1,6 @@
|
|||
## Latest - ???
|
||||
### Added
|
||||
- SC2232: Warn about invalid arguments to sudo
|
||||
- SC2231: Suggest quoting expansions in for loop globs
|
||||
- SC2229: Warn about 'read $var'
|
||||
- SC2227: Warn about redirections in the middle of 'find' commands
|
||||
|
|
|
@ -121,6 +121,7 @@ nodeChecks = [
|
|||
,checkTestRedirects
|
||||
,checkIndirectExpansion
|
||||
,checkSudoRedirect
|
||||
,checkSudoArgs
|
||||
,checkPS1Assignments
|
||||
,checkBackticks
|
||||
,checkInexplicablyUnquoted
|
||||
|
@ -1306,6 +1307,22 @@ checkSudoRedirect _ (T_Redirecting _ redirs cmd) | cmd `isCommand` "sudo" =
|
|||
special file = concat (oversimplify file) == "/dev/null"
|
||||
checkSudoRedirect _ _ = return ()
|
||||
|
||||
prop_checkSudoArgs1 = verify checkSudoArgs "sudo cd /root"
|
||||
prop_checkSudoArgs2 = verify checkSudoArgs "sudo export x=3"
|
||||
prop_checkSudoArgs3 = verifyNot checkSudoArgs "sudo ls /usr/local/protected"
|
||||
prop_checkSudoArgs4 = verifyNot checkSudoArgs "sudo ls && export x=3"
|
||||
prop_checkSudoArgs5 = verifyNot checkSudoArgs "sudo echo ls"
|
||||
checkSudoArgs _ t@(T_SimpleCommand _ _ (_:rest))
|
||||
| t `isCommand` "sudo" = checkArgs args
|
||||
where checkArgs (x:xs)
|
||||
| x `elem` prohibitedArguments = warn (getId t) 2232 $ "Can't use sudo with " ++ x
|
||||
| x `elem` commonCommands = return ()
|
||||
| otherwise = checkArgs xs
|
||||
checkArgs [] = return ()
|
||||
args = map onlyLiteralString $ concat $ map getWordParts rest
|
||||
prohibitedArguments = ["cd", "export"]
|
||||
checkSudoArgs _ _ = return ()
|
||||
|
||||
prop_checkPS11 = verify checkPS1Assignments "PS1='\\033[1;35m\\$ '"
|
||||
prop_checkPS11a= verify checkPS1Assignments "export PS1='\\033[1;35m\\$ '"
|
||||
prop_checkPSf2 = verify checkPS1Assignments "PS1='\\h \\e[0m\\$ '"
|
||||
|
|
Loading…
Reference in New Issue