Skip to content

Commit

Permalink
feat: okta auth module
Browse files Browse the repository at this point in the history
  • Loading branch information
NGPixel committed Apr 28, 2019
1 parent c03dae9 commit d80bb92
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 10 deletions.
23 changes: 15 additions & 8 deletions server/modules/authentication/okta/authentication.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
// ------------------------------------

const OktaStrategy = require('passport-okta-oauth').Strategy
const _ = require('lodash')

module.exports = {
init (passport, conf) {
Expand All @@ -15,14 +16,20 @@ module.exports = {
clientSecret: conf.clientSecret,
idp: conf.idp,
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)
}
})
)
}
Expand Down
16 changes: 14 additions & 2 deletions server/modules/authentication/okta/definition.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,30 @@ author: requarks.io
logo: https://static.requarks.io/logo/okta.svg
color: blue darken-1
website: https://www.okta.com/
isAvailable: true
useForm: false
scopes:
- profile
- email
- openid
props:
clientId:
title: Client ID
type: String
hint: 20 chars alphanumeric string
order: 2
clientSecret:
title: Client Secret
type: String
hint: 40 chars alphanumeric string with a hyphen(s)
order: 3
idp:
title: Identity Provider ID (idp)
type: String
hint: (optional) 20 chars alphanumeric string
hint: (Optional) - 20 chars alphanumeric string
order: 4
audience:
title: Org URL
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

0 comments on commit d80bb92

Please sign in to comment.