hippofish/packages/backend/src/server/api/endpoints/drive/files.ts
ThatOneCalculator abf47e54f3
clean up w/ rome
2023-01-16 11:19:20 -08:00

72 lines
1.6 KiB
TypeScript

import define from "../../define.js";
import { DriveFiles } from "@/models/index.js";
import { makePaginationQuery } from "../../common/make-pagination-query.js";
export const meta = {
tags: ["drive"],
requireCredential: true,
kind: "read:drive",
res: {
type: "array",
optional: false,
nullable: false,
items: {
type: "object",
optional: false,
nullable: false,
ref: "DriveFile",
},
},
} as const;
export const paramDef = {
type: "object",
properties: {
limit: { type: "integer", minimum: 1, maximum: 100, default: 10 },
sinceId: { type: "string", format: "misskey:id" },
untilId: { type: "string", format: "misskey:id" },
folderId: {
type: "string",
format: "misskey:id",
nullable: true,
default: null,
},
type: {
type: "string",
nullable: true,
pattern: /^[a-zA-Z\/\-*]+$/.toString().slice(1, -1),
},
},
required: [],
} as const;
export default define(meta, paramDef, async (ps, user) => {
const query = makePaginationQuery(
DriveFiles.createQueryBuilder("file"),
ps.sinceId,
ps.untilId,
).andWhere("file.userId = :userId", { userId: user.id });
if (ps.folderId) {
query.andWhere("file.folderId = :folderId", { folderId: ps.folderId });
} else {
query.andWhere("file.folderId IS NULL");
}
if (ps.type) {
if (ps.type.endsWith("/*")) {
query.andWhere("file.type like :type", {
type: `${ps.type.replace("/*", "/")}%`,
});
} else {
query.andWhere("file.type = :type", { type: ps.type });
}
}
const files = await query.take(ps.limit).getMany();
return await DriveFiles.packMany(files, { detail: false, self: true });
});