Add Oauth2 authentication to your Meteor app, supports Meteor 1.5+
- Add required dependencies:
meteor add accounts-base accounts-oauth service-configuration \
random oauth oauth2 http
meteor npm install meteor-u5auth
- Configure Service
Add (or update) a
service configuration
for the u5auth
service (on the server side only, so keep it in the
./server
directory):
import { getLiveToken, setU5AuthDebug } from 'meteor-u5auth'
Meteor.startup(() => {
if ()
ServiceConfiguration.configurations.upsert({
service: 'u5auth'
}, {
$set: {
clientId: process.env.OAUTH2_ID || 'your-client-id',
secret: process.env.OAUTH2_SECRET || 'your-client-secret',
issuer: process.env.OAUTH2_SITE || 'https://my-oauth2-service.com',
requestPermissions: [ 'email', 'userinfo', 'phone_number', 'sub' ],
ttl: 60 /* minutes */ * 60 /* seconds */
}
})
})
clientId
andsecret
must be issued by your OAuth2 provider.issuer
is the url pointing at your auth provider.- Ensure the
ttl
is in line with the expiry of your tokens, 1 hour in the code snippet above. Thettl
will be used to get a new token, if 90% of the ttl have passed. requestPermissions
are the scopes you request with the token.- It is good practice to keep live/production secrets out of the code.
Therefore, you may want to use the approach using environment variables demonstrated above (
secret: process.env.OAUTH2_SECRET || 'test-secret'
).
See also the example app.
On the client, use Meteor.loginWithU5Auth()
:
Meteor.loginWithU5Auth({}, err => {
if (err) {
throw err
}
})
Use Meteor.logout
:
Meteor.logout()
This may not destroy your session at the auth provider. As a result, the next login attempt may authorize you without prompting for (another) user/password. In order to fully log out, you may have to make an additional call (via Ajax?) to your auth provider.
The OAuth2 token received during login can be used to make calls to other APIs or services that support your auth provider. The token can be used both client and server side like this:
import { getLiveToken } from 'meteor-u5auth'
function someFunction() {
getLiveToken().then(token => {
// now use the token
...
})
}
Only use getLiveToken
when you know the user is logged in. If in doubt,
check e.g. if Meteor.user()
is available.
getLiveToken
will ensure that the token is not expired, i.e. it will refresh the access token (via the refresh token, if available) before resolving the promise.
The userinfo provided by the auth provider is available as:
Meteor.user().profile
In order to ensure userinfo is up-to-date, call refreshUserinfo
:
import { refreshUserinfo } from 'meteor-u5auth'
function someFunction() {
refreshUserinfo().then(() => console.log('refreshed'))
}
Now Meteor.user().profile
will have updated details from the auth provider.
In order to debug anything related to this package, call setU5AuthDebug
on the server:
import { setU5AuthDebug } from 'meteor-u5auth'
Meteor.startup(() => {
setU5AuthDebug()
}
The server logs will now contain a detailed log under a prefix. Beware, though, that access tokens and refresh tokens are then logged in verbatim, which may be a security risk.