Browse Source

feat: okta auth module

pull/835/head
Nick 5 years ago
parent
commit
d80bb928f7
2 changed files with 29 additions and 10 deletions
  1. 23
      server/modules/authentication/okta/authentication.js
  2. 16
      server/modules/authentication/okta/definition.yml

23
server/modules/authentication/okta/authentication.js

@ -5,6 +5,7 @@
// ------------------------------------ // ------------------------------------
const OktaStrategy = require('passport-okta-oauth').Strategy const OktaStrategy = require('passport-okta-oauth').Strategy
const _ = require('lodash')
module.exports = { module.exports = {
init (passport, conf) { init (passport, conf) {
@ -15,14 +16,20 @@ module.exports = {
clientSecret: conf.clientSecret, clientSecret: conf.clientSecret,
idp: conf.idp, idp: conf.idp,
callbackURL: conf.callbackURL, callbackURL: conf.callbackURL,
response_type: 'code',
scope: ['openid', 'email', 'profile']
}, (accessToken, refreshToken, profile, cb) => {
WIKI.models.users.processProfile(profile).then((user) => {
return cb(null, user) || true
}).catch((err) => {
return cb(err, null) || true
})
response_type: 'code'
}, async (accessToken, refreshToken, profile, cb) => {
try {
const user = await WIKI.models.users.processProfile({
profile: {
...profile,
picture: _.get(profile, '_json.profile', '')
},
providerKey: 'okta'
})
cb(null, user)
} catch (err) {
cb(err, null)
}
}) })
) )
} }

16
server/modules/authentication/okta/definition.yml

@ -5,18 +5,30 @@ author: requarks.io
logo: https://static.requarks.io/logo/okta.svg logo: https://static.requarks.io/logo/okta.svg
color: blue darken-1 color: blue darken-1
website: https://www.okta.com/ website: https://www.okta.com/
isAvailable: true
useForm: false useForm: false
scopes:
- profile
- email
- openid
props: props:
clientId: clientId:
title: Client ID
type: String type: String
hint: 20 chars alphanumeric string hint: 20 chars alphanumeric string
order: 2
clientSecret: clientSecret:
title: Client Secret
type: String type: String
hint: 40 chars alphanumeric string with a hyphen(s) hint: 40 chars alphanumeric string with a hyphen(s)
order: 3
idp: idp:
title: Identity Provider ID (idp) title: Identity Provider ID (idp)
type: String type: String
hint: (optional) 20 chars alphanumeric string
hint: (Optional) - 20 chars alphanumeric string
order: 4
audience: audience:
title: Org URL
type: String type: String
hint: Okta domain (e.g. https://example.okta.com, https://example.oktapreview.com)
hint: Okta organization URL (e.g. https://example.okta.com, https://example.oktapreview.com), found on the Developer Dashboard, in the upper right.
order: 1
Loading…
Cancel
Save