import Resolver from '../../resolver'; import { IRemoteUser } from '../../../../models/entities/user'; import announceNote from './note'; import { IAnnounce, validPost, getApId } from '../../type'; import { apLogger } from '../../logger'; const logger = apLogger; export default async (actor: IRemoteUser, activity: IAnnounce): Promise => { const uri = getApId(activity); logger.info(`Announce: ${uri}`); const resolver = new Resolver(); const object = await resolver.resolve(activity.object).catch(e => { logger.error(`Resolution failed: ${e}`); throw e; }); if (validPost.includes(object.type)) { announceNote(resolver, actor, activity, object); } else { logger.warn(`Unknown announce type: ${object.type}`); } };