0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Fixed YT live embeds for non-www URLs

ref https://github.com/TryGhost/Ghost/pull/20706
ref https://linear.app/tryghost/issue/ONC-197

- previous check for YT live match was a little too specific and required the www which should have been optional
This commit is contained in:
Kevin Ansfield 2024-08-01 17:13:31 +01:00
parent 1eab73c76d
commit ad1a00f60d
2 changed files with 27 additions and 1 deletions

View file

@ -378,7 +378,7 @@ class OEmbedService {
// We convert live URLs to watch URLs so we can go straight to the // We convert live URLs to watch URLs so we can go straight to the
// oembed request via a known provider rather than going through the page fetch routine. // oembed request via a known provider rather than going through the page fetch routine.
const ytLiveRegex = /^\/live\/([a-zA-Z0-9_-]+)$/; const ytLiveRegex = /^\/live\/([a-zA-Z0-9_-]+)$/;
if (urlObject.hostname === 'www.youtube.com' && ytLiveRegex.test(urlObject.pathname)) { if (urlObject.hostname.match(/(?:www\.)?youtube\.com/) && ytLiveRegex.test(urlObject.pathname)) {
const videoId = ytLiveRegex.exec(urlObject.pathname)[1]; const videoId = ytLiveRegex.exec(urlObject.pathname)[1];
urlObject.pathname = '/watch'; urlObject.pathname = '/watch';
urlObject.searchParams.set('v', videoId); urlObject.searchParams.set('v', videoId);

View file

@ -198,5 +198,31 @@ describe('oembed-service', function () {
await oembedService.fetchOembedDataFromUrl('https://www.youtube.com/live/1234?param=existing'); await oembedService.fetchOembedDataFromUrl('https://www.youtube.com/live/1234?param=existing');
}); });
it('converts YT live URLs to watch URLs (non-www)', async function () {
nock('https://www.youtube.com')
.get('/oembed')
.query((query) => {
// Ensure the URL is converted to a watch URL and retains existing query params.
const actual = query.url;
const expected = 'https://youtube.com/watch?param=existing&v=1234';
assert.equal(actual, expected, 'URL passed to oembed endpoint is incorrect');
return actual === expected;
})
.reply(200, {
type: 'rich',
version: '1.0',
title: 'Test Title',
author_name: 'Test Author',
author_url: 'https://example.com/user/testauthor',
html: '<iframe src="https://www.example.com/embed"></iframe>',
width: 640,
height: null
});
await oembedService.fetchOembedDataFromUrl('https://youtube.com/live/1234?param=existing');
});
}); });
}); });