90 lines
2.7 KiB
JavaScript
Raw Normal View History

2023-01-24 19:16:14 -06:00
const { selfUrl, WellKnownActivityTypes } = require('./util');
2023-01-19 22:31:14 -07:00
const ActivityPubObject = require('./object');
2023-01-12 23:19:52 -07:00
const { Errors } = require('../enig_error');
const UserProps = require('../user_property');
const { postJson } = require('../http_util');
2023-01-24 18:11:28 -07:00
const { getISOTimestampString } = require('../database');
// deps
const _ = require('lodash');
2023-01-19 22:31:14 -07:00
module.exports = class Activity extends ActivityPubObject {
constructor(obj) {
2023-01-19 22:31:14 -07:00
super(obj);
}
static get ActivityTypes() {
2023-01-19 22:31:14 -07:00
return WellKnownActivityTypes;
}
static makeFollow(webServer, localActor, remoteActor) {
2023-01-22 13:51:32 -07:00
return new Activity({
id: Activity.activityObjectId(webServer),
2023-01-22 13:51:32 -07:00
type: 'Follow',
actor: localActor,
object: remoteActor.id,
});
}
// https://www.w3.org/TR/activitypub/#accept-activity-inbox
static makeAccept(webServer, localActor, followRequest) {
return new Activity({
id: Activity.activityObjectId(webServer),
type: 'Accept',
actor: localActor,
object: followRequest, // previous request Activity
});
}
static makeCreate(webServer, actor, obj) {
return new Activity({
id: Activity.activityObjectId(webServer),
type: 'Create',
actor,
object: obj,
});
}
2023-01-24 18:11:28 -07:00
static makeTombstone(obj) {
const deleted = getISOTimestampString();
return new Activity({
id: obj.id,
type: 'Tombstone',
deleted,
published: deleted,
updated: deleted,
});
}
sendTo(actorUrl, fromUser, webServer, cb) {
const privateKey = fromUser.getProperty(UserProps.PrivateActivityPubSigningKey);
if (_.isEmpty(privateKey)) {
return cb(
Errors.MissingProperty(
`User "${fromUser.username}" is missing the '${UserProps.PrivateActivityPubSigningKey}' property`
)
);
}
const reqOpts = {
headers: {
'Content-Type': 'application/activity+json',
},
sign: {
// :TODO: Make a helper for this
key: privateKey,
keyId: selfUrl(webServer, fromUser) + '#main-key',
authorizationHeaderName: 'Signature',
headers: ['(request-target)', 'host', 'date', 'digest', 'content-type'],
},
};
const activityJson = JSON.stringify(this);
return postJson(actorUrl, activityJson, reqOpts, cb);
}
static activityObjectId(webServer) {
return ActivityPubObject.makeObjectId(webServer, 'activity');
}
};