All files / middlewares accessTokenParser.js

26.67% Statements 4/15
0% Branches 0/2
25% Functions 1/4
26.67% Lines 4/15

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 2815x   15x   15x 15x                                            
const debug = require('debug')('crowi:middlewares:accessTokenParser')
 
const { parseAccessToken } = require('../util/accessTokenParser')
 
module.exports = (crowi, app) => {
  return (req, res, next) => {
    const accessToken = parseAccessToken(req)
    if (!accessToken) {
      return next()
    }
 
    var User = crowi.model('User')
 
    debug('accessToken is', accessToken)
    User.findUserByApiToken(accessToken)
      .then(function(userData) {
        req.user = userData
        req.skipCsrfVerify = true
        debug('Access token parsed: skipCsrfVerify')
 
        next()
      })
      .catch(function(err) {
        next()
      })
  }
}