From 9aac44236c84f17b14ce35e358a87389766e2743 Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Fri, 14 Dec 2018 15:49:36 +0100 Subject: [PATCH] Add video title/description when rendering html --- server/controllers/client.ts | 18 ++++++------- server/lib/client-html.ts | 51 +++++++++++++++++++++++------------- 2 files changed, 41 insertions(+), 28 deletions(-) diff --git a/server/controllers/client.ts b/server/controllers/client.ts index e5bd487f1..f17f2a5d2 100644 --- a/server/controllers/client.ts +++ b/server/controllers/client.ts @@ -16,22 +16,20 @@ const testEmbedPath = join(distPath, 'standalone', 'videos', 'test-embed.html') // Special route that add OpenGraph and oEmbed tags // Do not use a template engine for a so little thing -clientsRouter.use('/videos/watch/:id', - asyncMiddleware(generateWatchHtmlPage) -) +clientsRouter.use('/videos/watch/:id', asyncMiddleware(generateWatchHtmlPage)) -clientsRouter.use('' + +clientsRouter.use( '/videos/embed', embedCSP, - (req: express.Request, res: express.Response, next: express.NextFunction) => { + (req: express.Request, res: express.Response) => { res.removeHeader('X-Frame-Options') res.sendFile(embedPath) } ) -clientsRouter.use('' + - '/videos/test-embed', (req: express.Request, res: express.Response, next: express.NextFunction) => { - res.sendFile(testEmbedPath) -}) +clientsRouter.use( + '/videos/test-embed', + (req: express.Request, res: express.Response) => res.sendFile(testEmbedPath) +) // Static HTML/CSS/JS client files @@ -90,7 +88,7 @@ export { // --------------------------------------------------------------------------- async function generateHTMLPage (req: express.Request, res: express.Response, paramLang?: string) { - const html = await ClientHtml.getIndexHTML(req, res, paramLang) + const html = await ClientHtml.getDefaultHTMLPage(req, res, paramLang) return sendHTML(html, res) } diff --git a/server/lib/client-html.ts b/server/lib/client-html.ts index fc013e0c3..2db3f8a34 100644 --- a/server/lib/client-html.ts +++ b/server/lib/client-html.ts @@ -18,21 +18,13 @@ export class ClientHtml { ClientHtml.htmlCache = {} } - static async getIndexHTML (req: express.Request, res: express.Response, paramLang?: string) { - const path = ClientHtml.getIndexPath(req, res, paramLang) - if (ClientHtml.htmlCache[path]) return ClientHtml.htmlCache[path] + static async getDefaultHTMLPage (req: express.Request, res: express.Response, paramLang?: string) { + const html = await ClientHtml.getIndexHTML(req, res, paramLang) - const buffer = await readFile(path) + let customHtml = ClientHtml.addTitleTag(html) + customHtml = ClientHtml.addDescriptionTag(customHtml) - let html = buffer.toString() - - html = ClientHtml.addTitleTag(html) - html = ClientHtml.addDescriptionTag(html) - html = ClientHtml.addCustomCSS(html) - - ClientHtml.htmlCache[path] = html - - return html + return customHtml } static async getWatchHTMLPage (videoId: string, req: express.Request, res: express.Response) { @@ -55,7 +47,26 @@ export class ClientHtml { return ClientHtml.getIndexHTML(req, res) } - return ClientHtml.addOpenGraphAndOEmbedTags(html, video) + let customHtml = ClientHtml.addTitleTag(html, escapeHTML(video.name)) + customHtml = ClientHtml.addDescriptionTag(customHtml, escapeHTML(video.description)) + customHtml = ClientHtml.addOpenGraphAndOEmbedTags(customHtml, video) + + return customHtml + } + + private static async getIndexHTML (req: express.Request, res: express.Response, paramLang?: string) { + const path = ClientHtml.getIndexPath(req, res, paramLang) + if (ClientHtml.htmlCache[path]) return ClientHtml.htmlCache[path] + + const buffer = await readFile(path) + + let html = buffer.toString() + + html = ClientHtml.addCustomCSS(html) + + ClientHtml.htmlCache[path] = html + + return html } private static getIndexPath (req: express.Request, res: express.Response, paramLang?: string) { @@ -81,14 +92,18 @@ export class ClientHtml { return join(__dirname, '../../../client/dist/' + buildFileLocale(lang) + '/index.html') } - private static addTitleTag (htmlStringPage: string) { - const titleTag = '' + CONFIG.INSTANCE.NAME + '' + private static addTitleTag (htmlStringPage: string, title?: string) { + let text = title || CONFIG.INSTANCE.NAME + if (title) text += ` - ${CONFIG.INSTANCE.NAME}` + + const titleTag = `${text}` return htmlStringPage.replace(CUSTOM_HTML_TAG_COMMENTS.TITLE, titleTag) } - private static addDescriptionTag (htmlStringPage: string) { - const descriptionTag = `` + private static addDescriptionTag (htmlStringPage: string, description?: string) { + const content = description || CONFIG.INSTANCE.SHORT_DESCRIPTION + const descriptionTag = `` return htmlStringPage.replace(CUSTOM_HTML_TAG_COMMENTS.DESCRIPTION, descriptionTag) }