Skip to content

Commit

Permalink
Merge pull request #59 from sashamelentyev/feat/pkgfunargs
Browse files Browse the repository at this point in the history
feat: add pkgFunArgs
  • Loading branch information
sashamelentyev authored Aug 26, 2022
2 parents 6863d7f + cc47a16 commit fdf62cc
Showing 1 changed file with 76 additions and 70 deletions.
146 changes: 76 additions & 70 deletions pkg/analyzer/analyzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,84 +60,17 @@ func run(pass *analysis.Pass) (interface{}, error) {
insp.Preorder(types, func(node ast.Node) {
switch n := node.(type) {
case *ast.CallExpr:
selectorExpr, ok := n.Fun.(*ast.SelectorExpr)
fun, ok := n.Fun.(*ast.SelectorExpr)
if !ok {
return
}

ident, ok := selectorExpr.X.(*ast.Ident)
pkg, ok := fun.X.(*ast.Ident)
if !ok {
return
}

switch ident.Name {
case "http":
switch selectorExpr.Sel.Name {
case "NewRequest":
if !lookupFlag(pass, HTTPMethodFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 3, 0, token.STRING); basicLit != nil {
checkHTTPMethod(pass, basicLit)
}

case "NewRequestWithContext":
if !lookupFlag(pass, HTTPMethodFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 4, 1, token.STRING); basicLit != nil {
checkHTTPMethod(pass, basicLit)
}

case "Error":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 3, 2, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "StatusText":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 1, 0, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "Redirect":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 4, 3, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "RedirectHandler":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 2, 1, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}
}
default:
if selectorExpr.Sel.Name == "WriteHeader" {
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(n.Args, 1, 0, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}
}
}
pkgFunArgs(pass, pkg, fun, n.Args)

case *ast.BasicLit:
if lookupFlag(pass, TimeWeekdayFlag) {
Expand Down Expand Up @@ -281,6 +214,79 @@ func run(pass *analysis.Pass) (interface{}, error) {
return nil, nil
}

// pkgFunArgs checks arguments of function from package.
func pkgFunArgs(pass *analysis.Pass, pkg *ast.Ident, fun *ast.SelectorExpr, args []ast.Expr) {
switch pkg.Name {
case "http":
switch fun.Sel.Name {
case "NewRequest":
if !lookupFlag(pass, HTTPMethodFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 3, 0, token.STRING); basicLit != nil {
checkHTTPMethod(pass, basicLit)
}

case "NewRequestWithContext":
if !lookupFlag(pass, HTTPMethodFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 4, 1, token.STRING); basicLit != nil {
checkHTTPMethod(pass, basicLit)
}

case "Error":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 3, 2, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "StatusText":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 1, 0, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "Redirect":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 4, 3, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}

case "RedirectHandler":
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 2, 1, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}
}
default:
if fun.Sel.Name == "WriteHeader" {
if !lookupFlag(pass, HTTPStatusCodeFlag) {
return
}

if basicLit := getBasicLitFromArgs(args, 1, 0, token.INT); basicLit != nil {
checkHTTPStatusCode(pass, basicLit)
}
}
}
}

// ifstmt checks X and Y in if-statement.
func ifstmt(pass *analysis.Pass, x *ast.SelectorExpr, y *ast.BasicLit) {
switch x.Sel.Name {
case "StatusCode":
Expand Down

0 comments on commit fdf62cc

Please sign in to comment.