yumechi-no-kuni/src/server/api/endpoints/messaging/history.ts

46 lines
1 KiB
TypeScript
Raw Normal View History

2017-03-08 12:50:09 -06:00
import $ from 'cafy';
2018-03-29 06:32:18 -05:00
import History from '../../../../models/messaging-history';
import Mute from '../../../../models/mute';
import { pack } from '../../../../models/messaging-message';
2018-06-17 19:54:53 -05:00
import { ILocalUser } from '../../../../models/user';
2016-12-28 16:49:51 -06:00
2018-07-16 14:36:44 -05:00
export const meta = {
desc: {
ja: 'Messagingの履歴を取得します。',
en: 'Show messaging history.'
},
requireCredential: true,
kind: 'messaging-read'
};
2018-07-05 12:58:29 -05:00
export default (params: any, user: ILocalUser) => new Promise(async (res, rej) => {
2016-12-28 16:49:51 -06:00
// Get 'limit' parameter
2018-07-05 09:36:07 -05:00
const [limit = 10, limitErr] = $.num.optional.range(1, 100).get(params.limit);
2017-03-02 17:24:48 -06:00
if (limitErr) return rej('invalid limit param');
2016-12-28 16:49:51 -06:00
2017-12-21 23:21:40 -06:00
const mute = await Mute.find({
2018-03-29 00:48:47 -05:00
muterId: user._id,
deletedAt: { $exists: false }
2017-12-21 23:21:40 -06:00
});
2016-12-28 16:49:51 -06:00
// Get history
const history = await History
.find({
2018-03-29 00:48:47 -05:00
userId: user._id,
partnerId: {
$nin: mute.map(m => m.muteeId)
2017-12-21 23:21:40 -06:00
}
2017-01-16 20:11:22 -06:00
}, {
2016-12-28 16:49:51 -06:00
limit: limit,
sort: {
2018-03-29 00:48:47 -05:00
updatedAt: -1
2016-12-28 16:49:51 -06:00
}
2017-01-16 20:11:22 -06:00
});
2016-12-28 16:49:51 -06:00
// Serialize
res(await Promise.all(history.map(async h =>
2018-03-29 00:48:47 -05:00
await pack(h.messageId, user))));
2016-12-28 16:49:51 -06:00
});