Compare commits
6 commits
98c3388052
...
7cf4e6bc42
Author | SHA1 | Date | |
---|---|---|---|
7cf4e6bc42 | |||
4f061a2849 | |||
290d9fcbc0 | |||
c44121c575 | |||
79af7b0eae | |||
c777931168 |
5 changed files with 12 additions and 8 deletions
|
@ -1,10 +1,12 @@
|
||||||
|
import { unsafeCast } from "./unsafe-cast.js";
|
||||||
|
|
||||||
export type Promiseable<T> = {
|
export type Promiseable<T> = {
|
||||||
[K in keyof T]: Promise<T[K]> | T[K];
|
[K in keyof T]: Promise<T[K]> | T[K];
|
||||||
};
|
};
|
||||||
|
|
||||||
export async function awaitAll<T>(obj: Promiseable<T>): Promise<T> {
|
export async function awaitAll<T>(obj: Promiseable<T>): Promise<T> {
|
||||||
const target = {} as T;
|
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 values = Object.values(obj) as any[];
|
||||||
|
|
||||||
const resolvedValues = await Promise.all(
|
const resolvedValues = await Promise.all(
|
||||||
|
|
4
packages/backend/src/prelude/unsafe-cast.ts
Normal file
4
packages/backend/src/prelude/unsafe-cast.ts
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
// unsafe type cast
|
||||||
|
export function unsafeCast<T>(val: unknown): T {
|
||||||
|
return val as T;
|
||||||
|
}
|
|
@ -1,6 +1,8 @@
|
||||||
import { Users } from "@/models/index.js";
|
import { Users } from "@/models/index.js";
|
||||||
import { publishInternalEvent } from "@/services/stream.js";
|
import { publishInternalEvent } from "@/services/stream.js";
|
||||||
import define from "../../define.js";
|
import define from "../../define.js";
|
||||||
|
import type { EmojiModPerm } from "@/models/entities/user.js";
|
||||||
|
import { unsafeCast } from "@/prelude/unsafe-cast.js";
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
tags: ["admin"],
|
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, {
|
await Users.update(user.id, {
|
||||||
emojiModPerm: _emojiModPerm,
|
emojiModPerm: unsafeCast<EmojiModPerm>(ps.emojiModPerm),
|
||||||
});
|
});
|
||||||
|
|
||||||
publishInternalEvent("userChangeModeratorState", {
|
publishInternalEvent("userChangeModeratorState", {
|
||||||
|
|
|
@ -17,7 +17,7 @@ export const paramDef = {
|
||||||
required: ["userId", "text"],
|
required: ["userId", "text"],
|
||||||
} as const;
|
} as const;
|
||||||
|
|
||||||
export default define(meta, paramDef, async (ps, me) => {
|
export default define(meta, paramDef, async (ps) => {
|
||||||
const user = await Users.findOneBy({ id: ps.userId });
|
const user = await Users.findOneBy({ id: ps.userId });
|
||||||
|
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
|
|
|
@ -10,7 +10,7 @@ const nonExistingLanguagesCache = new Set<string>();
|
||||||
export const loadLanguage = (lang: string) =>
|
export const loadLanguage = (lang: string) =>
|
||||||
new Promise<void>((resolve, reject) => {
|
new Promise<void>((resolve, reject) => {
|
||||||
// for now
|
// for now
|
||||||
if (!defaultStore.state.useEmojiCdn) return resolve();
|
if (!defaultStore.state.useEmojiCdn) return reject();
|
||||||
// cached non-existing language
|
// cached non-existing language
|
||||||
if (nonExistingLanguagesCache.has(lang)) return reject();
|
if (nonExistingLanguagesCache.has(lang)) return reject();
|
||||||
// load language with autoloader
|
// load language with autoloader
|
||||||
|
|
Loading…
Reference in a new issue