sendou.ink/scripts/add-badge-winners.ts
Kalle fd48bced91
Migrate Prettier/Eslint/Stylelint setup to Biome (#1772)
* 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>
2024-06-24 13:07:17 +03:00

36 lines
1.0 KiB
TypeScript

import "dotenv/config";
import { sql } from "~/db/sql";
import invariant from "~/utils/invariant";
import { logger } from "~/utils/logger";
const badgeId = process.argv[2]?.trim();
const discordIds = process.argv[3]?.trim();
invariant(discordIds, "id list of discord ids required (argument 1)");
invariant(badgeId, "display name of badge is required (argument 2)");
invariant(
discordIds.includes(","),
"discordIds must be a comma separated list of discord ids",
);
const stm = sql.prepare(
/* sql */ `insert into "TournamentBadgeOwner" ("badgeId", "userId") values (@badgeId, (select "id" from "User" where "discordId" = @userId))`,
);
const userStm = sql.prepare(
/* sql */ `select "id" from "User" where "discordId" = @discordId`,
);
const users = discordIds.split(",");
for (const userId of users) {
const user = userStm.get({ discordId: userId });
if (!user) {
logger.info(`User with discord id ${userId} not found`);
continue;
}
stm.run({ badgeId: Number(badgeId), userId });
}
logger.info(`Added ${users.length} owners to the badge`);