aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/controllers
diff options
context:
space:
mode:
Diffstat (limited to 'server/controllers')
-rw-r--r--server/controllers/api/actor.ts37
-rw-r--r--server/controllers/api/index.ts2
2 files changed, 39 insertions, 0 deletions
diff --git a/server/controllers/api/actor.ts b/server/controllers/api/actor.ts
new file mode 100644
index 000000000..da7f2eb91
--- /dev/null
+++ b/server/controllers/api/actor.ts
@@ -0,0 +1,37 @@
1import * as express from 'express'
2import { JobQueue } from '../../lib/job-queue'
3import { asyncMiddleware } from '../../middlewares'
4import { actorNameWithHostGetValidator } from '../../middlewares/validators'
5
6const actorRouter = express.Router()
7
8actorRouter.get('/:actorName',
9 asyncMiddleware(actorNameWithHostGetValidator),
10 getActor
11)
12
13// ---------------------------------------------------------------------------
14
15export {
16 actorRouter
17}
18
19// ---------------------------------------------------------------------------
20
21function getActor (req: express.Request, res: express.Response) {
22 let accountOrVideoChannel
23
24 if (res.locals.account) {
25 accountOrVideoChannel = res.locals.account
26 }
27
28 if (res.locals.videoChannel) {
29 accountOrVideoChannel = res.locals.videoChannel
30 }
31
32 if (accountOrVideoChannel.isOutdated()) {
33 JobQueue.Instance.createJob({ type: 'activitypub-refresher', payload: { type: 'actor', url: accountOrVideoChannel.Actor.url } })
34 }
35
36 return res.json(accountOrVideoChannel.toFormattedJSON())
37}
diff --git a/server/controllers/api/index.ts b/server/controllers/api/index.ts
index 7ade1df3a..4f4561ffd 100644
--- a/server/controllers/api/index.ts
+++ b/server/controllers/api/index.ts
@@ -15,6 +15,7 @@ import { pluginRouter } from './plugins'
15import { searchRouter } from './search' 15import { searchRouter } from './search'
16import { serverRouter } from './server' 16import { serverRouter } from './server'
17import { usersRouter } from './users' 17import { usersRouter } from './users'
18import { actorRouter } from './actor'
18import { videoChannelRouter } from './video-channel' 19import { videoChannelRouter } from './video-channel'
19import { videoPlaylistRouter } from './video-playlist' 20import { videoPlaylistRouter } from './video-playlist'
20import { videosRouter } from './videos' 21import { videosRouter } from './videos'
@@ -39,6 +40,7 @@ apiRouter.use('/bulk', bulkRouter)
39apiRouter.use('/oauth-clients', oauthClientsRouter) 40apiRouter.use('/oauth-clients', oauthClientsRouter)
40apiRouter.use('/config', configRouter) 41apiRouter.use('/config', configRouter)
41apiRouter.use('/users', usersRouter) 42apiRouter.use('/users', usersRouter)
43apiRouter.use('/actors', actorRouter)
42apiRouter.use('/accounts', accountsRouter) 44apiRouter.use('/accounts', accountsRouter)
43apiRouter.use('/video-channels', videoChannelRouter) 45apiRouter.use('/video-channels', videoChannelRouter)
44apiRouter.use('/video-playlists', videoPlaylistRouter) 46apiRouter.use('/video-playlists', videoPlaylistRouter)