mirror of
https://github.com/woodchen-ink/certimate.git
synced 2025-07-18 09:21:56 +08:00
46 lines
1.3 KiB
TypeScript
46 lines
1.3 KiB
TypeScript
import dayjs from "dayjs";
|
|
import { type RecordListOptions } from "pocketbase";
|
|
|
|
import { type CertificateModel } from "@/domain/certificate";
|
|
import { getPocketBase } from "./pocketbase";
|
|
|
|
const COLLECTION_NAME = "certificate";
|
|
|
|
export type ListCertificateRequest = {
|
|
page?: number;
|
|
perPage?: number;
|
|
state?: "expireSoon" | "expired";
|
|
};
|
|
|
|
export const list = async (request: ListCertificateRequest) => {
|
|
const pb = getPocketBase();
|
|
|
|
const page = request.page || 1;
|
|
const perPage = request.perPage || 10;
|
|
|
|
const options: RecordListOptions = {
|
|
expand: "workflowId",
|
|
filter: "deleted=null",
|
|
sort: "-created",
|
|
requestKey: null,
|
|
};
|
|
|
|
if (request.state === "expireSoon") {
|
|
options.filter = pb.filter("expireAt<{:expiredAt} && deleted=null", {
|
|
expiredAt: dayjs().add(20, "d").toDate(),
|
|
});
|
|
} else if (request.state === "expired") {
|
|
options.filter = pb.filter("expireAt<={:expiredAt} && deleted=null", {
|
|
expiredAt: new Date(),
|
|
});
|
|
}
|
|
|
|
return pb.collection(COLLECTION_NAME).getList<CertificateModel>(page, perPage, options);
|
|
};
|
|
|
|
export const remove = async (record: MaybeModelRecordWithId<CertificateModel>) => {
|
|
record = { ...record, deleted: dayjs.utc().format("YYYY-MM-DD HH:mm:ss") };
|
|
|
|
await getPocketBase().collection(COLLECTION_NAME).update<CertificateModel>(record.id!, record);
|
|
};
|