diff options
| author | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-12-27 01:24:57 +0900 |
|---|---|---|
| committer | Aya Morisawa <AyaMorisawa4869@gmail.com> | 2018-12-27 01:26:03 +0900 |
| commit | 21f8dbf2deb0d766496c3503f036d07705da4238 (patch) | |
| tree | a97518ef3a92dcd6d2907c1719d9ea6c168bb8b8 /src/server/api/endpoints/messaging/history.ts | |
| parent | Feature to show only my posts in the user page (#3753) (diff) | |
| download | misskey-21f8dbf2deb0d766496c3503f036d07705da4238.tar.gz misskey-21f8dbf2deb0d766496c3503f036d07705da4238.tar.bz2 misskey-21f8dbf2deb0d766496c3503f036d07705da4238.zip | |
Resolve #3248
Co-authored-by: syuilo <syuilotan@yahoo.co.jp>
Diffstat (limited to 'src/server/api/endpoints/messaging/history.ts')
| -rw-r--r-- | src/server/api/endpoints/messaging/history.ts | 40 |
1 files changed, 28 insertions, 12 deletions
diff --git a/src/server/api/endpoints/messaging/history.ts b/src/server/api/endpoints/messaging/history.ts index c026e5dd91..78abea269a 100644 --- a/src/server/api/endpoints/messaging/history.ts +++ b/src/server/api/endpoints/messaging/history.ts @@ -1,7 +1,6 @@ import $ from 'cafy'; -import History from '../../../../models/messaging-history'; import Mute from '../../../../models/mute'; -import { pack } from '../../../../models/messaging-message'; +import Message, { pack, IMessagingMessage } from '../../../../models/messaging-message'; import define from '../../define'; export const meta = { @@ -28,19 +27,36 @@ export default define(meta, (ps, user) => new Promise(async (res, rej) => { deletedAt: { $exists: false } }); - // Get history - const history = await History - .find({ - userId: user._id, - partnerId: { - $nin: mute.map(m => m.muteeId) - } + const history: IMessagingMessage[] = []; + + for (let i = 0; i < ps.limit; i++) { + const found = history.map(m => m.userId.equals(user._id) ? m.recipientId : m.userId); + + const message = await Message.findOne({ + $or: [{ + userId: user._id + }, { + recipientId: user._id + }], + $and: [{ + userId: { $nin: found }, + recipientId: { $nin: found } + }, { + userId: { $nin: mute.map(m => m.muteeId) }, + recipientId: { $nin: mute.map(m => m.muteeId) } + }] }, { - limit: ps.limit, sort: { - updatedAt: -1 + createdAt: -1 } }); - res(await Promise.all(history.map(h => pack(h.messageId, user)))); + if (message) { + history.push(message); + } else { + break; + } + } + + res(await Promise.all(history.map(h => pack(h._id, user)))); })); |