mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2024-11-23 17:13:08 +02:00
Fix bug
This commit is contained in:
parent
765a10c8da
commit
de620c822a
2 changed files with 28 additions and 5 deletions
|
@ -1,18 +1,35 @@
|
|||
import Resolver from '../../resolver';
|
||||
import deleteNote from './note';
|
||||
import Post from '../../../../models/post';
|
||||
|
||||
/**
|
||||
* 削除アクティビティを捌きます
|
||||
*/
|
||||
export default async (actor, activity): Promise<void> => {
|
||||
if ('actor' in activity && actor.account.uri !== activity.actor) {
|
||||
throw new Error();
|
||||
throw new Error('invalid actor');
|
||||
}
|
||||
|
||||
const resolver = new Resolver();
|
||||
|
||||
const object = await resolver.resolve(activity);
|
||||
const object = await resolver.resolve(activity.object);
|
||||
|
||||
const uri = (object as any).id;
|
||||
|
||||
switch (object.type) {
|
||||
case 'Note':
|
||||
deleteNote(object);
|
||||
deleteNote(uri);
|
||||
break;
|
||||
|
||||
case 'Tombstone':
|
||||
const post = await Post.findOne({ uri });
|
||||
if (post != null) {
|
||||
deleteNote(uri);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
console.warn(`Unknown type: ${object.type}`);
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
|
|
@ -1,8 +1,14 @@
|
|||
import * as debug from 'debug';
|
||||
|
||||
import Post from '../../../../models/post';
|
||||
import { createDb } from '../../../../queue';
|
||||
|
||||
export default async function(note) {
|
||||
const post = await Post.findOneAndDelete({ uri: note.id });
|
||||
const log = debug('misskey:activitypub');
|
||||
|
||||
export default async function(uri: string) {
|
||||
log(`Deleting the Note: ${uri}`);
|
||||
|
||||
const post = await Post.findOneAndDelete({ uri });
|
||||
|
||||
createDb({
|
||||
type: 'deletePostDependents',
|
||||
|
|
Loading…
Reference in a new issue