mizzkey/src/remote/activitypub/kernel/create/index.ts

44 lines
1.3 KiB
TypeScript
Raw Normal View History

import Resolver from '../../resolver';
import { IRemoteUser } from '@/models/entities/user';
import createNote from './note';
import { ICreate, getApId, isPost, getApType } from '../../type';
import { apLogger } from '../../logger';
import { toArray, concat, unique } from '../../../../prelude/array';
2018-04-06 19:35:23 +09:00
const logger = apLogger;
2018-04-06 19:35:23 +09:00
2018-04-07 16:14:35 +09:00
export default async (actor: IRemoteUser, activity: ICreate): Promise<void> => {
const uri = getApId(activity);
2018-04-06 19:35:23 +09:00
logger.info(`Create: ${uri}`);
2018-04-06 19:35:23 +09:00
// copy audiences between activity <=> object.
if (typeof activity.object === 'object') {
const to = unique(concat([toArray(activity.to), toArray(activity.object.to)]));
const cc = unique(concat([toArray(activity.cc), toArray(activity.object.cc)]));
activity.to = to;
activity.cc = cc;
activity.object.to = to;
activity.object.cc = cc;
}
// If there is no attributedTo, use Activity actor.
if (typeof activity.object === 'object' && !activity.object.attributedTo) {
activity.object.attributedTo = activity.actor;
}
2018-04-06 19:35:23 +09:00
const resolver = new Resolver();
2019-11-18 06:23:44 +09:00
const object = await resolver.resolve(activity.object).catch(e => {
logger.error(`Resolution failed: ${e}`);
2018-04-06 19:35:23 +09:00
throw e;
2019-11-18 06:23:44 +09:00
});
2018-04-06 19:35:23 +09:00
if (isPost(object)) {
createNote(resolver, actor, object, false, activity);
} else {
logger.warn(`Unknown type: ${getApType(object)}`);
2018-04-06 19:35:23 +09:00
}
};