# Cross-Site Request Forgery (CSRF) (CWE-352) The web application does not, or can not, sufficiently verify whether a well-formed, valid, consistent request was intentionally provided by the user who submitted the request. **Stack:** Go - Prevalence: Média 3 linguagens cobertas - Impact: Alto 3 regras de severidade alta - Prevention: Documentada 3 exemplos de correção **OWASP:** Broken Access Control (A01:2021-Broken Access Control) - #1 ## Description When a web server is designed to receive a request from a client without any mechanism for verifying that it was intentionally sent, then it might be possible for an attacker to trick a client into making an unintentional request to the web server which will be treated as an authentic request. ## Prevention Estratégias de prevenção para Cross-Site Request Forgery baseadas em 1 regras de detecção do Shoulder. ### Go Add CSRF middleware to protect state-changing endpoints ## Warning Signs - [HIGH] State-changing endpoints lack CSRF protection ## Consequences - Modificar dados da aplicação - Obter privilégios - Executar código não autorizado ## Mitigations - Use tokens anti-CSRF em todas as requisições que alteram estado - Verifique o cabeçalho Referer - Use o atributo SameSite em cookies ## Detection - Total rules: 3 - Languages: javascript, typescript, python, go ## Rules by Language ### Go (1 rules) - **Missing CSRF Protection (Gin)** [HIGH]: State-changing endpoints lack CSRF token protection. - Remediation: Add CSRF middleware using gin-csrf. ```go import "github.com/utrack/gin-csrf" r := gin.Default() r.Use(csrf.Middleware(csrf.Options{ Secret: os.Getenv("CSRF_SECRET"), })) r.POST("/transfer", transferHandler) ``` Learn more: https://shoulder.dev/learn/go/cwe-352/csrf-protection