Johann150
36a0e48e49
All checks were successful
ci/woodpecker/push/lint-client Pipeline was successful
ci/woodpecker/push/lint-foundkey-js Pipeline was successful
ci/woodpecker/push/lint-backend Pipeline was successful
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/test Pipeline was successful
There are still many places where import paths with `..` are used and maybe should use absolute paths also.
45 lines
1.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
import { CacheableRemoteUser } from '@/models/entities/user.js';
|
|
import { getApLock } from '@/misc/app-lock.js';
|
|
import { extractDbHost } from '@/misc/convert-host.js';
|
|
import { StatusError } from '@/misc/fetch.js';
|
|
import Resolver from '@/remote/activitypub/resolver.js';
|
|
import { createNote, fetchNote } from '@/remote/activitypub/models/note.js';
|
|
import { getApId, IObject, ICreate } from '@/remote/activitypub/type.js';
|
|
|
|
/**
|
|
* 投稿作成アクティビティを捌きます
|
|
*/
|
|
export default async function(resolver: Resolver, actor: CacheableRemoteUser, note: IObject, silent = false, activity?: ICreate): Promise<string> {
|
|
const uri = getApId(note);
|
|
|
|
if (typeof note === 'object') {
|
|
if (actor.uri !== note.attributedTo) {
|
|
return 'skip: actor.uri !== note.attributedTo';
|
|
}
|
|
|
|
if (typeof note.id === 'string') {
|
|
if (extractDbHost(actor.uri) !== extractDbHost(note.id)) {
|
|
return 'skip: host in actor.uri !== note.id';
|
|
}
|
|
}
|
|
}
|
|
|
|
const unlock = await getApLock(uri);
|
|
|
|
try {
|
|
const exist = await fetchNote(note);
|
|
if (exist) return 'skip: note exists';
|
|
|
|
await createNote(note, resolver, silent);
|
|
return 'ok';
|
|
} catch (e) {
|
|
if (e instanceof StatusError && e.isClientError) {
|
|
return `skip ${e.statusCode}`;
|
|
} else {
|
|
throw e;
|
|
}
|
|
} finally {
|
|
unlock();
|
|
}
|
|
}
|