Skip to content

Commit 7f56be6

Browse files
authored
Merge pull request #216 from asger-semmle/lusca-csrf
Approved by esben-semmle
2 parents 4617827 + 4797924 commit 7f56be6

File tree

4 files changed

+39
-4
lines changed

4 files changed

+39
-4
lines changed

change-notes/1.19/analysis-javascript.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,5 +22,6 @@
2222
| Regular expression injection | Fewer false-positive results | This rule now identifies calls to `String.prototype.search` with more precision. |
2323
| Unbound event handler receiver | Fewer false-positive results | This rule now recognizes additional ways class methods can be bound. |
2424
| Remote property injection | Fewer results | The precision of this rule has been revised to "medium". Results are no longer shown on LGTM by default. |
25+
| Missing CSRF middleware | Fewer false-positive results | This rule now recognizes additional CSRF protection middlewares. |
2526

2627
## Changes to QL libraries

javascript/ql/src/Security/CWE-352/MissingCsrfMiddleware.ql

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -38,12 +38,15 @@ predicate hasCookieMiddleware(Express::RouteHandlerExpr expr, Express::RouteHand
3838
* // protected from CSRF
3939
* })
4040
* ```
41-
*
42-
* Currently the predicate only detects `csurf`-based protectors.
4341
*/
4442
DataFlow::CallNode csrfMiddlewareCreation() {
45-
exists (DataFlow::ModuleImportNode mod | result = mod.getACall() |
46-
mod.getPath() = "csurf"
43+
exists (DataFlow::SourceNode callee | result = callee.getACall() |
44+
callee = DataFlow::moduleImport("csurf")
45+
or
46+
callee = DataFlow::moduleImport("lusca") and
47+
exists(result.getOptionArgument(0, "csrf"))
48+
or
49+
callee = DataFlow::moduleMember("lusca", "csrf")
4750
)
4851
}
4952

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,5 @@
11
| MissingCsrfMiddlewareBad.js:7:9:7:22 | cookieParser() | This cookie middleware is serving a request handler $@ without CSRF protection. | MissingCsrfMiddlewareBad.js:10:26:11:1 | functio ... es) {\\n} | here |
22
| csurf_api_example.js:39:37:39:50 | cookieParser() | This cookie middleware is serving a request handler $@ without CSRF protection. | csurf_api_example.js:39:53:41:3 | functio ... e')\\n } | here |
33
| csurf_example.js:18:9:18:22 | cookieParser() | This cookie middleware is serving a request handler $@ without CSRF protection. | csurf_example.js:29:40:31:1 | functio ... sed')\\n} | here |
4+
| lusca_example.js:9:9:9:22 | cookieParser() | This cookie middleware is serving a request handler $@ without CSRF protection. | lusca_example.js:23:42:25:1 | functio ... sed')\\n} | here |
5+
| lusca_example.js:9:9:9:22 | cookieParser() | This cookie middleware is serving a request handler $@ without CSRF protection. | lusca_example.js:27:40:29:1 | functio ... sed')\\n} | here |
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
var express = require('express')
2+
var cookieParser = require('cookie-parser')
3+
var bodyParser = require('body-parser')
4+
5+
var parseForm = bodyParser.urlencoded({ extended: false })
6+
var lusca = require('lusca');
7+
8+
var app = express()
9+
app.use(cookieParser())
10+
11+
app.post('/process', parseForm, lusca.csrf(), function (req, res) { // OK
12+
res.send('data is being processed')
13+
})
14+
15+
app.post('/process', parseForm, lusca({csrf:true}), function (req, res) { // OK
16+
res.send('data is being processed')
17+
})
18+
19+
app.post('/process', parseForm, lusca({csrf:{}}), function (req, res) { // OK
20+
res.send('data is being processed')
21+
})
22+
23+
app.post('/process', parseForm, lusca(), function (req, res) { // NOT OK - missing csrf option
24+
res.send('data is being processed')
25+
})
26+
27+
app.post('/process_unsafe', parseForm, function (req, res) { // NOT OK
28+
res.send('data is being processed')
29+
})

0 commit comments

Comments
 (0)