fixing type errors

This commit is contained in:
Emilien 2024-11-18 00:33:47 +01:00
parent 7ed48ad2af
commit f36079d56c

View file

@ -1,7 +1,9 @@
import { Innertube, YT, ApiResponse } from "youtubei.js"; import { ApiResponse, Innertube, YT } from "youtubei.js";
import { generateRandomString } from "youtubei.js/Utils"; import { generateRandomString } from "youtubei.js/Utils";
import { compress, decompress } from "https://deno.land/x/brotli@0.1.7/mod.ts"; import { compress, decompress } from "https://deno.land/x/brotli@0.1.7/mod.ts";
const { youtubePlayerReq } = await import(Deno.env.get("YT_PLAYER_REQ_LOCATION") || "./youtubePlayerReq.ts"); const { youtubePlayerReq } = await import(
Deno.env.get("YT_PLAYER_REQ_LOCATION") || "./youtubePlayerReq.ts"
);
import { Store } from "@willsoto/node-konfig-core"; import { Store } from "@willsoto/node-konfig-core";
const kv = await Deno.openKv(); const kv = await Deno.openKv();
@ -22,7 +24,7 @@ export const youtubePlayerParsing = async (
const youtubePlayerResponse = await youtubePlayerReq( const youtubePlayerResponse = await youtubePlayerReq(
innertubeClient, innertubeClient,
videoId, videoId,
konfigStore konfigStore,
); );
const videoData = youtubePlayerResponse.data; const videoData = youtubePlayerResponse.data;
@ -36,16 +38,26 @@ export const youtubePlayerParsing = async (
// Modify the original YouTube response to include deciphered URLs // Modify the original YouTube response to include deciphered URLs
if (streamingData && videoData && videoData.streamingData) { if (streamingData && videoData && videoData.streamingData) {
const ecatcherServiceTracking = videoData.responseContext?.serviceTrackingParams.find(o => o.service === 'ECATCHER'); const ecatcherServiceTracking = videoData.responseContext
const clientNameUsed = ecatcherServiceTracking?.params?.find(o => o.key === 'client.name'); ?.serviceTrackingParams.find((o: { service: string }) =>
o.service === "ECATCHER"
);
const clientNameUsed = ecatcherServiceTracking?.params?.find((
o: { key: string },
) => o.key === "client.name");
// no need to decipher on IOS nor ANDROID // no need to decipher on IOS nor ANDROID
if (!clientNameUsed?.value.includes("IOS") && !clientNameUsed?.value.includes("ANDROID")) { if (
!clientNameUsed?.value.includes("IOS") &&
!clientNameUsed?.value.includes("ANDROID")
) {
for (const [index, format] of streamingData.formats.entries()) { for (const [index, format] of streamingData.formats.entries()) {
videoData.streamingData.formats[index].url = format.decipher( videoData.streamingData.formats[index].url = format
.decipher(
innertubeClient.session.player, innertubeClient.session.player,
); );
if ( if (
videoData.streamingData.formats[index].signatureCipher !== videoData.streamingData.formats[index]
.signatureCipher !==
undefined undefined
) { ) {
delete videoData.streamingData.formats[index] delete videoData.streamingData.formats[index]
@ -53,7 +65,8 @@ export const youtubePlayerParsing = async (
} }
} }
for ( for (
const [index, adaptive_format] of streamingData.adaptive_formats const [index, adaptive_format] of streamingData
.adaptive_formats
.entries() .entries()
) { ) {
videoData.streamingData.adaptiveFormats[index].url = videoData.streamingData.adaptiveFormats[index].url =
@ -90,11 +103,14 @@ export const youtubePlayerParsing = async (
videoDetails, videoDetails,
microformat, microformat,
invidiousCompanion: { invidiousCompanion: {
"baseUrl": Deno.env.get("SERVER_BASE_URL") || konfigStore.get("server.base_url") as string, "baseUrl": Deno.env.get("SERVER_BASE_URL") ||
konfigStore.get("server.base_url") as string,
}, },
}))(videoData); }))(videoData);
if (cacheEnabled == true && videoData.playabilityStatus?.status == "OK") { if (
cacheEnabled == true && videoData.playabilityStatus?.status == "OK"
) {
(async () => { (async () => {
await kv.set( await kv.set(
["video_cache", videoId], ["video_cache", videoId],
@ -116,7 +132,7 @@ export const youtubePlayerParsing = async (
export const youtubeVideoInfo = ( export const youtubeVideoInfo = (
innertubeClient: Innertube, innertubeClient: Innertube,
youtubePlayerResponseJson: object youtubePlayerResponseJson: object,
): YT.VideoInfo => { ): YT.VideoInfo => {
const playerResponse = { const playerResponse = {
success: true, success: true,
@ -128,4 +144,4 @@ export const youtubeVideoInfo = (
innertubeClient.actions, innertubeClient.actions,
"", "",
); );
} };