coub: add support

This commit is contained in:
ihatespawn 2024-07-10 22:03:38 +00:00
parent c1f364929c
commit c753d9469c
6 changed files with 85 additions and 0 deletions

View File

@ -25,6 +25,7 @@ import twitch from "./services/twitch.js";
import rutube from "./services/rutube.js";
import dailymotion from "./services/dailymotion.js";
import loom from "./services/loom.js";
import coub from "./services/coub.js";
let freebind;
@ -193,6 +194,11 @@ export default async function(host, patternMatch, lang, obj) {
id: patternMatch.id
});
break;
case "coub":
r = await coub({
id: patternMatch.id
});
break;
default:
return createResponse("error", {
t: loc(lang, 'ErrorUnsupported')

View File

@ -109,6 +109,7 @@ export default function(r, host, userFormat, isAudioOnly, lang, isAudioMuted, di
responseType = r.typeId;
params = { type: r.type };
break;
case "coub":
case "vimeo":
if (Array.isArray(r.urls)) {
params = { type: "render" }

View File

@ -0,0 +1,31 @@
async function a(id) {
const req = await fetch(`https://coub.com/view/${id}/`, {
method: "GET",
headers: {
"user-agent": "firefox",
}
})
.then(request => request.text())
.catch(() => {return {error:'ClickToCopy'}});
if (!req) return { error: 'ErrorEmptyDownload' };
const infoScript = req?.split('{"flag":')[1]
const downloadLinks = infoScript?.split('"html5":')[1].split(',"mobile"')[0];
const videoUrl = downloadLinks?.split('"https://')[1].split('"')[0];
const audioUrl = downloadLinks?.split('"https://')[3].split('"')[0];
if (videoUrl?.includes('.mp4') && audioUrl?.includes('.mp3')) {
return {
urls: [
'https://' + videoUrl,
'https://' + audioUrl
],
filename: `coub_${id}.mp4`,
audioFilename: `coub_${id}_audio`
}
}
return { error: 'ErrorEmptyDownload' }
}
a("dhxy").then(console.log)

View File

@ -0,0 +1,39 @@
import { genericUserAgent } from "../../config.js";
export default async function({ id }) {
const req = await fetch(`https://coub.com/view/${id}/`, {
method: "GET",
headers: {
"user-agent": genericUserAgent,
}
})
.then(request => request.text())
.catch(() => {});
if (!req) return { error: 'ErrorEmptyDownload' };
const infoScript = req?.split("<script id='coubPageCoubJson' type='text/json'>")[1].split('</script>')[0].replace('\n','');
const infoJSON = JSON.parse(infoScript);
const downloadLinks = infoJSON?.file_versions.html5;
const videoUrl = downloadLinks?.video.high.url;
const audioUrl = downloadLinks?.audio.high.url;
if (videoUrl?.includes('.mp4') && audioUrl?.includes('.mp3')) {
return {
urls: [
videoUrl,
audioUrl
],
filename: `coub_${id}.mp4`,
audioFilename: `coub_${id}_audio`,
filenameAttributes: {
service: 'coub',
id: id,
title: infoJSON?.title,
author: infoJSON?.channel.title,
extension: 'mp4'
},
}
}
return { error: 'ErrorEmptyDownload' }
}

View File

@ -118,6 +118,11 @@
"alias": "loom videos",
"patterns": ["share/:id"],
"enabled": true
},
"coub": {
"alias": "coub videos",
"patterns": ["view/:id", "embed/:id"],
"enabled": true
}
}
}

View File

@ -1,4 +1,7 @@
export const testers = {
"coub": (patternMatch) =>
patternMatch.id?.length <= 6,
"bilibili": (patternMatch) =>
patternMatch.comId?.length <= 12 || patternMatch.comShortLink?.length <= 16
|| patternMatch.tvId?.length <= 24,