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

45 lines
1 KiB
TypeScript
Raw Normal View History

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