1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103 | import { FastifyRequest, FastifyReply, FastifyInstance, RegisterOptions } from 'fastify';
import { MOVIES } from '@consumet/extensions';
import { StreamingServers } from '@consumet/extensions/dist/models';
import cache from '../../utils/cache';
import { redis } from '../../main';
import { Redis } from 'ioredis';
const routes = async (fastify: FastifyInstance, options: RegisterOptions) => {
const fmovies = new MOVIES.Fmovies(
process.env.NINE_ANIME_HELPER_URL,
{
url: process.env.NINE_ANIME_PROXY as string,
},
process.env?.NINE_ANIME_HELPER_KEY,
);
fastify.get('/', (_, rp) => {
rp.status(200).send({
intro:
"Welcome to the fmovies provider: check out the provider's website @ https://fmovies.to/",
routes: ['/:query', '/info', '/watch'],
documentation: 'https://docs.consumet.org/#tag/fmovies',
});
});
fastify.get('/:query', async (request: FastifyRequest, reply: FastifyReply) => {
const query = decodeURIComponent((request.params as { query: string }).query);
const page = (request.query as { page: number }).page;
let res = redis
? await cache.fetch(
redis as Redis,
`fmovies:${query}:${page}`,
async () => await fmovies.search(query, page ? page : 1),
60 * 60 * 6,
)
: await fmovies.search(query, page ? page : 1);
reply.status(200).send(res);
});
fastify.get('/info', async (request: FastifyRequest, reply: FastifyReply) => {
const id = (request.query as { id: string }).id;
if (typeof id === 'undefined')
return reply.status(400).send({
message: 'id is required',
});
try {
let res = redis
? await cache.fetch(
redis as Redis,
`fmovies:info:${id}`,
async () => await fmovies.fetchMediaInfo(id),
60 * 60 * 3,
)
: await fmovies.fetchMediaInfo(id);
reply.status(200).send(res);
} catch (err) {
reply.status(500).send({
message:
'Something went wrong. Please try again later. or contact the developers.',
});
}
});
fastify.get('/watch', async (request: FastifyRequest, reply: FastifyReply) => {
const episodeId = (request.query as { episodeId: string }).episodeId;
const mediaId = (request.query as { mediaId: string }).mediaId;
const server = (request.query as { server: StreamingServers }).server;
if (typeof episodeId === 'undefined')
return reply.status(400).send({ message: 'episodeId is required' });
if (typeof mediaId === 'undefined')
return reply.status(400).send({ message: 'mediaId is required' });
if (server && !Object.values(StreamingServers).includes(server))
return reply.status(400).send({ message: 'Invalid server query' });
try {
let res = redis
? await cache.fetch(
redis as Redis,
`fmovies:watch:${episodeId}:${mediaId}:${server}`,
async () => await fmovies.fetchEpisodeSources(episodeId, mediaId, server),
60 * 30,
)
: await fmovies.fetchEpisodeSources(episodeId, mediaId, server);
reply.status(200).send(res);
} catch (err) {
reply
.status(500)
.send({ message: 'Something went wrong. Please try again later.' });
}
});
};
export default routes;
|