2023-01-13 05:40:33 +01:00
|
|
|
import define from "../../define.js";
|
|
|
|
import { DriveFiles } from "@/models/index.js";
|
|
|
|
import { makePaginationQuery } from "../../common/make-pagination-query.js";
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-07-16 21:36:44 +02:00
|
|
|
export const meta = {
|
2023-01-13 05:40:33 +01:00
|
|
|
tags: ["drive"],
|
2019-02-23 03:20:58 +01:00
|
|
|
|
2022-01-18 14:27:10 +01:00
|
|
|
requireCredential: true,
|
2018-07-16 21:36:44 +02:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
kind: "read:drive",
|
2018-07-16 21:36:44 +02:00
|
|
|
|
2019-02-23 03:20:58 +01:00
|
|
|
res: {
|
2023-01-13 05:40:33 +01:00
|
|
|
type: "array",
|
|
|
|
optional: false,
|
|
|
|
nullable: false,
|
2019-02-23 03:20:58 +01:00
|
|
|
items: {
|
2023-01-13 05:40:33 +01:00
|
|
|
type: "object",
|
|
|
|
optional: false,
|
|
|
|
nullable: false,
|
|
|
|
ref: "DriveFile",
|
2021-12-09 15:58:30 +01:00
|
|
|
},
|
2019-02-23 03:20:58 +01:00
|
|
|
},
|
2022-01-18 14:27:10 +01:00
|
|
|
} as const;
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2022-02-20 05:15:40 +01:00
|
|
|
export const paramDef = {
|
2023-01-13 05:40:33 +01:00
|
|
|
type: "object",
|
2022-02-19 06:05:32 +01:00
|
|
|
properties: {
|
2023-01-13 05:40:33 +01:00
|
|
|
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),
|
|
|
|
},
|
2022-02-19 06:05:32 +01:00
|
|
|
},
|
|
|
|
required: [],
|
|
|
|
} as const;
|
|
|
|
|
|
|
|
export default define(meta, paramDef, async (ps, user) => {
|
2023-01-13 05:40:33 +01:00
|
|
|
const query = makePaginationQuery(
|
|
|
|
DriveFiles.createQueryBuilder("file"),
|
|
|
|
ps.sinceId,
|
|
|
|
ps.untilId,
|
|
|
|
).andWhere("file.userId = :userId", { userId: user.id });
|
2018-06-15 02:53:30 +02:00
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
if (ps.folderId) {
|
2023-01-13 05:40:33 +01:00
|
|
|
query.andWhere("file.folderId = :folderId", { folderId: ps.folderId });
|
2019-04-07 14:50:36 +02:00
|
|
|
} else {
|
2023-01-13 05:40:33 +01:00
|
|
|
query.andWhere("file.folderId IS NULL");
|
2016-12-28 23:49:51 +01:00
|
|
|
}
|
2018-06-15 02:53:30 +02:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
if (ps.type) {
|
2023-01-13 05:40:33 +01:00
|
|
|
if (ps.type.endsWith("/*")) {
|
|
|
|
query.andWhere("file.type like :type", {
|
|
|
|
type: `${ps.type.replace("/*", "/")}%`,
|
|
|
|
});
|
2019-04-07 14:50:36 +02:00
|
|
|
} else {
|
2023-01-13 05:40:33 +01:00
|
|
|
query.andWhere("file.type = :type", { type: ps.type });
|
2019-04-07 14:50:36 +02:00
|
|
|
}
|
2017-11-08 18:55:03 +01:00
|
|
|
}
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2022-02-19 06:05:32 +01:00
|
|
|
const files = await query.take(ps.limit).getMany();
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
return await DriveFiles.packMany(files, { detail: false, self: true });
|
2019-02-22 03:46:58 +01:00
|
|
|
});
|