summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2018-10-31 11:17:24 +0900
committerGitHub <noreply@github.com>2018-10-31 11:17:24 +0900
commit5e3372e9329883aefa19fa572715077d79eac5be (patch)
treec259467122fa4d2add35aa413b4e9986ab6fd7ce /src/server/api/endpoints
parentImplement /api/v1/instance (#3045) (diff)
parent良い感じに (diff)
downloadsharkey-5e3372e9329883aefa19fa572715077d79eac5be.tar.gz
sharkey-5e3372e9329883aefa19fa572715077d79eac5be.tar.bz2
sharkey-5e3372e9329883aefa19fa572715077d79eac5be.zip
Merge pull request #3047 from mei23/mei-1031-blokings-list
blockings list
Diffstat (limited to 'src/server/api/endpoints')
-rw-r--r--src/server/api/endpoints/blocking/list.ts64
-rw-r--r--src/server/api/endpoints/mute/list.ts80
2 files changed, 99 insertions, 45 deletions
diff --git a/src/server/api/endpoints/blocking/list.ts b/src/server/api/endpoints/blocking/list.ts
new file mode 100644
index 0000000000..a0bef38b58
--- /dev/null
+++ b/src/server/api/endpoints/blocking/list.ts
@@ -0,0 +1,64 @@
+import $ from 'cafy'; import ID from '../../../../misc/cafy-id';
+import Blocking, { packMany } from '../../../../models/blocking';
+import { ILocalUser } from '../../../../models/user';
+import getParams from '../../get-params';
+
+export const meta = {
+ desc: {
+ 'ja-JP': 'ブロックしているユーザー一覧を取得します。',
+ 'en-US': 'Get blocking users.'
+ },
+
+ requireCredential: true,
+
+ kind: 'following-read',
+
+ params: {
+ limit: $.num.optional.range(1, 100).note({
+ default: 30
+ }),
+
+ sinceId: $.type(ID).optional.note({
+ }),
+
+ untilId: $.type(ID).optional.note({
+ }),
+ }
+};
+
+export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) return rej(psErr);
+
+ // Check if both of sinceId and untilId is specified
+ if (ps.sinceId && ps.untilId) {
+ return rej('cannot set sinceId and untilId');
+ }
+
+ const query = {
+ blockerId: me._id
+ } as any;
+
+ const sort = {
+ _id: -1
+ };
+
+ if (ps.sinceId) {
+ sort._id = 1;
+ query._id = {
+ $gt: ps.sinceId
+ };
+ } else if (ps.untilId) {
+ query._id = {
+ $lt: ps.untilId
+ };
+ }
+
+ const blockings = await Blocking
+ .find(query, {
+ limit: ps.limit,
+ sort: sort
+ });
+
+ res(await packMany(blockings, me));
+});
diff --git a/src/server/api/endpoints/mute/list.ts b/src/server/api/endpoints/mute/list.ts
index 387b2396f5..4653877621 100644
--- a/src/server/api/endpoints/mute/list.ts
+++ b/src/server/api/endpoints/mute/list.ts
@@ -1,7 +1,7 @@
import $ from 'cafy'; import ID from '../../../../misc/cafy-id';
-import Mute from '../../../../models/mute';
-import { pack, ILocalUser } from '../../../../models/user';
-import { getFriendIds } from '../../common/get-friends';
+import Mute, { packMany } from '../../../../models/mute';
+import { ILocalUser } from '../../../../models/user';
+import getParams from '../../get-params';
export const meta = {
desc: {
@@ -11,64 +11,54 @@ export const meta = {
requireCredential: true,
- kind: 'account/read'
+ kind: 'account/read',
+
+ params: {
+ limit: $.num.optional.range(1, 100).note({
+ default: 30
+ }),
+
+ sinceId: $.type(ID).optional.note({
+ }),
+
+ untilId: $.type(ID).optional.note({
+ }),
+ }
};
export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
- // Get 'iknow' parameter
- const [iknow = false, iknowErr] = $.bool.optional.get(params.iknow);
- if (iknowErr) return rej('invalid iknow param');
-
- // Get 'limit' parameter
- const [limit = 30, limitErr] = $.num.optional.range(1, 100).get(params.limit);
- if (limitErr) return rej('invalid limit param');
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) return rej(psErr);
- // Get 'cursor' parameter
- const [cursor = null, cursorErr] = $.type(ID).optional.get(params.cursor);
- if (cursorErr) return rej('invalid cursor param');
+ // Check if both of sinceId and untilId is specified
+ if (ps.sinceId && ps.untilId) {
+ return rej('cannot set sinceId and untilId');
+ }
- // Construct query
const query = {
- muterId: me._id,
- deletedAt: { $exists: false }
+ muterId: me._id
} as any;
- if (iknow) {
- // Get my friends
- const myFriends = await getFriendIds(me._id);
+ const sort = {
+ _id: -1
+ };
- query.muteeId = {
- $in: myFriends
+ if (ps.sinceId) {
+ sort._id = 1;
+ query._id = {
+ $gt: ps.sinceId
};
- }
-
- // カーソルが指定されている場合
- if (cursor) {
+ } else if (ps.untilId) {
query._id = {
- $lt: cursor
+ $lt: ps.untilId
};
}
- // Get mutes
const mutes = await Mute
.find(query, {
- limit: limit + 1,
- sort: { _id: -1 }
+ limit: ps.limit,
+ sort: sort
});
- // 「次のページ」があるかどうか
- const inStock = mutes.length === limit + 1;
- if (inStock) {
- mutes.pop();
- }
-
- // Serialize
- const users = await Promise.all(mutes.map(async m =>
- await pack(m.muteeId, me, { detail: true })));
-
- // Response
- res({
- users: users,
- next: inStock ? mutes[mutes.length - 1]._id : null,
- });
+ res(await packMany(mutes, me));
});