From 10717c69f63f8fed1c7312b04169f04ebec547f8 Mon Sep 17 00:00:00 2001 From: wukko Date: Sat, 31 Aug 2024 14:23:18 +0600 Subject: [PATCH] api/twitter: support proxying videos & images in a picker --- api/src/processing/match.js | 1 + api/src/processing/services/twitter.js | 26 +++++++++++++++++--------- 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/api/src/processing/match.js b/api/src/processing/match.js index 1266dcb5..9ebdfda9 100644 --- a/api/src/processing/match.js +++ b/api/src/processing/match.js @@ -69,6 +69,7 @@ export default async function(host, patternMatch, obj) { id: patternMatch.id, index: patternMatch.index - 1, toGif: !!obj.twitterGif, + alwaysProxy: obj.alwaysProxy, dispatcher }); break; diff --git a/api/src/processing/services/twitter.js b/api/src/processing/services/twitter.js index 7ed7fe4d..18866b49 100644 --- a/api/src/processing/services/twitter.js +++ b/api/src/processing/services/twitter.js @@ -101,7 +101,7 @@ const requestTweet = async(dispatcher, tweetId, token, cookie) => { return result } -export default async function({ id, index, toGif, dispatcher }) { +export default async function({ id, index, toGif, dispatcher, alwaysProxy }) { const cookie = await getCookie('twitter'); let guestToken = await getGuestToken(dispatcher); @@ -159,6 +159,12 @@ export default async function({ id, index, toGif, dispatcher }) { const getFileExt = (url) => new URL(url).pathname.split(".", 2)[1]; + const proxyMedia = (u, filename) => createStream({ + service: "twitter", + type: "proxy", + u, filename, + }) + switch (media?.length) { case undefined: case 0: @@ -184,25 +190,25 @@ export default async function({ id, index, toGif, dispatcher }) { } default: const proxyThumb = (url, i) => - createStream({ - service: "twitter", - type: "proxy", - u: url, - filename: `twitter_${id}_${i + 1}.${getFileExt(url)}` - }) + proxyMedia(url, `twitter_${id}_${i + 1}.${getFileExt(url)}`); const picker = media.map((content, i) => { if (content.type === "photo") { let url = `${content.media_url_https}?name=4096x4096`; + let proxiedImage = proxyThumb(url, i); + + if (alwaysProxy) url = proxiedImage; + return { type: "photo", url, - thumb: proxyThumb(url, i), + thumb: proxiedImage, } } let url = bestQuality(content.video_info.variants); const shouldRenderGif = content.type === "animated_gif" && toGif; + const videoFilename = `twitter_${id}_${i + 1}.mp4`; let type = "video"; if (shouldRenderGif) type = "gif"; @@ -212,8 +218,10 @@ export default async function({ id, index, toGif, dispatcher }) { service: "twitter", type: shouldRenderGif ? "gif" : "remux", u: url, - filename: `twitter_${id}_${i + 1}.mp4` + filename: videoFilename, }) + } else if (alwaysProxy) { + url = proxyMedia(url, videoFilename); } return {