mirror of
https://github.com/ajayyy/SponsorBlockServer.git
synced 2025-12-10 05:27:00 +03:00
48 lines
1.9 KiB
TypeScript
48 lines
1.9 KiB
TypeScript
import {Request, Response} from 'express';
|
|
import {Logger} from '../utils/logger';
|
|
import {db} from '../databases/databases';
|
|
import {isUserVIP} from '../utils/isUserVIP';
|
|
import {getHash} from '../utils/getHash';
|
|
import { HashedUserID, UserID } from '../types/user.model';
|
|
|
|
export async function postWarning(req: Request, res: Response): Promise<Response> {
|
|
// exit early if no body passed in
|
|
if (!req.body.userID && !req.body.issuerUserID) return res.status(400).json({"message": "Missing parameters"});
|
|
// Collect user input data
|
|
const issuerUserID: HashedUserID = getHash(<UserID> req.body.issuerUserID);
|
|
const userID: UserID = req.body.userID;
|
|
const issueTime = new Date().getTime();
|
|
const enabled: boolean = req.body.enabled ?? true;
|
|
const reason: string = req.body.reason ?? '';
|
|
|
|
// Ensure user is a VIP
|
|
if (!await isUserVIP(issuerUserID)) {
|
|
Logger.warn("Permission violation: User " + issuerUserID + " attempted to warn user " + userID + ".");
|
|
return res.status(403).json({"message": "Not a VIP"});
|
|
}
|
|
|
|
let resultStatus = "";
|
|
|
|
if (enabled) {
|
|
const previousWarning = await db.prepare('get', 'SELECT * FROM "warnings" WHERE "userID" = ? AND "issuerUserID" = ?', [userID, issuerUserID]);
|
|
|
|
if (!previousWarning) {
|
|
await db.prepare(
|
|
'run',
|
|
'INSERT INTO "warnings" ("userID", "issueTime", "issuerUserID", "enabled", "reason") VALUES (?, ?, ?, 1, ?)',
|
|
[userID, issueTime, issuerUserID, reason]
|
|
);
|
|
resultStatus = "issued to";
|
|
} else {
|
|
return res.sendStatus(409);
|
|
}
|
|
} else {
|
|
await db.prepare('run', 'UPDATE "warnings" SET "enabled" = 0 WHERE "userID" = ?', [userID]);
|
|
resultStatus = "removed from";
|
|
}
|
|
|
|
return res.status(200).json({
|
|
message: "Warning " + resultStatus + " user '" + userID + "'.",
|
|
});
|
|
}
|