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.
73 lines
2.2 KiB
TypeScript
73 lines
2.2 KiB
TypeScript
import post from '@/services/note/create.js';
|
|
import { CacheableRemoteUser } from '@/models/entities/user.js';
|
|
import { extractDbHost } from '@/misc/convert-host.js';
|
|
import { fetchMeta } from '@/misc/fetch-meta.js';
|
|
import { getApLock } from '@/misc/app-lock.js';
|
|
import { StatusError } from '@/misc/fetch.js';
|
|
import { Notes } from '@/models/index.js';
|
|
import { parseAudience } from '@/remote/activitypub/audience.js';
|
|
import { apLogger } from '@/remote/activitypub/logger.js';
|
|
import { fetchNote, resolveNote } from '@/remote/activitypub/models/note.js';
|
|
import Resolver from '@/remote/activitypub/resolver.js';
|
|
import { IAnnounce, getApId } from '@/remote/activitypub/type.js';
|
|
|
|
const logger = apLogger;
|
|
|
|
/**
|
|
* アナウンスアクティビティを捌きます
|
|
*/
|
|
export default async function(resolver: Resolver, actor: CacheableRemoteUser, activity: IAnnounce, targetUri: string): Promise<void> {
|
|
const uri = getApId(activity);
|
|
|
|
if (actor.isSuspended) {
|
|
return;
|
|
}
|
|
|
|
// アナウンス先をブロックしてたら中断
|
|
const meta = await fetchMeta();
|
|
if (meta.blockedHosts.includes(extractDbHost(uri))) return;
|
|
|
|
const unlock = await getApLock(uri);
|
|
|
|
try {
|
|
// 既に同じURIを持つものが登録されていないかチェック
|
|
const exist = await fetchNote(uri);
|
|
if (exist) {
|
|
return;
|
|
}
|
|
|
|
// Announce対象をresolve
|
|
let renote;
|
|
try {
|
|
renote = await resolveNote(targetUri);
|
|
} catch (e) {
|
|
// 対象が4xxならスキップ
|
|
if (e instanceof StatusError) {
|
|
if (e.isClientError) {
|
|
logger.warn(`Ignored announce target ${targetUri} - ${e.statusCode}`);
|
|
return;
|
|
}
|
|
|
|
logger.warn(`Error in announce target ${targetUri} - ${e.statusCode || e}`);
|
|
}
|
|
throw e;
|
|
}
|
|
|
|
if (!await Notes.isVisibleForMe(renote, actor.id)) return 'skip: invalid actor for this activity';
|
|
|
|
logger.info(`Creating the (Re)Note: ${uri}`);
|
|
|
|
const activityAudience = await parseAudience(actor, activity.to, activity.cc);
|
|
|
|
await post(actor, {
|
|
createdAt: activity.published ? new Date(activity.published) : null,
|
|
renote,
|
|
visibility: activityAudience.visibility,
|
|
visibleUsers: activityAudience.visibleUsers,
|
|
uri,
|
|
});
|
|
} finally {
|
|
unlock();
|
|
}
|
|
}
|