]>
git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - server/tests/fixtures/peertube-plugin-test/main.js
1 async
function register ({ registerHook
, registerSetting
, settingsManager
, storageManager
, peertubeHelpers
}) {
3 'action:application.listening',
4 'action:notifier.notification.created',
6 'action:api.video.updated',
7 'action:api.video.deleted',
8 'action:api.video.uploaded',
9 'action:api.video.viewed',
11 'action:api.video-channel.created',
12 'action:api.video-channel.updated',
13 'action:api.video-channel.deleted',
15 'action:api.live-video.created',
17 'action:api.video-thread.created',
18 'action:api.video-comment-reply.created',
19 'action:api.video-comment.deleted',
21 'action:api.video-caption.created',
22 'action:api.video-caption.deleted',
24 'action:api.user.blocked',
25 'action:api.user.unblocked',
26 'action:api.user.registered',
27 'action:api.user.created',
28 'action:api.user.deleted',
29 'action:api.user.updated',
30 'action:api.user.oauth2-got-token',
32 'action:api.video-playlist-element.created'
35 for (const h
of actionHooks
) {
38 handler: () => peertubeHelpers
.logger
.debug('Run hook %s.', h
)
43 target: 'filter:api.videos.list.params',
44 handler: obj
=> addToCount(obj
)
48 target: 'filter:api.videos.list.result',
49 handler: obj
=> addToTotal(obj
)
53 target: 'filter:api.video-playlist.videos.list.params',
54 handler: obj
=> addToCount(obj
)
58 target: 'filter:api.video-playlist.videos.list.result',
59 handler: obj
=> addToTotal(obj
)
63 target: 'filter:api.accounts.videos.list.params',
64 handler: obj
=> addToCount(obj
)
68 target: 'filter:api.accounts.videos.list.result',
69 handler: obj
=> addToTotal(obj
, 2)
73 target: 'filter:api.video-channels.videos.list.params',
74 handler: obj
=> addToCount(obj
, 3)
78 target: 'filter:api.video-channels.videos.list.result',
79 handler: obj
=> addToTotal(obj
, 3)
83 target: 'filter:api.user.me.videos.list.params',
84 handler: obj
=> addToCount(obj
, 4)
88 target: 'filter:api.user.me.videos.list.result',
89 handler: obj
=> addToTotal(obj
, 4)
93 target: 'filter:api.video.get.result',
101 // ---------------------------------------------------------------------------
104 target: 'filter:api.video-channels.list.params',
105 handler: obj
=> addToCount(obj
, 1)
109 target: 'filter:api.video-channels.list.result',
110 handler: obj
=> addToTotal(obj
, 1)
114 target: 'filter:api.video-channel.get.result',
115 handler: channel
=> {
116 channel
.name
+= ' <3'
122 // ---------------------------------------------------------------------------
124 for (const hook
of [ 'filter:api.video.upload.accept.result', 'filter:api.live-video.create.accept.result' ]) {
127 handler: ({ accepted
}, { videoBody
, liveVideoBody
}) => {
128 if (!accepted
) return { accepted: false }
130 const name
= videoBody
134 if (name
.indexOf('bad word') !== -1) return { accepted: false, errorMessage: 'bad word' }
136 return { accepted: true }
142 target: 'filter:api.video.pre-import-url.accept.result',
143 handler: ({ accepted
}, { videoImportBody
}) => {
144 if (!accepted
) return { accepted: false }
145 if (videoImportBody
.targetUrl
.includes('bad')) return { accepted: false, errorMessage: 'bad target url' }
147 return { accepted: true }
152 target: 'filter:api.video.pre-import-torrent.accept.result',
153 handler: ({ accepted
}, { videoImportBody
}) => {
154 if (!accepted
) return { accepted: false }
155 if (videoImportBody
.name
.includes('bad torrent')) return { accepted: false, errorMessage: 'bad torrent' }
157 return { accepted: true }
162 target: 'filter:api.video.post-import-url.accept.result',
163 handler: ({ accepted
}, { video
}) => {
164 if (!accepted
) return { accepted: false }
165 if (video
.name
.includes('bad word')) return { accepted: false, errorMessage: 'bad word' }
167 return { accepted: true }
172 target: 'filter:api.video.post-import-torrent.accept.result',
173 handler: ({ accepted
}, { video
}) => {
174 if (!accepted
) return { accepted: false }
175 if (video
.name
.includes('bad word')) return { accepted: false, errorMessage: 'bad word' }
177 return { accepted: true }
181 // ---------------------------------------------------------------------------
184 target: 'filter:api.video-thread.create.accept.result',
185 handler: ({ accepted
}, { commentBody
}) => checkCommentBadWord(accepted
, commentBody
)
189 target: 'filter:api.video-comment-reply.create.accept.result',
190 handler: ({ accepted
}, { commentBody
}) => checkCommentBadWord(accepted
, commentBody
)
194 target: 'filter:activity-pub.remote-video-comment.create.accept.result',
195 handler: ({ accepted
}, { comment
}) => checkCommentBadWord(accepted
, comment
)
198 // ---------------------------------------------------------------------------
201 target: 'filter:api.video-threads.list.params',
202 handler: obj
=> addToCount(obj
)
206 target: 'filter:api.video-threads.list.result',
207 handler: obj
=> addToTotal(obj
)
211 target: 'filter:api.video-thread-comments.list.result',
213 obj
.data
.forEach(c
=> c
.text
+= ' <3')
220 target: 'filter:video.auto-blacklist.result',
221 handler: (blacklisted
, { video
}) => {
222 if (blacklisted
) return true
223 if (video
.name
.includes('please blacklist me')) return true
230 target: 'filter:api.user.signup.allowed.result',
231 handler: (result
, params
) => {
232 if (params
&& params
.body
&& params
.body
.email
&& params
.body
.email
.includes('jma')) {
233 return { allowed: false, errorMessage: 'No jma' }
241 target: 'filter:api.download.torrent.allowed.result',
242 handler: (result
, params
) => {
243 if (params
&& params
.downloadName
.includes('bad torrent')) {
244 return { allowed: false, errorMessage: 'Liu Bei' }
252 target: 'filter:api.download.video.allowed.result',
253 handler: (result
, params
) => {
254 if (params
&& !params
.streamingPlaylist
&& params
.video
.name
.includes('bad file')) {
255 return { allowed: false, errorMessage: 'Cao Cao' }
258 if (params
&& params
.streamingPlaylist
&& params
.video
.name
.includes('bad playlist file')) {
259 return { allowed: false, errorMessage: 'Sun Jian' }
267 target: 'filter:html.embed.video.allowed.result',
268 handler: (result
, params
) => {
277 target: 'filter:html.embed.video-playlist.allowed.result',
278 handler: (result
, params
) => {
287 target: 'filter:api.server.stats.get.result',
288 handler: (result
) => {
289 return { ...result
, customStats: 14 }
294 target: 'filter:job-queue.process.params',
295 handler: (object
, context
) => {
296 if (context
.type
!== 'video-studio-edition') return object
298 object
.data
.tasks
= [
313 target: 'filter:transcoding.auto.resolutions-to-transcode.result',
314 handler: (object
, context
) => {
315 if (context
.video
.name
.includes('transcode-filter')) {
323 // Upload/import/live attributes
324 for (const target
of [
325 'filter:api.video.upload.video-attribute.result',
326 'filter:api.video.import-url.video-attribute.result',
327 'filter:api.video.import-torrent.video-attribute.result',
328 'filter:api.video.live.video-attribute.result'
332 handler: (result
) => {
333 return { ...result
, description: result
.description
+ ' - ' + target
}
339 const filterHooks
= [
340 'filter:api.search.videos.local.list.params',
341 'filter:api.search.videos.local.list.result',
342 'filter:api.search.videos.index.list.params',
343 'filter:api.search.videos.index.list.result',
344 'filter:api.search.video-channels.local.list.params',
345 'filter:api.search.video-channels.local.list.result',
346 'filter:api.search.video-channels.index.list.params',
347 'filter:api.search.video-channels.index.list.result',
348 'filter:api.search.video-playlists.local.list.params',
349 'filter:api.search.video-playlists.local.list.result',
350 'filter:api.search.video-playlists.index.list.params',
351 'filter:api.search.video-playlists.index.list.result',
353 'filter:api.overviews.videos.list.params',
354 'filter:api.overviews.videos.list.result',
356 'filter:job-queue.process.params',
357 'filter:job-queue.process.result'
360 for (const h
of filterHooks
) {
364 peertubeHelpers
.logger
.debug('Run hook %s.', h
)
373 async
function unregister () {
382 // ############################################################################
384 function addToCount (obj
, amount
= 1) {
385 return Object
.assign({}, obj
, { count: obj
.count
+ amount
})
388 function addToTotal (result
, amount
= 1) {
391 total: result
.total
+ amount
395 function checkCommentBadWord (accepted
, commentBody
) {
396 if (!accepted
) return { accepted: false }
397 if (commentBody
.text
.indexOf('bad word') !== -1) return { accepted: false, errorMessage: 'bad word '}
399 return { accepted: true }