aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/middlewares
diff options
context:
space:
mode:
authorChocobozzz <me@florianbigard.com>2019-07-05 13:54:32 +0200
committerChocobozzz <chocobozzz@cpy.re>2019-07-24 10:58:16 +0200
commit345da516fae80f24c90c2196e96393b489af2243 (patch)
tree64d72d25a531626c1d4a6337460dae4e32386f2a /server/middlewares
parent297067399db2bf7505561d67667ca0d559a8e42b (diff)
downloadPeerTube-345da516fae80f24c90c2196e96393b489af2243.tar.gz
PeerTube-345da516fae80f24c90c2196e96393b489af2243.tar.zst
PeerTube-345da516fae80f24c90c2196e96393b489af2243.zip
WIP plugins: add ability to register plugins
Diffstat (limited to 'server/middlewares')
-rw-r--r--server/middlewares/validators/plugins.ts35
-rw-r--r--server/middlewares/validators/themes.ts39
2 files changed, 74 insertions, 0 deletions
diff --git a/server/middlewares/validators/plugins.ts b/server/middlewares/validators/plugins.ts
new file mode 100644
index 000000000..672299ee1
--- /dev/null
+++ b/server/middlewares/validators/plugins.ts
@@ -0,0 +1,35 @@
1import * as express from 'express'
2import { param } from 'express-validator/check'
3import { logger } from '../../helpers/logger'
4import { areValidationErrors } from './utils'
5import { isPluginNameValid, isPluginVersionValid } from '../../helpers/custom-validators/plugins'
6import { PluginManager } from '../../lib/plugins/plugin-manager'
7import { isSafePath } from '../../helpers/custom-validators/misc'
8
9const servePluginStaticDirectoryValidator = [
10 param('pluginName').custom(isPluginNameValid).withMessage('Should have a valid plugin name'),
11 param('pluginVersion').custom(isPluginVersionValid).withMessage('Should have a valid plugin version'),
12 param('staticEndpoint').custom(isSafePath).withMessage('Should have a valid static endpoint'),
13
14 (req: express.Request, res: express.Response, next: express.NextFunction) => {
15 logger.debug('Checking servePluginStaticDirectory parameters', { parameters: req.params })
16
17 if (areValidationErrors(req, res)) return
18
19 const plugin = PluginManager.Instance.getRegisteredPlugin(req.params.pluginName)
20
21 if (!plugin || plugin.version !== req.params.pluginVersion) {
22 return res.sendStatus(404)
23 }
24
25 res.locals.registeredPlugin = plugin
26
27 return next()
28 }
29]
30
31// ---------------------------------------------------------------------------
32
33export {
34 servePluginStaticDirectoryValidator
35}
diff --git a/server/middlewares/validators/themes.ts b/server/middlewares/validators/themes.ts
new file mode 100644
index 000000000..642f2df78
--- /dev/null
+++ b/server/middlewares/validators/themes.ts
@@ -0,0 +1,39 @@
1import * as express from 'express'
2import { param } from 'express-validator/check'
3import { logger } from '../../helpers/logger'
4import { areValidationErrors } from './utils'
5import { isPluginNameValid, isPluginVersionValid } from '../../helpers/custom-validators/plugins'
6import { PluginManager } from '../../lib/plugins/plugin-manager'
7import { isSafePath } from '../../helpers/custom-validators/misc'
8
9const serveThemeCSSValidator = [
10 param('themeName').custom(isPluginNameValid).withMessage('Should have a valid theme name'),
11 param('themeVersion').custom(isPluginVersionValid).withMessage('Should have a valid theme version'),
12 param('staticEndpoint').custom(isSafePath).withMessage('Should have a valid static endpoint'),
13
14 (req: express.Request, res: express.Response, next: express.NextFunction) => {
15 logger.debug('Checking serveThemeCSS parameters', { parameters: req.params })
16
17 if (areValidationErrors(req, res)) return
18
19 const theme = PluginManager.Instance.getRegisteredTheme(req.params.themeName)
20
21 if (!theme || theme.version !== req.params.themeVersion) {
22 return res.sendStatus(404)
23 }
24
25 if (theme.css.includes(req.params.staticEndpoint) === false) {
26 return res.sendStatus(404)
27 }
28
29 res.locals.registeredPlugin = theme
30
31 return next()
32 }
33]
34
35// ---------------------------------------------------------------------------
36
37export {
38 serveThemeCSSValidator
39}