cobalt/src/modules/processing/match.js

224 lines
7.3 KiB
JavaScript
Raw Normal View History

import { strict as assert } from "node:assert";
import { env } from '../config.js';
import { createResponse } from "../processing/request.js";
2022-12-06 20:21:07 +01:00
import loc from "../../localization/manager.js";
import { testers } from "./servicesPatternTesters.js";
2023-02-13 16:56:52 +01:00
import matchActionDecider from "./matchActionDecider.js";
import bilibili from "./services/bilibili.js";
import reddit from "./services/reddit.js";
import twitter from "./services/twitter.js";
import youtube from "./services/youtube.js";
import vk from "./services/vk.js";
2024-01-17 08:02:52 +01:00
import ok from "./services/ok.js";
import tiktok from "./services/tiktok.js";
import tumblr from "./services/tumblr.js";
import vimeo from "./services/vimeo.js";
import soundcloud from "./services/soundcloud.js";
2023-04-24 21:01:25 +02:00
import instagram from "./services/instagram.js";
import vine from "./services/vine.js";
2023-05-24 19:32:41 +02:00
import pinterest from "./services/pinterest.js";
2023-08-19 18:42:10 +02:00
import streamable from "./services/streamable.js";
2023-04-29 21:33:36 +02:00
import twitch from "./services/twitch.js";
import rutube from "./services/rutube.js";
import dailymotion from "./services/dailymotion.js";
2022-07-08 20:17:56 +02:00
let freebind;
2024-05-15 14:46:08 +02:00
export default async function(host, patternMatch, lang, obj) {
const { url } = obj;
assert(url instanceof URL);
let dispatcher, requestIP;
if (env.freebindCIDR) {
if (!freebind) {
freebind = await import('freebind');
}
requestIP = freebind.ip.random(env.freebindCIDR);
dispatcher = freebind.dispatcherFromIP(requestIP, { strict: false });
}
2022-07-08 20:17:56 +02:00
try {
let r,
isAudioOnly = !!obj.isAudioOnly,
disableMetadata = !!obj.disableMetadata;
if (!testers[host]) {
return createResponse("error", {
t: loc(lang, 'ErrorUnsupported')
});
}
if (!(testers[host](patternMatch))) {
return createResponse("error", {
t: loc(lang, 'ErrorBrokenLink', host)
});
}
2022-07-08 20:17:56 +02:00
switch (host) {
case "twitter":
r = await twitter({
id: patternMatch.id,
index: patternMatch.index - 1,
2024-05-23 05:22:33 +02:00
toGif: !!obj.twitterGif,
dispatcher
});
break;
2022-07-08 20:17:56 +02:00
case "vk":
r = await vk({
2024-01-17 08:02:52 +01:00
userId: patternMatch.userId,
videoId: patternMatch.videoId,
quality: obj.vQuality
});
break;
case "ok":
r = await ok({
id: patternMatch.id,
quality: obj.vQuality
});
break;
2022-07-08 20:17:56 +02:00
case "bilibili":
r = await bilibili(patternMatch);
break;
2022-07-08 20:17:56 +02:00
case "youtube":
let fetchInfo = {
2024-01-17 08:02:52 +01:00
id: patternMatch.id.slice(0, 11),
quality: obj.vQuality,
2023-02-26 17:49:25 +01:00
format: obj.vCodec,
isAudioOnly: isAudioOnly,
isAudioMuted: obj.isAudioMuted,
dubLang: obj.dubLang,
dispatcher
2023-02-26 17:49:25 +01:00
}
2023-12-14 23:43:57 +01:00
if (url.hostname === 'music.youtube.com' || isAudioOnly === true) {
2023-02-26 17:49:25 +01:00
fetchInfo.quality = "max";
fetchInfo.format = "vp9";
fetchInfo.isAudioOnly = true
}
2023-12-14 23:43:57 +01:00
r = await youtube(fetchInfo);
break;
2022-07-08 20:17:56 +02:00
case "reddit":
r = await reddit({
2024-01-17 08:02:52 +01:00
sub: patternMatch.sub,
id: patternMatch.id,
user: patternMatch.user
});
break;
case "tiktok":
r = await tiktok({
2024-01-17 08:02:52 +01:00
postId: patternMatch.postId,
id: patternMatch.id,
fullAudio: obj.isTTFullAudio,
isAudioOnly: isAudioOnly,
h265: obj.tiktokH265
});
break;
case "tumblr":
r = await tumblr({
2023-12-14 23:43:57 +01:00
id: patternMatch.id,
user: patternMatch.user,
url
});
break;
case "vimeo":
r = await vimeo({
2024-01-17 08:02:52 +01:00
id: patternMatch.id.slice(0, 11),
2024-03-05 00:26:14 +01:00
password: patternMatch.password,
quality: obj.vQuality,
isAudioOnly: isAudioOnly
});
break;
case "soundcloud":
isAudioOnly = true;
r = await soundcloud({
url,
2024-01-17 08:02:52 +01:00
author: patternMatch.author,
song: patternMatch.song,
format: obj.aFormat,
2024-01-17 08:02:52 +01:00
shortLink: patternMatch.shortLink || false,
accessKey: patternMatch.accessKey || false
});
break;
2023-04-24 21:01:25 +02:00
case "instagram":
r = await instagram({
...patternMatch,
quality: obj.vQuality,
dispatcher
})
break;
case "vine":
r = await vine({
2024-01-17 08:02:52 +01:00
id: patternMatch.id
});
2023-04-24 21:01:25 +02:00
break;
2023-05-24 19:32:41 +02:00
case "pinterest":
r = await pinterest({
id: patternMatch.id,
shortLink: patternMatch.shortLink || false
});
2023-05-24 19:32:41 +02:00
break;
2023-08-19 18:42:10 +02:00
case "streamable":
r = await streamable({
2024-01-17 08:02:52 +01:00
id: patternMatch.id,
2023-08-19 18:42:10 +02:00
quality: obj.vQuality,
isAudioOnly: isAudioOnly,
});
break;
2023-04-29 21:33:36 +02:00
case "twitch":
r = await twitch({
2024-01-17 08:02:52 +01:00
clipId: patternMatch.clip || false,
2023-09-16 12:27:53 +02:00
quality: obj.vQuality,
isAudioOnly: obj.isAudioOnly
2023-04-29 21:33:36 +02:00
});
2023-09-16 12:27:53 +02:00
break;
case "rutube":
r = await rutube({
2024-01-17 08:02:52 +01:00
id: patternMatch.id,
yappyId: patternMatch.yappyId,
key: patternMatch.key,
quality: obj.vQuality,
isAudioOnly: isAudioOnly
});
break;
case "dailymotion":
r = await dailymotion(patternMatch);
break;
2022-07-08 20:17:56 +02:00
default:
return createResponse("error", {
t: loc(lang, 'ErrorUnsupported')
});
2022-07-08 20:17:56 +02:00
}
if (r.isAudioOnly) isAudioOnly = true;
let isAudioMuted = isAudioOnly ? false : obj.isAudioMuted;
if (r.error && r.critical) {
return createResponse("critical", {
t: loc(lang, r.error)
})
}
if (r.error) {
return createResponse("error", {
t: Array.isArray(r.error)
? loc(lang, r.error[0], r.error[1])
: loc(lang, r.error)
})
}
return matchActionDecider(
r, host, obj.aFormat, isAudioOnly,
lang, isAudioMuted, disableMetadata,
obj.filenamePattern, obj.twitterGif,
requestIP
)
} catch {
return createResponse("error", {
t: loc(lang, 'ErrorBadFetch', host)
})
2022-07-08 20:17:56 +02:00
}
}