]>
Commit | Line | Data |
---|---|---|
69b0a27c C |
1 | const mongoose = require('mongoose') |
2 | ||
2f372a86 C |
3 | const logger = require('../helpers/logger') |
4 | ||
69b0a27c C |
5 | // --------------------------------------------------------------------------- |
6 | ||
7 | const OAuthTokenSchema = mongoose.Schema({ | |
8 | accessToken: String, | |
2f372a86 | 9 | accessTokenExpiresAt: Date, |
69b0a27c C |
10 | client: { type: mongoose.Schema.Types.ObjectId, ref: 'OAuthClient' }, |
11 | refreshToken: String, | |
2f372a86 | 12 | refreshTokenExpiresAt: Date, |
69b0a27c C |
13 | user: { type: mongoose.Schema.Types.ObjectId, ref: 'User' } |
14 | }) | |
15 | ||
16 | OAuthTokenSchema.path('accessToken').required(true) | |
17 | OAuthTokenSchema.path('client').required(true) | |
18 | OAuthTokenSchema.path('user').required(true) | |
19 | ||
20 | OAuthTokenSchema.statics = { | |
c4403b29 C |
21 | getByRefreshTokenAndPopulateClient, |
22 | getByTokenAndPopulateUser, | |
bf2fc85c | 23 | getByRefreshTokenAndPopulateUser, |
c4403b29 | 24 | removeByUserId |
69b0a27c C |
25 | } |
26 | ||
27 | mongoose.model('OAuthToken', OAuthTokenSchema) | |
28 | ||
29 | // --------------------------------------------------------------------------- | |
30 | ||
2f372a86 | 31 | function getByRefreshTokenAndPopulateClient (refreshToken) { |
32bb4156 | 32 | return this.findOne({ refreshToken: refreshToken }).populate('client').exec().then(function (token) { |
2f372a86 C |
33 | if (!token) return token |
34 | ||
35 | const tokenInfos = { | |
36 | refreshToken: token.refreshToken, | |
37 | refreshTokenExpiresAt: token.refreshTokenExpiresAt, | |
38 | client: { | |
39 | id: token.client._id.toString() | |
40 | }, | |
371fa093 C |
41 | user: { |
42 | id: token.user | |
43 | } | |
2f372a86 C |
44 | } |
45 | ||
46 | return tokenInfos | |
47 | }).catch(function (err) { | |
48 | logger.info('getRefreshToken error.', { error: err }) | |
49 | }) | |
69b0a27c C |
50 | } |
51 | ||
2f372a86 | 52 | function getByTokenAndPopulateUser (bearerToken) { |
32bb4156 | 53 | return this.findOne({ accessToken: bearerToken }).populate('user').exec() |
69b0a27c | 54 | } |
2f372a86 | 55 | |
bf2fc85c C |
56 | function getByRefreshTokenAndPopulateUser (refreshToken) { |
57 | return this.findOne({ refreshToken: refreshToken }).populate('user').exec() | |
2f372a86 | 58 | } |
b81929a0 C |
59 | |
60 | function removeByUserId (userId, callback) { | |
61 | return this.remove({ user: userId }, callback) | |
62 | } |