authentication.js 1.73 KB
Newer Older
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 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
const _ = require('lodash')

/* global WIKI */

// ------------------------------------
// Rocket.chat Account
// ------------------------------------

const OAuth2Strategy = require('passport-oauth2').Strategy

module.exports = {
  init (passport, conf) {
    const siteURL = conf.siteURL.slice(-1) === '/' ? conf.siteURL.slice(0, -1) : conf.siteURL

    OAuth2Strategy.prototype.userProfile = function (accessToken, cb) {
      this._oauth2.get(`${siteURL}/api/v1/me`, accessToken, (err, body, res) => {
        if (err) {
          WIKI.logger.warn('Rocket.chat - Failed to fetch user profile.')
          return cb(err)
        }
        try {
          const usr = JSON.parse(body)
          cb(null, {
            id: usr._id,
            displayName: _.isEmpty(usr.name) ? usr.username : usr.name,
            email: usr.email,
            picture: usr.avatarUrl
          })
        } catch (err) {
          WIKI.logger.warn('Rocket.chat - Failed to parse user profile.')
          cb(err)
        }
      })
    }

    passport.use('rocketchat',
      new OAuth2Strategy({
        authorizationURL: `${siteURL}/oauth/authorize`,
        tokenURL: `${siteURL}/oauth/token`,
        clientID: conf.clientId,
        clientSecret: conf.clientSecret,
        callbackURL: conf.callbackURL,
        passReqToCallback: true
      }, async (req, accessToken, refreshToken, profile, cb) => {
        try {
          const user = await WIKI.models.users.processProfile({
            providerKey: req.params.strategy,
            profile
          })
          cb(null, user)
        } catch (err) {
          cb(err, null)
        }
      })
    )
  },
  logout (conf) {
    if (!conf.logoutURL) {
      return '/'
    } else {
      return conf.logoutURL
    }
  }
}