mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-03-21 18:04:39 -05:00
* Initial * CSS lint * Test CI * Add 1v1, 2v2, and 3v3 Tags (#1771) * Initial * CSS lint * Test CI * Rename step --------- Co-authored-by: xi <104683822+ximk@users.noreply.github.com>
144 lines
3.3 KiB
TypeScript
144 lines
3.3 KiB
TypeScript
import { db, sql } from "~/db/sql";
|
|
import type { Tables } from "~/db/tables";
|
|
import { dateToDatabaseTimestamp } from "~/utils/dates";
|
|
import invariant from "~/utils/invariant";
|
|
import { syncXPBadges } from "../badges/queries/syncXPBadges.server";
|
|
|
|
const removeOldLikesStm = sql.prepare(/*sql*/ `
|
|
delete from
|
|
"GroupLike"
|
|
where
|
|
"GroupLike"."createdAt" < cast(strftime('%s', datetime('now', 'start of day', '-7 days')) as int)
|
|
`);
|
|
|
|
const removeOldGroupStm = sql.prepare(/*sql*/ `
|
|
delete from
|
|
"Group"
|
|
where "Group"."id" in (
|
|
select "Group"."id"
|
|
from "Group"
|
|
left join "GroupMatch" on "Group"."id" = "GroupMatch"."alphaGroupId" or "Group"."id" = "GroupMatch"."bravoGroupId"
|
|
where "Group"."status" = 'INACTIVE'
|
|
and "GroupMatch"."id" is null
|
|
)
|
|
`);
|
|
|
|
const cleanUpStm = sql.prepare(/*sql*/ `
|
|
vacuum
|
|
`);
|
|
|
|
export const cleanUp = () => {
|
|
removeOldLikesStm.run();
|
|
removeOldGroupStm.run();
|
|
cleanUpStm.run();
|
|
};
|
|
|
|
export function migrate(args: { newUserId: number; oldUserId: number }) {
|
|
return db.transaction().execute(async (trx) => {
|
|
const deletedUser = await trx
|
|
.deleteFrom("User")
|
|
.where("User.id", "=", args.newUserId)
|
|
.returning("discordId")
|
|
.executeTakeFirstOrThrow();
|
|
|
|
await trx
|
|
.updateTable("User")
|
|
.set({ discordId: deletedUser.discordId })
|
|
.where("User.id", "=", args.oldUserId)
|
|
.execute();
|
|
});
|
|
}
|
|
|
|
export function replacePlusTiers(
|
|
plusTiers: Array<{ userId: number; tier: number }>,
|
|
) {
|
|
invariant(plusTiers.length > 0, "plusTiers must not be empty");
|
|
|
|
return db.transaction().execute(async (trx) => {
|
|
await trx.deleteFrom("PlusTier").execute();
|
|
await trx.insertInto("PlusTier").values(plusTiers).execute();
|
|
});
|
|
}
|
|
|
|
export function allPlusTiersFromLatestVoting() {
|
|
return db
|
|
.selectFrom("FreshPlusTier")
|
|
.select(["FreshPlusTier.userId", "FreshPlusTier.tier"])
|
|
.where("FreshPlusTier.tier", "is not", null)
|
|
.execute() as Promise<{ userId: number; tier: number }[]>;
|
|
}
|
|
|
|
export function makeVideoAdderByUserId(userId: number) {
|
|
return db
|
|
.updateTable("User")
|
|
.set({ isVideoAdder: 1 })
|
|
.where("User.id", "=", userId)
|
|
.execute();
|
|
}
|
|
|
|
export async function linkUserAndPlayer({
|
|
userId,
|
|
playerId,
|
|
}: {
|
|
userId: number;
|
|
playerId: number;
|
|
}) {
|
|
await db
|
|
.updateTable("SplatoonPlayer")
|
|
.set({ userId: null })
|
|
.where("SplatoonPlayer.userId", "=", userId)
|
|
.execute();
|
|
|
|
await db
|
|
.updateTable("SplatoonPlayer")
|
|
.set({ userId })
|
|
.where("SplatoonPlayer.id", "=", playerId)
|
|
.execute();
|
|
|
|
syncXPBadges();
|
|
}
|
|
|
|
export function forcePatron(args: {
|
|
id: number;
|
|
patronTier: Tables["User"]["patronTier"];
|
|
patronSince: Date;
|
|
patronTill: Date;
|
|
}) {
|
|
return db
|
|
.updateTable("User")
|
|
.set({
|
|
patronTier: args.patronTier,
|
|
patronSince: dateToDatabaseTimestamp(args.patronSince),
|
|
patronTill: dateToDatabaseTimestamp(args.patronTill),
|
|
})
|
|
.where("User.id", "=", args.id)
|
|
.execute();
|
|
}
|
|
|
|
export function banUser({
|
|
userId,
|
|
banned,
|
|
bannedReason,
|
|
}: {
|
|
userId: number;
|
|
banned: 1 | Date;
|
|
bannedReason: string | null;
|
|
}) {
|
|
return db
|
|
.updateTable("User")
|
|
.set({
|
|
banned: banned === 1 ? banned : dateToDatabaseTimestamp(banned),
|
|
bannedReason,
|
|
})
|
|
.where("User.id", "=", userId)
|
|
.execute();
|
|
}
|
|
|
|
export function unbanUser(userId: number) {
|
|
return db
|
|
.updateTable("User")
|
|
.set({ banned: 0 })
|
|
.where("User.id", "=", userId)
|
|
.execute();
|
|
}
|