From 796237b3c6a8239063d8eb634f862c6d91940106 Mon Sep 17 00:00:00 2001 From: syuilo Date: Fri, 14 Dec 2018 19:09:11 +0900 Subject: Implement admin drive page --- src/server/api/endpoints/admin/drive/files.ts | 79 +++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 src/server/api/endpoints/admin/drive/files.ts (limited to 'src/server/api') diff --git a/src/server/api/endpoints/admin/drive/files.ts b/src/server/api/endpoints/admin/drive/files.ts new file mode 100644 index 0000000000..2e54270a0f --- /dev/null +++ b/src/server/api/endpoints/admin/drive/files.ts @@ -0,0 +1,79 @@ +import $ from 'cafy'; +import File, { packMany } from '../../../../../models/drive-file'; +import define from '../../../define'; + +export const meta = { + requireCredential: false, + requireModerator: true, + + params: { + limit: { + validator: $.num.optional.range(1, 100), + default: 10 + }, + + offset: { + validator: $.num.optional.min(0), + default: 0 + }, + + sort: { + validator: $.str.optional.or([ + '+createdAt', + '-createdAt', + '+size', + '-size', + ]), + }, + + origin: { + validator: $.str.optional.or([ + 'combined', + 'local', + 'remote', + ]), + default: 'local' + } + } +}; + +export default define(meta, (ps, me) => new Promise(async (res, rej) => { + let _sort; + if (ps.sort) { + if (ps.sort == '+createdAt') { + _sort = { + uploadDate: -1 + }; + } else if (ps.sort == '-createdAt') { + _sort = { + uploadDate: 1 + }; + } else if (ps.sort == '+size') { + _sort = { + length: -1 + }; + } else if (ps.sort == '+size') { + _sort = { + length: -1 + }; + } + } else { + _sort = { + _id: -1 + }; + } + + const q = + ps.origin == 'local' ? { host: null } : + ps.origin == 'remote' ? { host: { $ne: null } } : + {}; + + const files = await File + .find(q, { + limit: ps.limit, + sort: _sort, + skip: ps.offset + }); + + res(await packMany(files, { detail: true, withUser: true })); +})); -- cgit v1.2.3-freya