]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/lib/plugins/plugin-helpers-builder.ts
Add server plugin helpers
[github/Chocobozzz/PeerTube.git] / server / lib / plugins / plugin-helpers-builder.ts
CommitLineData
67ed6552 1import { PeerTubeHelpers } from '@server/types/plugins'
1b05d82d
C
2import { sequelizeTypescript } from '@server/initializers/database'
3import { buildLogger } from '@server/helpers/logger'
ab3ead3a 4import { VideoModel } from '@server/models/video/video'
5a7eecdd 5import { WEBSERVER } from '@server/initializers/constants'
80fdaf06
C
6import { ServerModel } from '@server/models/server/server'
7import { getServerActor } from '@server/models/application/application'
8import { addServerInBlocklist, removeServerFromBlocklist, addAccountInBlocklist, removeAccountFromBlocklist } from '../blocklist'
9import { ServerBlocklistModel } from '@server/models/server/server-blocklist'
10import { AccountModel } from '@server/models/account/account'
11import { VideoBlacklistCreate } from '@shared/models'
12import { blacklistVideo, unblacklistVideo } from '../video-blacklist'
13import { VideoBlacklistModel } from '@server/models/video/video-blacklist'
14import { AccountBlocklistModel } from '@server/models/account/account-blocklist'
22820226
C
15import { getServerConfig } from '../config'
16import { MPlugin } from '@server/types/models'
bc0d801b 17
22820226 18function buildPluginHelpers (pluginModel: MPlugin, npmName: string): PeerTubeHelpers {
1b05d82d
C
19 const logger = buildPluginLogger(npmName)
20
21 const database = buildDatabaseHelpers()
ab3ead3a 22 const videos = buildVideosHelpers()
bc0d801b 23
5a7eecdd
C
24 const config = buildConfigHelpers()
25
80fdaf06
C
26 const server = buildServerHelpers()
27
28 const moderation = buildModerationHelpers()
29
22820226
C
30 const plugin = buildPluginRelatedHelpers(pluginModel)
31
bc0d801b 32 return {
1b05d82d 33 logger,
ab3ead3a 34 database,
5a7eecdd 35 videos,
80fdaf06
C
36 config,
37 moderation,
22820226 38 plugin,
80fdaf06 39 server
bc0d801b
C
40 }
41}
42
43export {
44 buildPluginHelpers
45}
46
47// ---------------------------------------------------------------------------
48
1b05d82d 49function buildPluginLogger (npmName: string) {
bc0d801b
C
50 return buildLogger(npmName)
51}
1b05d82d
C
52
53function buildDatabaseHelpers () {
54 return {
55 query: sequelizeTypescript.query.bind(sequelizeTypescript)
56 }
57}
ab3ead3a 58
80fdaf06
C
59function buildServerHelpers () {
60 return {
61 getServerActor: () => getServerActor()
62 }
63}
64
ab3ead3a
C
65function buildVideosHelpers () {
66 return {
80fdaf06
C
67 loadByUrl: (url: string) => {
68 return VideoModel.loadByUrl(url)
69 },
70
6559da28
C
71 loadByIdOrUUID: (id: number | string) => {
72 return VideoModel.load(id)
73 },
74
ab3ead3a
C
75 removeVideo: (id: number) => {
76 return sequelizeTypescript.transaction(async t => {
77 const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(id, t)
78
79 await video.destroy({ transaction: t })
80 })
81 }
82 }
83}
5a7eecdd 84
80fdaf06
C
85function buildModerationHelpers () {
86 return {
87 blockServer: async (options: { byAccountId: number, hostToBlock: string }) => {
88 const serverToBlock = await ServerModel.loadOrCreateByHost(options.hostToBlock)
89
90 await addServerInBlocklist(options.byAccountId, serverToBlock.id)
91 },
92
93 unblockServer: async (options: { byAccountId: number, hostToUnblock: string }) => {
94 const serverBlock = await ServerBlocklistModel.loadByAccountAndHost(options.byAccountId, options.hostToUnblock)
95 if (!serverBlock) return
96
97 await removeServerFromBlocklist(serverBlock)
98 },
99
100 blockAccount: async (options: { byAccountId: number, handleToBlock: string }) => {
101 const accountToBlock = await AccountModel.loadByNameWithHost(options.handleToBlock)
102 if (!accountToBlock) return
103
104 await addAccountInBlocklist(options.byAccountId, accountToBlock.id)
105 },
106
107 unblockAccount: async (options: { byAccountId: number, handleToUnblock: string }) => {
108 const targetAccount = await AccountModel.loadByNameWithHost(options.handleToUnblock)
109 if (!targetAccount) return
110
111 const accountBlock = await AccountBlocklistModel.loadByAccountAndTarget(options.byAccountId, targetAccount.id)
112 if (!accountBlock) return
113
114 await removeAccountFromBlocklist(accountBlock)
115 },
116
117 blacklistVideo: async (options: { videoIdOrUUID: number | string, createOptions: VideoBlacklistCreate }) => {
118 const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(options.videoIdOrUUID)
119 if (!video) return
120
121 await blacklistVideo(video, options.createOptions)
122 },
123
124 unblacklistVideo: async (options: { videoIdOrUUID: number | string }) => {
125 const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(options.videoIdOrUUID)
126 if (!video) return
127
128 const videoBlacklist = await VideoBlacklistModel.loadByVideoId(video.id)
129 if (!videoBlacklist) return
130
131 await unblacklistVideo(videoBlacklist, video)
132 }
133 }
134}
135
5a7eecdd
C
136function buildConfigHelpers () {
137 return {
138 getWebserverUrl () {
139 return WEBSERVER.URL
22820226
C
140 },
141
142 getServerConfig () {
143 return getServerConfig()
5a7eecdd
C
144 }
145 }
146}
22820226
C
147
148function buildPluginRelatedHelpers (plugin: MPlugin) {
149 return {
150 getBaseStaticRoute: () => `/plugins/${plugin.name}/${plugin.version}/static/`
151 }
152}