X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fservices.ts;h=7c7ca1ff3668d8446a993f24dab35c041f289afa;hb=5f3505ba78bc05fc61aeca44d95f9a954934c0fc;hp=ec057235fbb3f6958694dc31330b10f23026e39f;hpb=d5c8932a601c1854db0a2e399ccaf26e17385f1a;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/controllers/services.ts b/server/controllers/services.ts
index ec057235f..7c7ca1ff3 100644
--- a/server/controllers/services.ts
+++ b/server/controllers/services.ts
@@ -1,7 +1,10 @@
-import * as express from 'express'
-import { EMBED_SIZE, PREVIEWS_SIZE, WEBSERVER } from '../initializers/constants'
+import express from 'express'
+import { MChannelSummary } from '@server/types/models'
+import { escapeHTML } from '@shared/core-utils/renderer'
+import { EMBED_SIZE, PREVIEWS_SIZE, THUMBNAILS_SIZE, WEBSERVER } from '../initializers/constants'
import { asyncMiddleware, oembedValidator } from '../middlewares'
import { accountNameWithHostGetValidator } from '../middlewares/validators'
+import { forceNumber } from '@shared/core-utils'
const servicesRouter = express.Router()
@@ -23,29 +26,115 @@ export {
// ---------------------------------------------------------------------------
function generateOEmbed (req: express.Request, res: express.Response) {
+ if (res.locals.videoAll) return generateVideoOEmbed(req, res)
+
+ return generatePlaylistOEmbed(req, res)
+}
+
+function generatePlaylistOEmbed (req: express.Request, res: express.Response) {
+ const playlist = res.locals.videoPlaylistSummary
+
+ const json = buildOEmbed({
+ channel: playlist.VideoChannel,
+ title: playlist.name,
+ embedPath: playlist.getEmbedStaticPath() + buildPlayerURLQuery(req.query.url),
+ previewPath: playlist.getThumbnailStaticPath(),
+ previewSize: THUMBNAILS_SIZE,
+ req
+ })
+
+ return res.json(json)
+}
+
+function generateVideoOEmbed (req: express.Request, res: express.Response) {
const video = res.locals.videoAll
+
+ const json = buildOEmbed({
+ channel: video.VideoChannel,
+ title: video.name,
+ embedPath: video.getEmbedStaticPath() + buildPlayerURLQuery(req.query.url),
+ previewPath: video.getPreviewStaticPath(),
+ previewSize: PREVIEWS_SIZE,
+ req
+ })
+
+ return res.json(json)
+}
+
+function buildPlayerURLQuery (inputQueryUrl: string) {
+ const allowedParameters = new Set([
+ 'start',
+ 'stop',
+ 'loop',
+ 'autoplay',
+ 'muted',
+ 'controls',
+ 'controlBar',
+ 'title',
+ 'api',
+ 'warningTitle',
+ 'peertubeLink',
+ 'p2p',
+ 'subtitle',
+ 'bigPlayBackgroundColor',
+ 'mode',
+ 'foregroundColor'
+ ])
+
+ const params = new URLSearchParams()
+
+ new URL(inputQueryUrl).searchParams.forEach((v, k) => {
+ if (allowedParameters.has(k)) {
+ params.append(k, v)
+ }
+ })
+
+ const stringQuery = params.toString()
+ if (!stringQuery) return ''
+
+ return '?' + stringQuery
+}
+
+function buildOEmbed (options: {
+ req: express.Request
+ title: string
+ channel: MChannelSummary
+ previewPath: string | null
+ embedPath: string
+ previewSize: {
+ height: number
+ width: number
+ }
+}) {
+ const { req, previewSize, previewPath, title, channel, embedPath } = options
+
const webserverUrl = WEBSERVER.URL
- const maxHeight = parseInt(req.query.maxheight, 10)
- const maxWidth = parseInt(req.query.maxwidth, 10)
+ const maxHeight = forceNumber(req.query.maxheight)
+ const maxWidth = forceNumber(req.query.maxwidth)
+
+ const embedUrl = webserverUrl + embedPath
+ const embedTitle = escapeHTML(title)
+
+ let thumbnailUrl = previewPath
+ ? webserverUrl + previewPath
+ : undefined
- const embedUrl = webserverUrl + video.getEmbedStaticPath()
- let thumbnailUrl = webserverUrl + video.getPreviewStaticPath()
let embedWidth = EMBED_SIZE.width
- let embedHeight = EMBED_SIZE.height
+ if (maxWidth < embedWidth) embedWidth = maxWidth
+ let embedHeight = EMBED_SIZE.height
if (maxHeight < embedHeight) embedHeight = maxHeight
- if (maxWidth < embedWidth) embedWidth = maxWidth
// Our thumbnail is too big for the consumer
if (
- (maxHeight !== undefined && maxHeight < PREVIEWS_SIZE.height) ||
- (maxWidth !== undefined && maxWidth < PREVIEWS_SIZE.width)
+ (maxHeight !== undefined && maxHeight < previewSize.height) ||
+ (maxWidth !== undefined && maxWidth < previewSize.width)
) {
thumbnailUrl = undefined
}
- const html = ``
+ const html = ``
const json: any = {
type: 'video',
@@ -53,20 +142,20 @@ function generateOEmbed (req: express.Request, res: express.Response) {
html,
width: embedWidth,
height: embedHeight,
- title: video.name,
- author_name: video.VideoChannel.Account.name,
- author_url: video.VideoChannel.Account.Actor.url,
+ title,
+ author_name: channel.name,
+ author_url: channel.Actor.url,
provider_name: 'PeerTube',
provider_url: webserverUrl
}
if (thumbnailUrl !== undefined) {
json.thumbnail_url = thumbnailUrl
- json.thumbnail_width = PREVIEWS_SIZE.width
- json.thumbnail_height = PREVIEWS_SIZE.height
+ json.thumbnail_width = previewSize.width
+ json.thumbnail_height = previewSize.height
}
- return res.json(json)
+ return json
}
function redirectToAccountUrl (req: express.Request, res: express.Response, next: express.NextFunction) {