mizzkey/src/server/api/endpoints/messaging/history.ts

45 lines
1 KiB
TypeScript
Raw Normal View History

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