summaryrefslogtreecommitdiff
path: root/src/remote/activitypub/db-resolver.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/remote/activitypub/db-resolver.ts')
-rw-r--r--src/remote/activitypub/db-resolver.ts21
1 files changed, 20 insertions, 1 deletions
diff --git a/src/remote/activitypub/db-resolver.ts b/src/remote/activitypub/db-resolver.ts
index 6f1cb1e110..cad2212b70 100644
--- a/src/remote/activitypub/db-resolver.ts
+++ b/src/remote/activitypub/db-resolver.ts
@@ -2,7 +2,8 @@ import config from '../../config';
import { Note } from '../../models/entities/note';
import { User, IRemoteUser } from '../../models/entities/user';
import { UserPublickey } from '../../models/entities/user-publickey';
-import { Notes, Users, UserPublickeys } from '../../models';
+import { MessagingMessage } from '../../models/entities/messaging-message';
+import { Notes, Users, UserPublickeys, MessagingMessages } from '../../models';
import { IObject, getApId } from './type';
import { resolvePerson } from './models/person';
import { ensure } from '../../prelude/ensure';
@@ -33,6 +34,24 @@ export default class DbResolver {
return null;
}
+ public async getMessageFromApId(value: string | IObject): Promise<MessagingMessage | null> {
+ const parsed = this.parseUri(value);
+
+ if (parsed.id) {
+ return (await MessagingMessages.findOne({
+ id: parsed.id
+ })) || null;
+ }
+
+ if (parsed.uri) {
+ return (await MessagingMessages.findOne({
+ uri: parsed.uri
+ })) || null;
+ }
+
+ return null;
+ }
+
/**
* AP Person => Misskey User in DB
*/