refactor: minor restructure to move logic out of main controller file to src/api

This commit is contained in:
Julian Lam
2023-12-08 10:55:16 -05:00
parent 8a5fb86ddf
commit c803b2124c
3 changed files with 60 additions and 39 deletions

53
src/api/activitypub.js Normal file
View File

@@ -0,0 +1,53 @@
'use strict';
/**
* DEVELOPMENT NOTE
*
* THIS FILE IS UNDER ACTIVE DEVELOPMENT AND IS EXPLICITLY EXCLUDED FROM IMMUTABILITY GUARANTEES
*
* If you use api methods in this file, be prepared that they may be removed or modified with no warning.
*/
const db = require('../database');
const activitypub = require('../activitypub');
const activitypubApi = module.exports;
activitypubApi.follow = async (caller, { actorId } = {}) => {
if (!actorId) {
throw new Error('[[error:invalid-uid]]'); // should be activitypub-specific
}
await activitypub.send(caller.uid, actorId, {
type: 'Follow',
object: {
type: 'Person',
name: actorId,
},
});
const now = Date.now();
await Promise.all([
db.sortedSetAdd(`followingRemote:${caller.uid}`, now, actorId),
db.incrObjectField(`user:${caller.uid}`, 'followingRemoteCount'),
]);
};
activitypubApi.unfollow = async (caller, { actorId }) => {
if (!actorId) {
throw new Error('[[error:invalid-uid]]'); // should be activitypub-specific
}
await activitypub.send(caller.uid, actorId, {
type: 'Unfollow',
object: {
type: 'Person',
name: actorId,
},
});
await Promise.all([
db.sortedSetRemove(`followingRemote:${caller.uid}`, actorId),
db.decrObjectField(`user:${caller.uid}`, 'followingRemoteCount'),
]);
};

View File

@@ -11,6 +11,7 @@ module.exports = {
categories: require('./categories'), categories: require('./categories'),
search: require('./search'), search: require('./search'),
flags: require('./flags'), flags: require('./flags'),
activitypub: require('./activitypub'),
files: require('./files'), files: require('./files'),
utils: require('./utils'), utils: require('./utils'),
}; };

View File

@@ -5,6 +5,7 @@ const nconf = require('nconf');
const db = require('../../database'); const db = require('../../database');
const user = require('../../user'); const user = require('../../user');
const activitypub = require('../../activitypub'); const activitypub = require('../../activitypub');
const api = require('../../api');
const helpers = require('../helpers'); const helpers = require('../helpers');
const Controller = module.exports; const Controller = module.exports;
@@ -101,6 +102,7 @@ Controller.getInbox = async (req, res) => {
}; };
Controller.postInbox = async (req, res) => { Controller.postInbox = async (req, res) => {
// Note: internal-only, hence no exposure via src/api
switch (req.body.type) { switch (req.body.type) {
case 'Follow': { case 'Follow': {
await activitypub.inbox.follow(req.body.actor.name, req.body.object.name); await activitypub.inbox.follow(req.body.actor.name, req.body.object.name);
@@ -121,46 +123,11 @@ Controller.postInbox = async (req, res) => {
*/ */
Controller.follow = async (req, res) => { Controller.follow = async (req, res) => {
try { const { uid: actorId } = req.params;
const { uid: actorId } = req.params; helpers.formatApiResponse(200, res, await api.activitypub.follow(req, { actorId }));
await activitypub.send(req.uid, actorId, {
type: 'Follow',
object: {
type: 'Person',
name: actorId,
},
});
const now = Date.now();
await Promise.all([
db.sortedSetAdd(`followingRemote:${req.uid}`, now, actorId),
db.incrObjectField(`user:${req.uid}`, 'followingRemoteCount'),
]);
helpers.formatApiResponse(200, res);
} catch (e) {
helpers.formatApiResponse(400, res, e);
}
}; };
Controller.unfollow = async (req, res) => { Controller.unfollow = async (req, res) => {
try { const { uid: actorId } = req.params;
const { uid: actorId } = req.params; helpers.formatApiResponse(200, res, await api.activitypub.unfollow(req, { actorId }));
await activitypub.send(req.uid, actorId, {
type: 'Unfollow',
object: {
type: 'Person',
name: actorId,
},
});
await Promise.all([
db.sortedSetRemove(`followingRemote:${req.uid}`, actorId),
db.decrObjectField(`user:${req.uid}`, 'followingRemoteCount'),
]);
helpers.formatApiResponse(200, res);
} catch (e) {
helpers.formatApiResponse(400, res, e);
}
}; };