azure.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /* global WIKI */
  2. // ------------------------------------
  3. // Azure AD Account
  4. // ------------------------------------
  5. const AzureAdOAuth2Strategy = require('passport-azure-ad-oauth2').Strategy
  6. module.exports = {
  7. key: 'azure',
  8. title: 'Azure Active Directory',
  9. useForm: false,
  10. props: {
  11. clientId: String,
  12. clientSecret: String,
  13. resource: {
  14. type: String,
  15. default: '00000002-0000-0000-c000-000000000000'
  16. },
  17. tenant: {
  18. type: String,
  19. default: 'YOUR_TENANT.onmicrosoft.com'
  20. }
  21. },
  22. init (passport, conf) {
  23. const jwt = require('jsonwebtoken')
  24. passport.use('azure_ad_oauth2',
  25. new AzureAdOAuth2Strategy({
  26. clientID: conf.clientId,
  27. clientSecret: conf.clientSecret,
  28. callbackURL: conf.callbackURL,
  29. resource: conf.resource,
  30. tenant: conf.tenant
  31. }, (accessToken, refreshToken, params, profile, cb) => {
  32. let waadProfile = jwt.decode(params.id_token)
  33. waadProfile.id = waadProfile.oid
  34. waadProfile.provider = 'azure'
  35. WIKI.db.users.processProfile(waadProfile).then((user) => {
  36. return cb(null, user) || true
  37. }).catch((err) => {
  38. return cb(err, null) || true
  39. })
  40. }
  41. ))
  42. }
  43. }