Refractored code a little bit

This commit is contained in:
Dimitar Banchev 2024-08-21 15:29:34 +02:00 committed by Cosmin Cojocar
parent 0eb8143c23
commit 3f6e1e7326

View file

@ -23,42 +23,46 @@ func (r *usesHardcodedIV) Match(n ast.Node, c *gosec.Context) (*issue.Issue, err
funcCall := n.(*ast.CallExpr) funcCall := n.(*ast.CallExpr)
// cast to a function call from an object and get the function part; example: a.doSomething() // cast to a function call from an object and get the function part; example: a.doSomething()
funcSelector, exists := funcCall.Fun.(*ast.SelectorExpr)
if exists { if funcSelector, isSelector := funcCall.Fun.(*ast.SelectorExpr); isSelector {
//Iterate trough the wanted functions
for functionName, functionNumArgsAndNoncePosArr := range r.trackedFunctions {
// Check if the call is actually made from an object // Check if the call is actually made from an object
if _, hasX := funcSelector.X.(*ast.Ident); hasX { if _, hasX := funcSelector.X.(*ast.Ident); hasX {
// Check if the function name matches with the one we look for, and if the function accepts an exact number of arguments(Function signature) //Iterate trough the wanted functions
for functionName, functionNumArgsAndNoncePosArr := range r.trackedFunctions {
// Check if the function name matches with the one we look for, and if the function accepts an exact number of arguments(rough function signature check)
if funcSelector.Sel.Name == functionName && len(funcCall.Args) == functionNumArgsAndNoncePosArr[0] { if funcSelector.Sel.Name == functionName && len(funcCall.Args) == functionNumArgsAndNoncePosArr[0] {
// Check the type of the passed argument to the function // Check the type of the passed argument to the function
switch funcCall.Args[functionNumArgsAndNoncePosArr[1]].(type) { switch trackedFunctionPassedArgType := funcCall.Args[functionNumArgsAndNoncePosArr[1]].(type) {
// {} used
case *ast.CompositeLit: case *ast.CompositeLit:
// Check if the argument is static array // Check if the argument is static array
if _, isArray := funcCall.Args[functionNumArgsAndNoncePosArr[1]].(*ast.CompositeLit).Type.(*ast.ArrayType); isArray { if _, isArray := trackedFunctionPassedArgType.Type.(*ast.ArrayType); isArray {
return c.NewIssue(n, r.ID(), r.What+" by passing hardcoded byte array", r.Severity, r.Confidence), nil return c.NewIssue(n, r.ID(), r.What+" by passing hardcoded byte array", r.Severity, r.Confidence), nil
} }
// () used
case *ast.CallExpr: case *ast.CallExpr:
// Check if it's a function call, because []byte() is a function call, and also check if the number of arguments to this call is only 1 // Check if it's a function call, because []byte() is a function call, and also check if the number of arguments to this call is only 1
switch funcCall.Args[functionNumArgsAndNoncePosArr[1]].(*ast.CallExpr).Fun.(type) { switch trackedFunctionPassedArgType.Fun.(type) {
case *ast.ArrayType: case *ast.ArrayType:
return c.NewIssue(n, r.ID(), r.What+" by converting static string to a byte array", r.Severity, r.Confidence), nil return c.NewIssue(n, r.ID(), r.What+" by converting static string to a byte array", r.Severity, r.Confidence), nil
// Check if it's an anonymous function // Check if the argument passed is another function
case *ast.FuncLit: case *ast.FuncLit:
functionCalled, _ := funcCall.Args[functionNumArgsAndNoncePosArr[1]].(*ast.CallExpr).Fun.(*ast.FuncLit) functionCalled, _ := trackedFunctionPassedArgType.Fun.(*ast.FuncLit)
// Check the type of the last statement in the anonymous function // Check the type of the last statement in the anonymous function
switch functionCalled.Body.List[len(functionCalled.Body.List)-1].(type) { switch calledFunctionLastInstructionType := functionCalled.Body.List[len(functionCalled.Body.List)-1].(type) {
case *ast.IfStmt: case *ast.IfStmt:
ifStatementContent := functionCalled.Body.List[len(functionCalled.Body.List)-1].(*ast.IfStmt).Body.List ifStatementContent := calledFunctionLastInstructionType.Body.List
// check if the if statement has return statement // check if the if statement has return statement
if retStatement, isReturn := ifStatementContent[len(ifStatementContent)-1].(*ast.ReturnStmt); isReturn { if retStatement, isReturn := ifStatementContent[len(ifStatementContent)-1].(*ast.ReturnStmt); isReturn {
@ -80,7 +84,7 @@ func (r *usesHardcodedIV) Match(n ast.Node, c *gosec.Context) (*issue.Issue, err
} }
case *ast.ReturnStmt: case *ast.ReturnStmt:
argInNestedFunc := functionCalled.Body.List[len(functionCalled.Body.List)-1].(*ast.ReturnStmt).Results[0] argInNestedFunc := calledFunctionLastInstructionType.Results[0]
switch argInNestedFunc.(type) { switch argInNestedFunc.(type) {
case *ast.CompositeLit: case *ast.CompositeLit:
// Check if the argument is static array // Check if the argument is static array