summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/messaging/history.ts
diff options
context:
space:
mode:
authorAya Morisawa <AyaMorisawa4869@gmail.com>2018-12-27 01:24:57 +0900
committerAya Morisawa <AyaMorisawa4869@gmail.com>2018-12-27 01:26:03 +0900
commit21f8dbf2deb0d766496c3503f036d07705da4238 (patch)
treea97518ef3a92dcd6d2907c1719d9ea6c168bb8b8 /src/server/api/endpoints/messaging/history.ts
parent Feature to show only my posts in the user page (#3753) (diff)
downloadmisskey-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.ts40
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))));
}));