123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- import {
- AfterDestroy,
- AfterUpdate,
- AllowNull,
- BelongsTo,
- Column,
- CreatedAt,
- ForeignKey,
- Model,
- Scopes,
- Table,
- UpdatedAt
- } from 'sequelize-typescript'
- 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 { ActorModel } from '../activitypub/actor'
- import { clearCacheByToken } from '../../lib/oauth-model'
- export type OAuthTokenInfo = {
- refreshToken: string
- refreshTokenExpiresAt: Date,
- client: {
- id: number
- },
- user: {
- id: number
- }
- }
- enum ScopeNames {
- WITH_USER = 'WITH_USER'
- }
- @Scopes({
- [ScopeNames.WITH_USER]: {
- include: [
- {
- model: () => UserModel.unscoped(),
- required: true,
- include: [
- {
- attributes: [ 'id' ],
- model: () => AccountModel.unscoped(),
- required: true,
- include: [
- {
- attributes: [ 'id', 'url' ],
- model: () => ActorModel.unscoped(),
- required: true
- }
- ]
- }
- ]
- }
- ]
- }
- })
- @Table({
- tableName: 'oAuthToken',
- indexes: [
- {
- fields: [ 'refreshToken' ],
- unique: true
- },
- {
- fields: [ 'accessToken' ],
- unique: true
- },
- {
- fields: [ 'userId' ]
- },
- {
- fields: [ 'oAuthClientId' ]
- }
- ]
- })
- export class OAuthTokenModel extends Model<OAuthTokenModel> {
- @AllowNull(false)
- @Column
- accessToken: string
- @AllowNull(false)
- @Column
- accessTokenExpiresAt: Date
- @AllowNull(false)
- @Column
- refreshToken: string
- @AllowNull(false)
- @Column
- refreshTokenExpiresAt: Date
- @CreatedAt
- createdAt: Date
- @UpdatedAt
- updatedAt: Date
- @ForeignKey(() => UserModel)
- @Column
- userId: number
- @BelongsTo(() => UserModel, {
- foreignKey: {
- allowNull: false
- },
- onDelete: 'cascade'
- })
- User: UserModel
- @ForeignKey(() => OAuthClientModel)
- @Column
- oAuthClientId: number
- @BelongsTo(() => OAuthClientModel, {
- foreignKey: {
- allowNull: false
- },
- onDelete: 'cascade'
- })
- OAuthClients: OAuthClientModel[]
- @AfterUpdate
- @AfterDestroy
- static removeTokenCache (token: OAuthTokenModel) {
- return clearCacheByToken(token.accessToken)
- }
- static getByRefreshTokenAndPopulateClient (refreshToken: string) {
- const query = {
- where: {
- refreshToken: refreshToken
- },
- include: [ OAuthClientModel ]
- }
- return OAuthTokenModel.findOne(query)
- .then(token => {
- if (!token) return null
- return {
- refreshToken: token.refreshToken,
- refreshTokenExpiresAt: token.refreshTokenExpiresAt,
- client: {
- id: token.oAuthClientId
- },
- user: {
- id: token.userId
- }
- } as OAuthTokenInfo
- })
- .catch(err => {
- logger.error('getRefreshToken error.', { err })
- throw err
- })
- }
- static getByTokenAndPopulateUser (bearerToken: string) {
- const query = {
- where: {
- accessToken: bearerToken
- }
- }
- return OAuthTokenModel.scope(ScopeNames.WITH_USER).findOne(query).then(token => {
- if (token) token['user'] = token.User
- return token
- })
- }
- static getByRefreshTokenAndPopulateUser (refreshToken: string) {
- const query = {
- where: {
- refreshToken: refreshToken
- }
- }
- return OAuthTokenModel.scope(ScopeNames.WITH_USER)
- .findOne(query)
- .then(token => {
- if (token) {
- token['user'] = token.User
- return token
- } else {
- return new OAuthTokenModel()
- }
- })
- }
- static deleteUserToken (userId: number, t?: Transaction) {
- const query = {
- where: {
- userId
- },
- transaction: t
- }
- return OAuthTokenModel.destroy(query)
- }
- }
|