cobalt/src/modules/processing/match.js

130 lines
4.8 KiB
JavaScript
Raw Normal View History

2022-10-09 18:44:00 +01:00
import { apiJSON } from "../sub/utils.js";
import { errorUnsupported, genericError } from "../sub/errors.js";
2022-07-08 19:17:56 +01:00
2022-12-06 19:21:07 +00:00
import loc from "../../localization/manager.js";
import { testers } from "./servicesPatternTesters.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";
import tiktok from "./services/tiktok.js";
import tumblr from "./services/tumblr.js";
2022-10-09 18:44:00 +01:00
import matchActionDecider from "./matchActionDecider.js";
import vimeo from "./services/vimeo.js";
import soundcloud from "./services/soundcloud.js";
2022-07-08 19:17:56 +01:00
export default async function (host, patternMatch, url, lang, obj) {
2022-07-08 19:17:56 +01:00
try {
let r, isAudioOnly = !!obj.isAudioOnly;
if (!testers[host]) return apiJSON(0, { t: errorUnsupported(lang) });
if (!(testers[host](patternMatch))) return apiJSON(0, { t: brokenLink(lang) });
2022-07-08 19:17:56 +01:00
switch (host) {
case "twitter":
r = await twitter({
id: patternMatch["id"] ? patternMatch["id"] : false,
spaceId: patternMatch["spaceId"] ? patternMatch["spaceId"] : false,
lang: lang
});
break;
2022-07-08 19:17:56 +01:00
case "vk":
r = await vk({
2022-09-11 16:04:06 +01:00
url: url,
userId: patternMatch["userId"],
videoId: patternMatch["videoId"],
lang: lang,
quality: obj.vQuality
});
break;
2022-07-08 19:17:56 +01:00
case "bilibili":
r = await bilibili({
id: patternMatch["id"].slice(0, 12),
lang: lang
});
break;
2022-07-08 19:17:56 +01:00
case "youtube":
let fetchInfo = {
2022-08-16 08:14:19 +01:00
id: patternMatch["id"].slice(0, 11),
lang: lang,
quality: obj.vQuality,
format: "webm"
};
if (url.match('music.youtube.com') || isAudioOnly === true) obj.vFormat = "audio";
switch (obj.vFormat) {
case "mp4":
fetchInfo["format"] = "mp4";
break;
case "audio":
fetchInfo["format"] = "webm";
fetchInfo["isAudioOnly"] = true;
fetchInfo["quality"] = "max";
isAudioOnly = true;
break;
}
r = await youtube(fetchInfo);
break;
2022-07-08 19:17:56 +01:00
case "reddit":
r = await reddit({
sub: patternMatch["sub"],
id: patternMatch["id"],
title: patternMatch["title"],
lang: lang,
});
break;
2022-09-03 16:32:39 +01:00
case "douyin":
case "tiktok":
r = await tiktok({
2022-09-03 16:32:39 +01:00
host: host,
postId: patternMatch["postId"],
id: patternMatch["id"],
lang: lang,
noWatermark: obj.isNoTTWatermark,
fullAudio: obj.isTTFullAudio,
isAudioOnly: isAudioOnly
});
break;
case "tumblr":
r = await tumblr({
id: patternMatch["id"],
url: url,
user: patternMatch["user"] ? patternMatch["user"] : false,
lang: lang
});
break;
case "vimeo":
r = await vimeo({
id: patternMatch["id"].slice(0, 11),
quality: obj.vQuality,
lang: lang
});
break;
case "soundcloud":
isAudioOnly = true;
r = await soundcloud({
author: patternMatch["author"],
song: patternMatch["song"], url: url,
shortLink: patternMatch["shortLink"] ? patternMatch["shortLink"] : false,
accessKey: patternMatch["accessKey"] ? patternMatch["accessKey"] : false,
format: obj.aFormat,
lang: lang
});
break;
2022-07-08 19:17:56 +01:00
default:
return apiJSON(0, { t: errorUnsupported(lang) });
2022-07-08 19:17:56 +01:00
}
if (r.isAudioOnly) isAudioOnly = true;
let isAudioMuted = isAudioOnly ? false : obj.isAudioMuted;
if (r.error) return apiJSON(0, { t: Array.isArray(r.error) ? loc(lang, r.error[0], r.error[1]) : loc(lang, r.error) });
return matchActionDecider(r, host, obj.ip, obj.aFormat, isAudioOnly, lang, isAudioMuted);
2022-07-08 19:17:56 +01:00
} catch (e) {
return apiJSON(0, { t: genericError(lang, host) })
}
}