1 const mongoose = require('mongoose')
3 const logger = require('../helpers/logger')
5 // ---------------------------------------------------------------------------
7 const OAuthTokenSchema = mongoose.Schema({
9 accessTokenExpiresAt: Date,
10 client: { type: mongoose.Schema.Types.ObjectId, ref: 'OAuthClient' },
12 refreshTokenExpiresAt: Date,
13 user: { type: mongoose.Schema.Types.ObjectId, ref: 'User' }
16 OAuthTokenSchema.path('accessToken').required(true)
17 OAuthTokenSchema.path('client').required(true)
18 OAuthTokenSchema.path('user').required(true)
20 OAuthTokenSchema.statics = {
21 getByRefreshTokenAndPopulateClient,
22 getByTokenAndPopulateUser,
23 getByRefreshTokenAndPopulateUser,
27 mongoose.model('OAuthToken', OAuthTokenSchema)
29 // ---------------------------------------------------------------------------
31 function getByRefreshTokenAndPopulateClient (refreshToken) {
32 return this.findOne({ refreshToken: refreshToken }).populate('client').exec().then(function (token) {
33 if (!token) return token
36 refreshToken: token.refreshToken,
37 refreshTokenExpiresAt: token.refreshTokenExpiresAt,
39 id: token.client._id.toString()
47 }).catch(function (err) {
48 logger.info('getRefreshToken error.', { error: err })
52 function getByTokenAndPopulateUser (bearerToken) {
53 return this.findOne({ accessToken: bearerToken }).populate('user').exec()
56 function getByRefreshTokenAndPopulateUser (refreshToken) {
57 return this.findOne({ refreshToken: refreshToken }).populate('user').exec()
60 function removeByUserId (userId, callback) {
61 return this.remove({ user: userId }, callback)