aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/controllers/themes.ts
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/controllers/themes.ts
parent297067399db2bf7505561d67667ca0d559a8e42b (diff)
downloadPeerTube-345da516fae80f24c90c2196e96393b489af2243.tar.gz
PeerTube-345da516fae80f24c90c2196e96393b489af2243.tar.zst
PeerTube-345da516fae80f24c90c2196e96393b489af2243.zip
WIP plugins: add ability to register plugins
Diffstat (limited to 'server/controllers/themes.ts')
-rw-r--r--server/controllers/themes.ts28
1 files changed, 28 insertions, 0 deletions
diff --git a/server/controllers/themes.ts b/server/controllers/themes.ts
new file mode 100644
index 000000000..20e7062d0
--- /dev/null
+++ b/server/controllers/themes.ts
@@ -0,0 +1,28 @@
1import * as express from 'express'
2import { PLUGIN_GLOBAL_CSS_PATH } from '../initializers/constants'
3import { join } from 'path'
4import { RegisteredPlugin } from '../lib/plugins/plugin-manager'
5import { servePluginStaticDirectoryValidator } from '../middlewares/validators/plugins'
6import { serveThemeCSSValidator } from '../middlewares/validators/themes'
7
8const themesRouter = express.Router()
9
10themesRouter.get('/:themeName/:themeVersion/css/:staticEndpoint',
11 serveThemeCSSValidator,
12 serveThemeCSSDirectory
13)
14
15// ---------------------------------------------------------------------------
16
17export {
18 themesRouter
19}
20
21// ---------------------------------------------------------------------------
22
23function serveThemeCSSDirectory (req: express.Request, res: express.Response) {
24 const plugin: RegisteredPlugin = res.locals.registeredPlugin
25 const staticEndpoint = req.params.staticEndpoint
26
27 return express.static(join(plugin.path, staticEndpoint), { fallthrough: false })
28}