aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/controllers/activitypub/inbox.ts
diff options
context:
space:
mode:
authorChocobozzz <me@florianbigard.com>2023-07-31 14:34:36 +0200
committerChocobozzz <me@florianbigard.com>2023-08-11 15:02:33 +0200
commit3a4992633ee62d5edfbb484d9c6bcb3cf158489d (patch)
treee4510b39bdac9c318fdb4b47018d08f15368b8f0 /server/controllers/activitypub/inbox.ts
parent04d1da5621d25d59bd5fa1543b725c497bf5d9a8 (diff)
downloadPeerTube-3a4992633ee62d5edfbb484d9c6bcb3cf158489d.tar.gz
PeerTube-3a4992633ee62d5edfbb484d9c6bcb3cf158489d.tar.zst
PeerTube-3a4992633ee62d5edfbb484d9c6bcb3cf158489d.zip
Migrate server to ESM
Sorry for the very big commit that may lead to git log issues and merge conflicts, but it's a major step forward: * Server can be faster at startup because imports() are async and we can easily lazy import big modules * Angular doesn't seem to support ES import (with .js extension), so we had to correctly organize peertube into a monorepo: * Use yarn workspace feature * Use typescript reference projects for dependencies * Shared projects have been moved into "packages", each one is now a node module (with a dedicated package.json/tsconfig.json) * server/tools have been moved into apps/ and is now a dedicated app bundled and published on NPM so users don't have to build peertube cli tools manually * server/tests have been moved into packages/ so we don't compile them every time we want to run the server * Use isolatedModule option: * Had to move from const enum to const (https://www.typescriptlang.org/docs/handbook/enums.html#objects-vs-enums) * Had to explictely specify "type" imports when used in decorators * Prefer tsx (that uses esbuild under the hood) instead of ts-node to load typescript files (tests with mocha or scripts): * To reduce test complexity as esbuild doesn't support decorator metadata, we only test server files that do not import server models * We still build tests files into js files for a faster CI * Remove unmaintained peertube CLI import script * Removed some barrels to speed up execution (less imports)
Diffstat (limited to 'server/controllers/activitypub/inbox.ts')
-rw-r--r--server/controllers/activitypub/inbox.ts85
1 files changed, 0 insertions, 85 deletions
diff --git a/server/controllers/activitypub/inbox.ts b/server/controllers/activitypub/inbox.ts
deleted file mode 100644
index 862c7baf1..000000000
--- a/server/controllers/activitypub/inbox.ts
+++ /dev/null
@@ -1,85 +0,0 @@
1import express from 'express'
2import { InboxManager } from '@server/lib/activitypub/inbox-manager'
3import { Activity, ActivityPubCollection, ActivityPubOrderedCollection, RootActivity } from '@shared/models'
4import { HttpStatusCode } from '../../../shared/models/http/http-error-codes'
5import { isActivityValid } from '../../helpers/custom-validators/activitypub/activity'
6import { logger } from '../../helpers/logger'
7import {
8 activityPubRateLimiter,
9 asyncMiddleware,
10 checkSignature,
11 ensureIsLocalChannel,
12 localAccountValidator,
13 signatureValidator,
14 videoChannelsNameWithHostValidator
15} from '../../middlewares'
16import { activityPubValidator } from '../../middlewares/validators/activitypub/activity'
17
18const inboxRouter = express.Router()
19
20inboxRouter.post('/inbox',
21 activityPubRateLimiter,
22 signatureValidator,
23 asyncMiddleware(checkSignature),
24 asyncMiddleware(activityPubValidator),
25 inboxController
26)
27
28inboxRouter.post('/accounts/:name/inbox',
29 activityPubRateLimiter,
30 signatureValidator,
31 asyncMiddleware(checkSignature),
32 asyncMiddleware(localAccountValidator),
33 asyncMiddleware(activityPubValidator),
34 inboxController
35)
36
37inboxRouter.post('/video-channels/:nameWithHost/inbox',
38 activityPubRateLimiter,
39 signatureValidator,
40 asyncMiddleware(checkSignature),
41 asyncMiddleware(videoChannelsNameWithHostValidator),
42 ensureIsLocalChannel,
43 asyncMiddleware(activityPubValidator),
44 inboxController
45)
46
47// ---------------------------------------------------------------------------
48
49export {
50 inboxRouter
51}
52
53// ---------------------------------------------------------------------------
54
55function inboxController (req: express.Request, res: express.Response) {
56 const rootActivity: RootActivity = req.body
57 let activities: Activity[]
58
59 if ([ 'Collection', 'CollectionPage' ].includes(rootActivity.type)) {
60 activities = (rootActivity as ActivityPubCollection).items
61 } else if ([ 'OrderedCollection', 'OrderedCollectionPage' ].includes(rootActivity.type)) {
62 activities = (rootActivity as ActivityPubOrderedCollection<Activity>).orderedItems
63 } else {
64 activities = [ rootActivity as Activity ]
65 }
66
67 // Only keep activities we are able to process
68 logger.debug('Filtering %d activities...', activities.length)
69 activities = activities.filter(a => isActivityValid(a))
70 logger.debug('We keep %d activities.', activities.length, { activities })
71
72 const accountOrChannel = res.locals.account || res.locals.videoChannel
73
74 logger.info('Receiving inbox requests for %d activities by %s.', activities.length, res.locals.signature.actor.url)
75
76 InboxManager.Instance.addInboxMessage({
77 activities,
78 signatureActor: res.locals.signature.actor,
79 inboxActor: accountOrChannel
80 ? accountOrChannel.Actor
81 : undefined
82 })
83
84 return res.status(HttpStatusCode.NO_CONTENT_204).end()
85}