mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 08:36:12 +01:00 
			
		
		
		
	feat: fix activitypub toggler to be more complete; tests. #13054
This commit is contained in:
		| @@ -289,6 +289,7 @@ | ||||
| 	"api.503": "The route you are trying to call is not currently available due to a server configuration", | ||||
| 	"api.reauth-required": "The resource you are trying to access requires (re-)authentication.", | ||||
|  | ||||
| 	"activitypub.not-enabled": "Federation is not enabled on this server", | ||||
| 	"activitypub.invalid-id": "Unable to resolve the input id, likely as it is malformed.", | ||||
| 	"activitypub.get-failed": "Unable to retrieve the specified resource.", | ||||
| 	"activitypub.pubKey-not-found": "Unable to resolve public key, so payload verification cannot take place.", | ||||
|   | ||||
| @@ -28,7 +28,13 @@ const sha256 = payload => crypto.createHash('sha256').update(payload).digest('he | ||||
|  | ||||
| const Helpers = module.exports; | ||||
|  | ||||
| let _lastLog; | ||||
| Helpers.log = (message) => { | ||||
| 	if (!message) { | ||||
| 		return _lastLog; | ||||
| 	} | ||||
|  | ||||
| 	_lastLog = message; | ||||
| 	if (process.env.NODE_ENV === 'development') { | ||||
| 		winston.verbose(message); | ||||
| 	} | ||||
|   | ||||
| @@ -263,6 +263,10 @@ ActivityPub.verify = async (req) => { | ||||
| }; | ||||
|  | ||||
| ActivityPub.get = async (type, id, uri, options) => { | ||||
| 	if (!meta.config.activitypubEnabled) { | ||||
| 		throw new Error('[[error:activitypub.not-enabled]]'); | ||||
| 	} | ||||
|  | ||||
| 	options = { | ||||
| 		cache: true, | ||||
| 		...options, | ||||
| @@ -358,6 +362,10 @@ async function sendMessage(uri, id, type, payload, attempts = 1) { | ||||
| } | ||||
|  | ||||
| ActivityPub.send = async (type, id, targets, payload) => { | ||||
| 	if (!meta.config.activitypubEnabled) { | ||||
| 		return ActivityPub.helpers.log('[activitypub/send] Federation not enabled; not sending.'); | ||||
| 	} | ||||
|  | ||||
| 	if (!Array.isArray(targets)) { | ||||
| 		targets = [targets]; | ||||
| 	} | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
| const nconf = require('nconf'); | ||||
| const winston = require('winston'); | ||||
|  | ||||
| const meta = require('../../meta'); | ||||
| const user = require('../../user'); | ||||
| const activitypub = require('../../activitypub'); | ||||
| const helpers = require('../helpers'); | ||||
| @@ -14,7 +15,7 @@ Controller.topics = require('./topics'); | ||||
|  | ||||
| Controller.fetch = async (req, res, next) => { | ||||
| 	// Given a `resource` query parameter, attempts to retrieve and parse it | ||||
| 	if (!req.query.resource) { | ||||
| 	if (!meta.config.activitypubEnabled || !req.query.resource) { | ||||
| 		return next(); | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -99,7 +99,7 @@ apiController.loadConfig = async function (req) { | ||||
| 			version: fontawesome_version, | ||||
| 		}, | ||||
| 		activitypub: { | ||||
| 			probe: meta.config.activitypubProbe, | ||||
| 			probe: meta.config.activitypubEnabled && meta.config.activitypubProbe, | ||||
| 		}, | ||||
| 	}; | ||||
|  | ||||
|   | ||||
| @@ -11,7 +11,6 @@ const request = require('../src/request'); | ||||
|  | ||||
| const file = require('../src/file'); | ||||
| const install = require('../src/install'); | ||||
| const privileges = require('../src/privileges'); | ||||
| const meta = require('../src/meta'); | ||||
| const user = require('../src/user'); | ||||
| const categories = require('../src/categories'); | ||||
| @@ -29,6 +28,52 @@ describe('ActivityPub integration', () => { | ||||
| 		delete meta.config.activitypubEnabled; | ||||
| 	}); | ||||
|  | ||||
| 	describe.only('Master toggle', () => { | ||||
| 		before(async () => { | ||||
| 			delete meta.config.activitypubEnabled; | ||||
| 		}); | ||||
|  | ||||
| 		it('calls to activitypub.get should throw', async () => { | ||||
| 			await assert.rejects( | ||||
| 				activitypub.get('uid', 0, 'https://example.org'), | ||||
| 				{ message: '[[error:activitypub.not-enabled]]' }, | ||||
| 			); | ||||
| 		}); | ||||
|  | ||||
| 		it('calls to activitypub.send should silently log', async () => { | ||||
| 			await activitypub.send('uid', 0, ['https://example.org'], { foo: 'bar' }); | ||||
| 			assert.strictEqual(activitypub.helpers.log(), '[activitypub/send] Federation not enabled; not sending.') | ||||
| 		}); | ||||
|  | ||||
| 		it('request for an activitypub route should return 404 Not Found', async () => { | ||||
| 			const uid = user.create({ username: utils.generateUUID() }); | ||||
| 			const { response } = await request.get(`${nconf.get('url')}/uid/${uid}`, { | ||||
| 				headers: { | ||||
| 					Accept: 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"', | ||||
| 				}, | ||||
| 			}); | ||||
|  | ||||
| 			assert.strictEqual(response.statusCode, 404); | ||||
| 		}); | ||||
|  | ||||
| 		it('requests to the /ap endpoint should return 404 Not Found', async () => { | ||||
| 			const { response } = await request.get(`${nconf.get('url')}/ap?resource=${encodeURIComponent('https://example.org')}`); | ||||
| 			assert.strictEqual(response.statusCode, 404); | ||||
| 		}); | ||||
|  | ||||
| 		it('webfinger requests to a local user should not indicate an application/activity+json endpoint', async () => { | ||||
| 			const username = utils.generateUUID().slice(0, 8); | ||||
| 			user.create({ username }); | ||||
| 			const { response, body } = await request.get(`${nconf.get('url')}/.well-known/webfinger?resource=acct:${username}@${nconf.get('url_parsed').host}`); | ||||
|  | ||||
| 			assert.strictEqual(response.statusCode, 200); | ||||
| 		}); | ||||
|  | ||||
| 		after(() => { | ||||
| 			meta.config.activitypubEnabled = 1; | ||||
| 		}); | ||||
| 	}); | ||||
|  | ||||
| 	describe('Helpers', () => { | ||||
| 		describe('.query()', () => { | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user