mirror of
https://github.com/lifegpc/eh-downloader.git
synced 2026-06-14 09:34:20 +08:00
80 lines
3.1 KiB
TypeScript
80 lines
3.1 KiB
TypeScript
import { Handlers } from "$fresh/server.ts";
|
|
import { return_data, return_error } from "../../server/utils.ts";
|
|
import { User, UserPermission } from "../../db.ts";
|
|
import { get_string, parse_bool, parse_int } from "../../server/parse_form.ts";
|
|
import { base_logger, LogLevel } from "../../utils/logger.ts";
|
|
|
|
export const handler: Handlers = {
|
|
async DELETE(req, ctx) {
|
|
const user = <User | undefined> ctx.state.user;
|
|
if (
|
|
user && !user.is_admin &&
|
|
!(Number(user.permissions) & UserPermission.QueryLog)
|
|
) {
|
|
return return_error(403, "Permission denied.");
|
|
}
|
|
let form: FormData | undefined;
|
|
try {
|
|
form = await req.formData();
|
|
} catch (_) {
|
|
return return_error(400, "Bad Request");
|
|
}
|
|
const typ = await get_string(form.get("type"));
|
|
const min_level = await parse_int(form.get("min_level"), null);
|
|
const max_level = await parse_int(form.get("max_level"), null);
|
|
const deleted_level = (await get_string(form.get("deleted_level")))
|
|
?.split(",")?.map((x) => parseInt(x))?.filter((x) => !isNaN(x));
|
|
const end = await get_string(form.get("end_time"));
|
|
const endt = parseInt(end ?? "");
|
|
let end_time: Date | null;
|
|
try {
|
|
end_time = end === null ? null : new Date(isNaN(endt) ? end : endt);
|
|
} catch (e) {
|
|
base_logger.log("Failed to parse end_time:", e);
|
|
return return_error(1, "Failed to parse end_time.");
|
|
}
|
|
const optimize = await parse_bool(form.get("optimize"), true);
|
|
base_logger.clear(typ, min_level, max_level, deleted_level, end_time);
|
|
if (optimize) base_logger.optimize();
|
|
return return_data(true);
|
|
},
|
|
async GET(req, ctx) {
|
|
const user = <User | undefined> ctx.state.user;
|
|
if (
|
|
user && !user.is_admin &&
|
|
!(Number(user.permissions) & UserPermission.QueryLog)
|
|
) {
|
|
return return_error(403, "Permission denied.");
|
|
}
|
|
const u = new URL(req.url);
|
|
const params = u.searchParams;
|
|
const page = await parse_int(params.get("page"), null);
|
|
const limit = await parse_int(params.get("limit"), 50);
|
|
const offset = await parse_int(params.get("offset"), 0);
|
|
const type = params.get("type");
|
|
let min_level = await parse_int(
|
|
params.get("min_level"),
|
|
null,
|
|
);
|
|
const allowed_level = params.get("allowed_level")?.split(",").map((x) =>
|
|
parseInt(x)
|
|
).filter((x) => !isNaN(x));
|
|
if (!allowed_level && min_level === null) {
|
|
min_level = LogLevel.Log;
|
|
}
|
|
const datas = page === null
|
|
? base_logger.list(offset, limit, type, min_level, allowed_level)
|
|
: base_logger.list_page(
|
|
page,
|
|
limit,
|
|
type,
|
|
min_level,
|
|
allowed_level,
|
|
);
|
|
const count = page === null
|
|
? undefined
|
|
: base_logger.count(type, min_level, allowed_level);
|
|
return return_data({ datas, count });
|
|
},
|
|
};
|