67 lines
2.0 KiB
TypeScript
Raw Normal View History

2024-10-14 17:18:57 +08:00
import type { Database } from "db0"
2024-10-14 00:02:58 +08:00
import type { UserInfo } from "#/types"
export class UserTable {
private db
constructor(db: Database) {
this.db = db
}
async init() {
await this.db.prepare(`
CREATE TABLE IF NOT EXISTS user (
id TEXT PRIMARY KEY,
email TEXT,
data TEXT,
type TEXT,
created INTEGER,
updated INTEGER
);
`).run()
logger.success(`init user table`)
}
async addUser(id: string, email: string, type: "github") {
const u = await this.getUser(id)
const now = Date.now()
if (!u) {
await this.db.prepare(`INSERT INTO user (id, email, data, type, created, updated) VALUES (?, ?, ?, ?, ?, ?)`)
.run(id, email, "", type, now, now)
logger.success(`add user ${id}`)
} else if (u.email !== email && u.type !== type) {
2024-10-15 12:05:03 +08:00
await this.db.prepare(`UPDATE user SET email = ?, updated = ? WHERE id = ?`).run(id, email, now)
2024-10-14 00:02:58 +08:00
logger.success(`update user ${id} email`)
2024-10-14 17:18:57 +08:00
} else {
logger.info(`user ${id} already exists`)
2024-10-14 00:02:58 +08:00
}
}
async getUser(id: string) {
return (await this.db.prepare(`SELECT id, email, data, created, updated FROM user WHERE id = ?`).get(id)) as UserInfo
}
2024-10-15 12:05:03 +08:00
async setData(key: string, value: string, updatedTime = Date.now()) {
2024-10-14 00:02:58 +08:00
const state = await this.db.prepare(
2024-10-15 12:05:03 +08:00
`UPDATE user SET data = ?, updated = ? WHERE id = ?`,
).run(value, updatedTime, key)
2024-10-14 00:02:58 +08:00
if (!state.success) throw new Error(`set user ${key} data failed`)
2024-10-15 12:05:03 +08:00
logger.success(`set ${key} data`)
2024-10-14 00:02:58 +08:00
}
async getData(id: string) {
2024-10-15 12:05:03 +08:00
const row: any = await this.db.prepare(`SELECT data, updated FROM user WHERE id = ?`).get(id)
if (!row) throw new Error(`user ${id} not found`)
2024-10-14 00:02:58 +08:00
logger.success(`get ${id} data`)
2024-10-15 12:05:03 +08:00
return row as {
2024-10-14 00:02:58 +08:00
data: string
updated: number
}
}
async deleteUser(key: string) {
const state = await this.db.prepare(`DELETE FROM user WHERE id = ?`).run(key)
if (!state.success) throw new Error(`delete user ${key} failed`)
logger.success(`delete user ${key}`)
}
}