chore: 將令牌檢測函數移動到 TokenManager

* 這樣才叫 TokenManager 嘛X
This commit is contained in:
CrescentLeaf
2025-09-25 14:18:50 +08:00
parent b6be09ef7c
commit 692eb3d2a3
2 changed files with 13 additions and 7 deletions

View File

@@ -3,6 +3,7 @@ import ApiManager from "./ApiManager.ts"
import { CallMethod, ClientEvent } from './ApiDeclare.ts'
import User from "../data/User.ts"
import Token from "./Token.ts"
import TokenManager from './TokenManager.ts'
import * as SocketIo from "socket.io"
export default abstract class BaseApi {
@@ -24,12 +25,7 @@ export default abstract class BaseApi {
return false
}
checkToken(token: Token, deviceId: string) {
if (token.expired_time < Date.now()) return false
if (!token.author || !User.findById(token.author)) return false
if (deviceId != null)
if (token.device_id != deviceId)
return false
return true
return TokenManager.checkToken(token, deviceId)
}
registerEvent(name: CallMethod, func: EventCallbackFunction) {
if (!name.startsWith(this.getName() + ".")) throw Error("注冊的事件應該與接口集合命名空間相匹配: " + name)

View File

@@ -22,7 +22,6 @@ export default class TokenManager {
).toString('hex')
}
static decode(token: string) {
if (token == null) throw new Error('令牌為空!')
try {
return JSON.parse(crypto.createDecipheriv("aes-256-gcm", normalizeKey(config.aes_key), '01234567890123456').update(
Buffer.from(token, 'hex')
@@ -55,4 +54,15 @@ export default class TokenManager {
return this.makeAuth(user) == tk.auth
}
/**
* 嚴格檢驗令牌: 時間, 用戶, (設備 ID)
*/
static checkToken(token: Token, deviceId?: string) {
if (token.expired_time < Date.now()) return false
if (!token.author || !User.findById(token.author)) return false
if (deviceId != null)
if (token.device_id != deviceId)
return false
return true
}
}