const distPath = join(root(), 'client', 'dist')
const assetsImagesPath = join(root(), 'client', 'dist', 'client', 'assets', 'images')
+const manifestPath = join(root(), 'client', 'dist', 'manifest.json')
const embedPath = join(distPath, 'standalone', 'videos', 'embed.html')
const indexPath = join(distPath, 'index.html')
})
// Static HTML/CSS/JS client files
+clientsRouter.use('/manifest.json', express.static(manifestPath, { maxAge: STATIC_MAX_AGE }))
clientsRouter.use('/client', express.static(distPath, { maxAge: STATIC_MAX_AGE }))
clientsRouter.use('/client/assets/images', express.static(assetsImagesPath, { maxAge: STATIC_MAX_AGE }))
]
const schemaTags = {
+ '@context': 'http://schema.org',
+ '@type': 'VideoObject',
name: videoNameEscaped,
description: videoDescriptionEscaped,
duration: video.getActivityStreamDuration(),
}
let tagsString = ''
+
+ // Opengraph
Object.keys(openGraphMetaTags).forEach(tagName => {
const tagValue = openGraphMetaTags[tagName]
tagsString += `<meta property="${tagName}" content="${tagValue}" />`
})
+ // OEmbed
for (const oembedLinkTag of oembedLinkTags) {
tagsString += `<link rel="alternate" type="${oembedLinkTag.type}" href="${oembedLinkTag.href}" title="${oembedLinkTag.title}" />`
}
- tagsString += '<div itemprop="video" itemscope itemtype="http://schema.org/VideoObject">'
- tagsString += '<h2>Video: <span itemprop="name">' + schemaTags.name + '</span></h2>'
-
- Object.keys(schemaTags).forEach(tagName => {
- const tagValue = schemaTags[tagName]
- tagsString += `<meta itemprop="${tagName}" content="${tagValue}" />`
- })
-
- tagsString += '</div>'
+ // Schema.org
+ tagsString += `<script type="application/ld+json">${JSON.stringify(schemaTags)}</script>`
return htmlStringPage.replace(OPENGRAPH_AND_OEMBED_COMMENT, tagsString)
}