forked from administration/panel
don't error if publishing badge update failed
parent
19465043a1
commit
2522cfe6de
|
@ -75,10 +75,13 @@ export function UserActions({ user, bot }: { user: User; bot?: Bot }) {
|
||||||
const badges =
|
const badges =
|
||||||
(decodeTime(user._id) < 1629638578431 ? 256 : 0) |
|
(decodeTime(user._id) < 1629638578431 ? 256 : 0) |
|
||||||
((userDraft.badges ?? 0) ^ badge);
|
((userDraft.badges ?? 0) ^ badge);
|
||||||
await updateUserBadges(user._id, badges);
|
const result = await updateUserBadges(user._id, badges);
|
||||||
setUserDraft((user) => ({ ...user!, badges }));
|
setUserDraft((user) => ({ ...user!, badges }));
|
||||||
toast({
|
toast({
|
||||||
title: "Updated user badges",
|
title: "Updated user badges",
|
||||||
|
description: result.updatePublished
|
||||||
|
? undefined
|
||||||
|
: "Failed to publish event, users will need to reload to see the change",
|
||||||
});
|
});
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
toast({
|
toast({
|
||||||
|
|
|
@ -225,7 +225,7 @@ export async function suspendUser(userId: string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function updateUserBadges(userId: string, badges: number) {
|
export async function updateUserBadges(userId: string, badges: number): Promise<{ updatePublished: boolean }> {
|
||||||
await checkPermission("users/update/badges", userId, { badges });
|
await checkPermission("users/update/badges", userId, { badges });
|
||||||
await mongo().db("revolt").collection<User>("users").updateOne(
|
await mongo().db("revolt").collection<User>("users").updateOne(
|
||||||
{
|
{
|
||||||
|
@ -238,6 +238,7 @@ export async function updateUserBadges(userId: string, badges: number) {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
try {
|
||||||
const memberships = await fetchMembershipsByUser(userId);
|
const memberships = await fetchMembershipsByUser(userId);
|
||||||
for (const topic of [userId, ...memberships.map((x) => x._id.server)]) {
|
for (const topic of [userId, ...memberships.map((x) => x._id.server)]) {
|
||||||
await publishMessage(topic, {
|
await publishMessage(topic, {
|
||||||
|
@ -249,6 +250,11 @@ export async function updateUserBadges(userId: string, badges: number) {
|
||||||
clear: [],
|
clear: [],
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
} catch(e) {
|
||||||
|
return { updatePublished: false };
|
||||||
|
}
|
||||||
|
|
||||||
|
return { updatePublished: true };
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function wipeUser(userId: string, flags = 4) {
|
export async function wipeUser(userId: string, flags = 4) {
|
||||||
|
|
Loading…
Reference in New Issue