X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmodels%2Foauth%2Foauth-token.ts;h=27e643aa71cf0aba93e18fb8a15d4903d6c36c2a;hb=e62f03ae0412f4efa62917d8741bc1a39e8ed7fc;hp=38953e8ad0aefd1b5a48d6dbeec5291f8e9e5d6e;hpb=716adfaed6d8e549521b6dfe8bf5960d9f73bbd6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/models/oauth/oauth-token.ts b/server/models/oauth/oauth-token.ts index 38953e8ad..27e643aa7 100644 --- a/server/models/oauth/oauth-token.ts +++ b/server/models/oauth/oauth-token.ts @@ -1,3 +1,4 @@ +import { Transaction } from 'sequelize' import { AfterDestroy, AfterUpdate, @@ -11,15 +12,14 @@ import { Table, UpdatedAt } from 'sequelize-typescript' +import { TokensCache } from '@server/lib/auth/tokens-cache' +import { MUserAccountId } from '@server/types/models' +import { MOAuthTokenUser } from '@server/types/models/oauth/oauth-token' import { logger } from '../../helpers/logger' -import { UserModel } from '../account/user' -import { OAuthClientModel } from './oauth-client' -import { Transaction } from 'sequelize' import { AccountModel } from '../account/account' +import { UserModel } from '../account/user' import { ActorModel } from '../activitypub/actor' -import { clearCacheByToken } from '../../lib/oauth-model' -import * as Bluebird from 'bluebird' -import { MOAuthTokenUser } from '@server/typings/models/oauth/oauth-token' +import { OAuthClientModel } from './oauth-client' export type OAuthTokenInfo = { refreshToken: string @@ -27,9 +27,7 @@ export type OAuthTokenInfo = { client: { id: number } - user: { - id: number - } + user: MUserAccountId token: MOAuthTokenUser } @@ -80,7 +78,7 @@ enum ScopeNames { } ] }) -export class OAuthTokenModel extends Model { +export class OAuthTokenModel extends Model { @AllowNull(false) @Column @@ -134,7 +132,7 @@ export class OAuthTokenModel extends Model { @AfterUpdate @AfterDestroy static removeTokenCache (token: OAuthTokenModel) { - return clearCacheByToken(token.accessToken) + return TokensCache.Instance.clearCacheByToken(token.accessToken) } static loadByRefreshToken (refreshToken: string) { @@ -174,7 +172,7 @@ export class OAuthTokenModel extends Model { }) } - static getByTokenAndPopulateUser (bearerToken: string): Bluebird { + static getByTokenAndPopulateUser (bearerToken: string): Promise { const query = { where: { accessToken: bearerToken @@ -190,7 +188,7 @@ export class OAuthTokenModel extends Model { }) } - static getByRefreshTokenAndPopulateUser (refreshToken: string): Bluebird { + static getByRefreshTokenAndPopulateUser (refreshToken: string): Promise { const query = { where: { refreshToken @@ -207,6 +205,8 @@ export class OAuthTokenModel extends Model { } static deleteUserToken (userId: number, t?: Transaction) { + TokensCache.Instance.deleteUserToken(userId) + const query = { where: { userId