const Promise = require('bluebird') const crypto = require('crypto') const passportJWT = require('passport-jwt') module.exports = { sanitizeCommitUser (user) { // let wlist = new RegExp('[^a-zA-Z0-9-_.\',& ' + appdata.regex.cjk + appdata.regex.arabic + ']', 'g') // return { // name: _.chain(user.name).replace(wlist, '').trim().value(), // email: appconfig.git.showUserEmail ? user.email : appconfig.git.serverEmail // } }, /** * Generate a random token * * @param {any} length * @returns */ async generateToken (length) { return Promise.fromCallback(clb => { crypto.randomBytes(length, clb) }).then(buf => { return buf.toString('hex') }) }, extractJWT: passportJWT.ExtractJwt.fromExtractors([ passportJWT.ExtractJwt.fromAuthHeaderAsBearerToken(), (req) => { let token = null if (req && req.cookies) { token = req.cookies['jwt'] } // Force uploads to use Auth headers if (req.path.toLowerCase() === '/u') { return null } return token } ]) }