trying to improve again dynamic import

This commit is contained in:
Emilien 2024-12-12 23:28:49 +01:00
parent 57f4da848b
commit f3fff5cc09
5 changed files with 103 additions and 77 deletions

1
compile.env Normal file
View file

@ -0,0 +1 @@
DENO_COMPILED=true

View file

@ -4,8 +4,14 @@ import { compress, decompress } from "https://deno.land/x/brotli@0.1.7/mod.ts";
import { Store } from "@willsoto/node-konfig-core"; import { Store } from "@willsoto/node-konfig-core";
let youtubePlayerReqLocation = "youtubePlayerReq"; let youtubePlayerReqLocation = "youtubePlayerReq";
if (Deno.env.get("YT_PLAYER_REQ_LOCATION")) { if (Deno.env.get("YT_PLAYER_REQ_LOCATION")) {
youtubePlayerReqLocation = import.meta.dirname + "/" + if (Deno.env.has("DENO_COMPILED")) {
youtubePlayerReqLocation = Deno.mainModule.replace("main.ts", "") +
Deno.env.get("YT_PLAYER_REQ_LOCATION"); Deno.env.get("YT_PLAYER_REQ_LOCATION");
} else {
youtubePlayerReqLocation = Deno.env.get(
"YT_PLAYER_REQ_LOCATION",
) as string;
}
} }
const { youtubePlayerReq } = await import(youtubePlayerReqLocation); const { youtubePlayerReq } = await import(youtubePlayerReqLocation);

View file

@ -5,8 +5,14 @@ import { Innertube, UniversalCache } from "youtubei.js";
import { Store } from "@willsoto/node-konfig-core"; import { Store } from "@willsoto/node-konfig-core";
let getFetchClientLocation = "getFetchClient"; let getFetchClientLocation = "getFetchClient";
if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) { if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) {
getFetchClientLocation = import.meta.dirname + "/" + if (Deno.env.has("DENO_COMPILED")) {
getFetchClientLocation = Deno.mainModule.replace("main.ts", "") +
Deno.env.get("GET_FETCH_CLIENT_LOCATION"); Deno.env.get("GET_FETCH_CLIENT_LOCATION");
} else {
getFetchClientLocation = Deno.env.get(
"GET_FETCH_CLIENT_LOCATION",
) as string;
}
} }
const { getFetchClient } = await import(getFetchClientLocation); const { getFetchClient } = await import(getFetchClientLocation);
@ -14,7 +20,7 @@ const { getFetchClient } = await import(getFetchClientLocation);
export const poTokenGenerate = async ( export const poTokenGenerate = async (
innertubeClient: Innertube, innertubeClient: Innertube,
konfigStore: Store<Record<string, unknown>>, konfigStore: Store<Record<string, unknown>>,
innertubeClientCache: UniversalCache innertubeClientCache: UniversalCache,
): Promise<Innertube> => { ): Promise<Innertube> => {
const requestKey = "O43z0dpjhgX20SCx4KAo"; const requestKey = "O43z0dpjhgX20SCx4KAo";
@ -62,7 +68,7 @@ export const poTokenGenerate = async (
bgConfig, bgConfig,
}); });
await BG.PoToken.generatePlaceholder(visitorData);; await BG.PoToken.generatePlaceholder(visitorData);
return (await Innertube.create({ return (await Innertube.create({
po_token: poTokenResult.poToken, po_token: poTokenResult.poToken,

View file

@ -5,8 +5,14 @@ import { poTokenGenerate } from "./lib/jobs/potoken.ts";
import { konfigLoader } from "./lib/helpers/konfigLoader.ts"; import { konfigLoader } from "./lib/helpers/konfigLoader.ts";
let getFetchClientLocation = "getFetchClient"; let getFetchClientLocation = "getFetchClient";
if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) { if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) {
getFetchClientLocation = import.meta.dirname + "/" + if (Deno.env.has("DENO_COMPILED")) {
getFetchClientLocation = Deno.mainModule.replace("main.ts", "") +
Deno.env.get("GET_FETCH_CLIENT_LOCATION"); Deno.env.get("GET_FETCH_CLIENT_LOCATION");
} else {
getFetchClientLocation = Deno.env.get(
"GET_FETCH_CLIENT_LOCATION",
) as string;
}
} }
const { getFetchClient } = await import(getFetchClientLocation); const { getFetchClient } = await import(getFetchClientLocation);
@ -26,10 +32,10 @@ const innertubeClientCookies = konfigStore.get(
) as string; ) as string;
let innertubeClientCache = new UniversalCache( let innertubeClientCache = new UniversalCache(
true, true,
konfigStore.get('cache.directory') as string + "/youtubei.js/", konfigStore.get("cache.directory") as string + "/youtubei.js/",
) as UniversalCache; ) as UniversalCache;
Deno.env.set('TMPDIR', konfigStore.get("cache.directory") as string) Deno.env.set("TMPDIR", konfigStore.get("cache.directory") as string);
if (!innertubeClientOauthEnabled) { if (!innertubeClientOauthEnabled) {
if (innertubeClientJobPoTokenEnabled) { if (innertubeClientJobPoTokenEnabled) {
@ -110,6 +116,7 @@ app.use("*", async (c, next) => {
routes(app, konfigStore); routes(app, konfigStore);
Deno.serve({ Deno.serve({
port: Number(Deno.env.get("PORT")) || konfigStore.get("server.port") as number, port: Number(Deno.env.get("PORT")) ||
konfigStore.get("server.port") as number,
hostname: Deno.env.get("HOST") || konfigStore.get("server.host") as string, hostname: Deno.env.get("HOST") || konfigStore.get("server.host") as string,
}, app.fetch); }, app.fetch);

View file

@ -3,8 +3,14 @@ import { Store } from "@willsoto/node-konfig-core";
import { HTTPException } from "hono/http-exception"; import { HTTPException } from "hono/http-exception";
let getFetchClientLocation = "getFetchClient"; let getFetchClientLocation = "getFetchClient";
if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) { if (Deno.env.get("GET_FETCH_CLIENT_LOCATION")) {
getFetchClientLocation = import.meta.dirname + "/" + if (Deno.env.has("DENO_COMPILED")) {
getFetchClientLocation = Deno.mainModule.replace("main.ts", "") +
Deno.env.get("GET_FETCH_CLIENT_LOCATION"); Deno.env.get("GET_FETCH_CLIENT_LOCATION");
} else {
getFetchClientLocation = Deno.env.get(
"GET_FETCH_CLIENT_LOCATION",
) as string;
}
} }
const { getFetchClient } = await import(getFetchClientLocation); const { getFetchClient } = await import(getFetchClientLocation);