diff --git a/src/app.ts b/src/app.ts new file mode 100644 index 0000000..bae4bc6 --- /dev/null +++ b/src/app.ts @@ -0,0 +1,94 @@ +import Fastify from "fastify"; +import showbox from "./routes/showbox"; +import flixhq from "./routes/flixhq"; +import zoe from "./routes/zoe"; +import remotestream from "./routes/remotestream"; +import smashystream from "./routes/smashystream"; +import gomovies from "./routes/gomovies"; +import ridomovies from "./routes/ridomovies"; +import vidsrc from "./routes/vidsrc"; +import vidsrcto from "./routes/vidsrcto"; +import kissasian from "./routes/kissasian"; +import goojara from "./routes/goojara"; +import daddylive from "./routes/daddylive"; +import nepu from "./routes/nepu"; +import chalk from "chalk"; +import FastifyCors from "@fastify/cors"; +import dotenv from "dotenv"; +import Redis from "ioredis"; +dotenv.config(); + +export const workers_url = process.env.WORKERS_URL && process.env.WORKERS_URL; +export const tmdbKey = process.env.TMDB_KEY && process.env.TMDB_KEY; + +export const redis = + process.env.REDIS_HOST && + new Redis({ + host: process.env.REDIS_HOST, + port: Number(process.env.REDIS_PORT), + password: process.env.REDIS_PASSWORD, + }); + + + +async function startServer() { + const PORT = Number(process.env.PORT) || 3000; + console.log(chalk.green(`Starting server on port ${PORT}... 🚀`)); + if (!process.env.WORKERS_URL) + console.warn( + chalk.yellowBright( + "Workers (proxy) url not found use `proxied=false` argument in link fetching", + ), + ); + + if (!process.env.TMDB_KEY) + console.warn(chalk.yellowBright("TMDB key not found")); + + if (!process.env.REDIS_HOST) + console.warn(chalk.yellowBright("Redis not found. Cache disabled.")); + + const fastify = Fastify({ + maxParamLength: 1000, + logger: true, + }); + await fastify.register(FastifyCors, { + origin: "*", + methods: "GET", + }); + + await fastify.register(showbox, { prefix: "/superstream" }); + await fastify.register(showbox, { prefix: "/showbox" }); + await fastify.register(flixhq, { prefix: "/flixhq" }); + await fastify.register(zoe, { prefix: "/zoe" }); + await fastify.register(remotestream, { prefix: "/remotestream" }); + await fastify.register(smashystream, { prefix: "/smashystream" }); + await fastify.register(gomovies, { prefix: "/gomovies" }); + await fastify.register(ridomovies, { prefix: "/ridomovies" }); + await fastify.register(vidsrc, { prefix: "/vidsrc" }); + await fastify.register(vidsrcto, { prefix: "/vidsrcto" }); + await fastify.register(kissasian, { prefix: "/kissasian" }); + await fastify.register(goojara, { prefix: "/goojara" }); + await fastify.register(nepu, { prefix: "/nepu" }); + await fastify.register(daddylive, {prefix: "/daddylive"}); + + try { + fastify.get("/", async (_, rp) => { + rp.status(200).send("Welcome to FlixQuest API! 🎉"); + }); + fastify.get("*", (request, reply) => { + reply.status(404).send({ + message: "", + error: "page not found", + }); + }); + + fastify.listen({ port: PORT, host: "0.0.0.0" }, (e, address) => { + if (e) throw e; + console.log(`server listening on ${address}`); + }); + } catch (err: any) { + fastify.log.error(err); + process.exit(1); + } +} +export default startServer; \ No newline at end of file diff --git a/src/index.ts b/src/index.ts index c76077f..09fc988 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,97 +1,4 @@ -import Fastify from "fastify"; -import showbox from "./routes/showbox"; -import flixhq from "./routes/flixhq"; -import zoe from "./routes/zoe"; -import remotestream from "./routes/remotestream"; -import smashystream from "./routes/smashystream"; -import gomovies from "./routes/gomovies"; -import ridomovies from "./routes/ridomovies"; -import vidsrc from "./routes/vidsrc"; -import vidsrcto from "./routes/vidsrcto"; -import kissasian from "./routes/kissasian"; -import goojara from "./routes/goojara"; -import daddylive from "./routes/daddylive"; -import nepu from "./routes/nepu"; -import chalk from "chalk"; -import FastifyCors from "@fastify/cors"; -import dotenv from "dotenv"; -import Redis from "ioredis"; -dotenv.config(); - -export const workers_url = process.env.WORKERS_URL && process.env.WORKERS_URL; -export const tmdbKey = process.env.TMDB_KEY && process.env.TMDB_KEY; - -export const redis = - process.env.REDIS_HOST && - new Redis({ - host: process.env.REDIS_HOST, - port: Number(process.env.REDIS_PORT), - password: process.env.REDIS_PASSWORD, - }); - - - -async function startServer() { - const PORT = Number(process.env.PORT) || 3000; - console.log(chalk.green(`Starting server on port ${PORT}... 🚀`)); - if (!process.env.WORKERS_URL) - console.warn( - chalk.yellowBright( - "Workers (proxy) url not found use `proxied=false` argument in link fetching", - ), - ); - - if (!process.env.TMDB_KEY) - console.warn(chalk.yellowBright("TMDB key not found")); - - if (!process.env.REDIS_HOST) - console.warn(chalk.yellowBright("Redis not found. Cache disabled.")); - - const fastify = Fastify({ - maxParamLength: 1000, - logger: true, - }); - await fastify.register(FastifyCors, { - origin: "*", - methods: "GET", - }); - - await fastify.register(showbox, { prefix: "/superstream" }); - await fastify.register(showbox, { prefix: "/showbox" }); - await fastify.register(flixhq, { prefix: "/flixhq" }); - await fastify.register(zoe, { prefix: "/zoe" }); - await fastify.register(remotestream, { prefix: "/remotestream" }); - await fastify.register(smashystream, { prefix: "/smashystream" }); - await fastify.register(gomovies, { prefix: "/gomovies" }); - await fastify.register(ridomovies, { prefix: "/ridomovies" }); - await fastify.register(vidsrc, { prefix: "/vidsrc" }); - await fastify.register(vidsrcto, { prefix: "/vidsrcto" }); - await fastify.register(kissasian, { prefix: "/kissasian" }); - await fastify.register(goojara, { prefix: "/goojara" }); - await fastify.register(nepu, { prefix: "/nepu" }); - await fastify.register(daddylive, {prefix: "/daddylive"}); - - try { - fastify.get("/", async (_, rp) => { - rp.status(200).send("Welcome to FlixQuest API! 🎉"); - }); - fastify.get("*", (request, reply) => { - reply.status(404).send({ - message: "", - error: "page not found", - }); - }); - - fastify.listen({ port: PORT, host: "0.0.0.0" }, (e, address) => { - if (e) throw e; - console.log(`server listening on ${address}`); - }); - } catch (err: any) { - fastify.log.error(err); - process.exit(1); - } -} -export default startServer; +import startServer from "./app"; startServer(); diff --git a/src/utils/functions.ts b/src/utils/functions.ts index 63c759e..14512d8 100644 --- a/src/utils/functions.ts +++ b/src/utils/functions.ts @@ -12,7 +12,7 @@ import dotenv from "dotenv"; import { tmdbBaseUrl, tmdbKey } from "../constants/api_constants"; import { ResolutionStream, SubData, supportedLanguages } from "./types"; import { FastifyReply } from "fastify"; -import { redis } from "../index"; +import { redis } from "../app"; import cache from "./cache"; dotenv.config(); const proxyUrl = process.env.WORKERS_URL;