2018-07-07 13:19:00 +03:00
|
|
|
import $ from 'cafy'; import ID from '../../../../misc/cafy-id';
|
2018-04-07 20:30:37 +03:00
|
|
|
import Note from '../../../../models/note';
|
2018-04-19 06:43:25 +03:00
|
|
|
import { getFriendIds } from '../../common/get-friends';
|
2018-04-07 20:30:37 +03:00
|
|
|
import { pack } from '../../../../models/note';
|
2018-06-18 03:54:53 +03:00
|
|
|
import { ILocalUser } from '../../../../models/user';
|
2018-09-16 16:48:57 +03:00
|
|
|
import getParams from '../../get-params';
|
2018-09-23 10:05:46 +03:00
|
|
|
import read from '../../../../services/note/read';
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-07-16 22:36:44 +03:00
|
|
|
export const meta = {
|
|
|
|
desc: {
|
2018-08-29 00:59:43 +03:00
|
|
|
'ja-JP': '自分に言及している投稿の一覧を取得します。',
|
|
|
|
'en-US': 'Get mentions of myself.'
|
2018-07-16 22:36:44 +03:00
|
|
|
},
|
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
requireCredential: true,
|
2018-07-16 22:36:44 +03:00
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
params: {
|
|
|
|
following: $.bool.optional.note({
|
|
|
|
default: false
|
|
|
|
}),
|
|
|
|
|
|
|
|
limit: $.num.optional.range(1, 100).note({
|
|
|
|
default: 10
|
|
|
|
}),
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
sinceId: $.type(ID).optional.note({
|
|
|
|
}),
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
untilId: $.type(ID).optional.note({
|
|
|
|
}),
|
2018-09-17 20:14:12 +03:00
|
|
|
|
|
|
|
visibility: $.str.optional.note({
|
|
|
|
}),
|
2018-09-16 16:48:57 +03:00
|
|
|
}
|
|
|
|
};
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
export default (params: any, user: ILocalUser) => new Promise(async (res, rej) => {
|
|
|
|
const [ps, psErr] = getParams(meta, params);
|
|
|
|
if (psErr) throw psErr;
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-03-29 08:48:47 +03:00
|
|
|
// Check if both of sinceId and untilId is specified
|
2018-09-16 16:48:57 +03:00
|
|
|
if (ps.sinceId && ps.untilId) {
|
2018-03-29 08:48:47 +03:00
|
|
|
return rej('cannot set sinceId and untilId');
|
2016-12-29 00:49:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Construct query
|
|
|
|
const query = {
|
2018-09-16 16:48:57 +03:00
|
|
|
$or: [{
|
|
|
|
mentions: user._id
|
|
|
|
}, {
|
|
|
|
visibleUserIds: user._id
|
|
|
|
}]
|
2017-03-02 23:37:09 +02:00
|
|
|
} as any;
|
2016-12-29 00:49:51 +02:00
|
|
|
|
|
|
|
const sort = {
|
|
|
|
_id: -1
|
|
|
|
};
|
|
|
|
|
2018-09-17 20:14:12 +03:00
|
|
|
if (ps.visibility) {
|
|
|
|
query.visibility = ps.visibility;
|
|
|
|
}
|
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
if (ps.following) {
|
2018-04-19 06:43:25 +03:00
|
|
|
const followingIds = await getFriendIds(user._id);
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-03-29 08:48:47 +03:00
|
|
|
query.userId = {
|
2016-12-29 00:49:51 +02:00
|
|
|
$in: followingIds
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-09-16 16:48:57 +03:00
|
|
|
if (ps.sinceId) {
|
2016-12-29 00:49:51 +02:00
|
|
|
sort._id = 1;
|
|
|
|
query._id = {
|
2018-09-16 16:48:57 +03:00
|
|
|
$gt: ps.sinceId
|
2016-12-29 00:49:51 +02:00
|
|
|
};
|
2018-09-16 16:48:57 +03:00
|
|
|
} else if (ps.untilId) {
|
2016-12-29 00:49:51 +02:00
|
|
|
query._id = {
|
2018-09-16 16:48:57 +03:00
|
|
|
$lt: ps.untilId
|
2016-12-29 00:49:51 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// Issue query
|
2018-04-07 20:30:37 +03:00
|
|
|
const mentions = await Note
|
2017-01-17 04:11:22 +02:00
|
|
|
.find(query, {
|
2018-09-16 16:48:57 +03:00
|
|
|
limit: ps.limit,
|
2016-12-29 00:49:51 +02:00
|
|
|
sort: sort
|
2017-01-17 04:11:22 +02:00
|
|
|
});
|
2016-12-29 00:49:51 +02:00
|
|
|
|
2018-09-23 10:05:46 +03:00
|
|
|
mentions.forEach(note => read(user._id, note._id));
|
|
|
|
|
2016-12-29 00:49:51 +02:00
|
|
|
// Serialize
|
2018-09-16 16:48:57 +03:00
|
|
|
res(await Promise.all(mentions.map(mention => pack(mention, user))));
|
2016-12-29 00:49:51 +02:00
|
|
|
});
|