summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/admin/abuse-user-reports.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2019-01-19 19:16:48 +0900
committersyuilo <syuilotan@yahoo.co.jp>2019-01-19 19:16:48 +0900
commit048b9c295ed77f665c22f4b3f923013d0d9be990 (patch)
tree94fcc3b915b6dab60ff66f2e08d1c65d8a25e0c0 /src/server/api/endpoints/admin/abuse-user-reports.ts
parentFix typo (diff)
downloadsharkey-048b9c295ed77f665c22f4b3f923013d0d9be990.tar.gz
sharkey-048b9c295ed77f665c22f4b3f923013d0d9be990.tar.bz2
sharkey-048b9c295ed77f665c22f4b3f923013d0d9be990.zip
スパム報告機能
Resolve #1970
Diffstat (limited to 'src/server/api/endpoints/admin/abuse-user-reports.ts')
-rw-r--r--src/server/api/endpoints/admin/abuse-user-reports.ts54
1 files changed, 54 insertions, 0 deletions
diff --git a/src/server/api/endpoints/admin/abuse-user-reports.ts b/src/server/api/endpoints/admin/abuse-user-reports.ts
new file mode 100644
index 0000000000..c88174f13f
--- /dev/null
+++ b/src/server/api/endpoints/admin/abuse-user-reports.ts
@@ -0,0 +1,54 @@
+import $ from 'cafy'; import ID, { transform } from '../../../../misc/cafy-id';
+import Report, { packMany } from '../../../../models/abuse-user-report';
+import define from '../../define';
+
+export const meta = {
+ requireCredential: true,
+ requireModerator: true,
+
+ params: {
+ limit: {
+ validator: $.num.optional.range(1, 100),
+ default: 10
+ },
+
+ sinceId: {
+ validator: $.type(ID).optional,
+ transform: transform,
+ },
+
+ untilId: {
+ validator: $.type(ID).optional,
+ transform: transform,
+ },
+ }
+};
+
+export default define(meta, (ps) => new Promise(async (res, rej) => {
+ if (ps.sinceId && ps.untilId) {
+ return rej('cannot set sinceId and untilId');
+ }
+
+ const sort = {
+ _id: -1
+ };
+ const query = {} as any;
+ if (ps.sinceId) {
+ sort._id = 1;
+ query._id = {
+ $gt: ps.sinceId
+ };
+ } else if (ps.untilId) {
+ query._id = {
+ $lt: ps.untilId
+ };
+ }
+
+ const reports = await Report
+ .find(query, {
+ limit: ps.limit,
+ sort: sort
+ });
+
+ res(await packMany(reports));
+}));