From 78bdec3af4efb8421532eb244c806b0acab974e7 Mon Sep 17 00:00:00 2001 From: naskya Date: Sat, 2 Mar 2024 13:26:44 +0900 Subject: [PATCH] chore (backend): add prelude/unsafe-cast for unsafe type casting --- packages/backend/src/models/entities/user.ts | 4 +++- packages/backend/src/prelude/await-all.ts | 4 +++- packages/backend/src/prelude/unsafe-cast.ts | 4 ++++ .../src/server/api/endpoints/admin/set-emoji-moderator.ts | 8 +++----- 4 files changed, 13 insertions(+), 7 deletions(-) create mode 100644 packages/backend/src/prelude/unsafe-cast.ts diff --git a/packages/backend/src/models/entities/user.ts b/packages/backend/src/models/entities/user.ts index cb99fe53ca..6a2d3ee017 100644 --- a/packages/backend/src/models/entities/user.ts +++ b/packages/backend/src/models/entities/user.ts @@ -9,6 +9,8 @@ import { import { id } from "../id.js"; import { DriveFile } from "./drive-file.js"; +export type EmojiModPerm = "unauthorized" | "add" | "mod" | "full"; + @Entity() @Index(["usernameLower", "host"], { unique: true }) export class User { @@ -188,7 +190,7 @@ export class User { enum: ["unauthorized", "add", "mod", "full"], default: "unauthorized", }) - public emojiModPerm: "unauthorized" | "add" | "mod" | "full"; + public emojiModPerm: EmojiModPerm; @Index() @Column("boolean", { diff --git a/packages/backend/src/prelude/await-all.ts b/packages/backend/src/prelude/await-all.ts index ce11eb87b4..d81870a574 100644 --- a/packages/backend/src/prelude/await-all.ts +++ b/packages/backend/src/prelude/await-all.ts @@ -1,10 +1,12 @@ +import { unsafeCast } from "./unsafe-cast.js"; + export type Promiseable = { [K in keyof T]: Promise | T[K]; }; export async function awaitAll(obj: Promiseable): Promise { const target = {} as T; - const keys = Object.keys(obj) as unknown as (keyof T)[]; + const keys = unsafeCast<(keyof T)[]>(Object.keys(obj)); const values = Object.values(obj) as any[]; const resolvedValues = await Promise.all( diff --git a/packages/backend/src/prelude/unsafe-cast.ts b/packages/backend/src/prelude/unsafe-cast.ts new file mode 100644 index 0000000000..f7e251fa34 --- /dev/null +++ b/packages/backend/src/prelude/unsafe-cast.ts @@ -0,0 +1,4 @@ +// unsafe type cast +export function unsafeCast(val: unknown): T { + return val as T; +} diff --git a/packages/backend/src/server/api/endpoints/admin/set-emoji-moderator.ts b/packages/backend/src/server/api/endpoints/admin/set-emoji-moderator.ts index dfaf54ca7d..6633edbc8c 100644 --- a/packages/backend/src/server/api/endpoints/admin/set-emoji-moderator.ts +++ b/packages/backend/src/server/api/endpoints/admin/set-emoji-moderator.ts @@ -1,6 +1,8 @@ import define from "@/server/api/define.js"; import { Users } from "@/models/index.js"; import { publishInternalEvent } from "@/services/stream.js"; +import type { EmojiModPerm } from "@/models/entities/user.js"; +import { unsafeCast } from "@/prelude/unsafe-cast.js"; export const meta = { tags: ["admin"], @@ -31,12 +33,8 @@ export default define(meta, paramDef, async (ps) => { ); } - const _emojiModPerm = - (ps.emojiModPerm as "unauthorized" | "add" | "mod" | "full") ?? - "unauthorized"; - await Users.update(user.id, { - emojiModPerm: _emojiModPerm, + emojiModPerm: unsafeCast(ps.emojiModPerm), }); publishInternalEvent("userChangeModeratorState", {