Update index.js
This commit is contained in:
160
api/v1/index.js
160
api/v1/index.js
@@ -1,95 +1,103 @@
|
|||||||
const express = require('express');
|
const axios = require('axios');
|
||||||
const { getEpisodeFromAnixart } = require('./src/episode');
|
|
||||||
const getVerifiedUsers = require('./src/is_verified');
|
|
||||||
const getRolesUsers = require('./src/is_roles');
|
|
||||||
const { getProfileFromAnixart } = require('./src/profile');
|
|
||||||
const getToggles = require('./src/toggles');
|
|
||||||
|
|
||||||
const app = express();
|
// Функция для запроса к Anixart API с поддержкой releaseId, typeId и sourceId
|
||||||
const PORT = 3000;
|
async function getEpisodeFromAnixart(releaseId, token = '', typeId = '', sourceId = '') {
|
||||||
|
let url = `https://api.anixart.tv/episode/${releaseId}`;
|
||||||
|
|
||||||
// Новый эндпоинты Открываем
|
// Если передан typeId, добавляем его в URL
|
||||||
|
if (typeId) {
|
||||||
// Эндпоинт для получения Verified
|
url += `/${typeId}`;
|
||||||
app.get('/api/is_roles', (req, res) => {
|
|
||||||
try {
|
|
||||||
const data = getRolesUsers();
|
|
||||||
res.status(200).json(data);
|
|
||||||
} catch {
|
|
||||||
res.status(200).json([]);
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
// Эндпоинт для получения Verified
|
// Если передан sourceId, добавляем его в URL
|
||||||
app.get('/api/is_verified', (req, res) => {
|
if (sourceId) {
|
||||||
try {
|
url += `/${sourceId}`;
|
||||||
const data = getVerifiedUsers();
|
}
|
||||||
res.status(200).json(data);
|
|
||||||
} catch {
|
// Если передан токен, добавляем его как query параметр
|
||||||
res.status(200).json([]);
|
if (token) {
|
||||||
|
url += `?token=${token}`;
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
// Эндпоинт для получения профиля
|
|
||||||
app.get('/api/profile/:profileId', async (req, res) => {
|
|
||||||
const { profileId } = req.params;
|
|
||||||
const { token } = req.query;
|
|
||||||
try {
|
try {
|
||||||
const data = await getProfileFromAnixart(profileId, token);
|
const response = await axios.get(url);
|
||||||
res.json(data);
|
const data = response.data;
|
||||||
|
|
||||||
|
// Проверяем структуру данных и, если что-то отсутствует, возвращаем кастомный ответ
|
||||||
|
if (data.code === 0 && !data.types) {
|
||||||
|
// Если нет данных о типах, обращаемся к Seele API
|
||||||
|
return await getEpisodeFromSeele(releaseId, token);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Если данные по типам или источникам есть, возвращаем их
|
||||||
|
return data;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
res.status(500).json({ error: error.message });
|
console.error("Ошибка при запросе к Anixart API:", error.message);
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// Эндпоинт для получения информации об эпизоде (Новый эндпоинт)
|
// Если ошибка 404, то пробуем получить данные с Seele API
|
||||||
app.get('/api/episode/:releaseId/:typeId?/:sourceId?', async (req, res) => {
|
if (error.response && error.response.status === 404) {
|
||||||
const { releaseId, typeId, sourceId } = req.params;
|
return await getEpisodeFromSeele(releaseId, token);
|
||||||
const { token } = req.query; // Извлекаем token из query-параметров
|
}
|
||||||
|
|
||||||
|
// В случае других ошибок
|
||||||
|
throw new Error("Ошибка при получении данных из Anixart API");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Функция для запроса к Seele API
|
||||||
|
async function getEpisodeFromSeele(releaseId, token = '') {
|
||||||
|
const url = `https://cloud.seele.su/episode/${releaseId}.json${token ? `?token=${token}` : ''}`;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const data = await getEpisodeFromAnixart(releaseId, token, typeId, sourceId);
|
const response = await axios.get(url);
|
||||||
res.json(data);
|
const data = response.data;
|
||||||
} catch (error) {
|
|
||||||
res.status(500).json({ error: error.message });
|
// Если нет данных по типам, возвращаем кастомный ответ
|
||||||
|
if (!data.types || data.types.length === 0) {
|
||||||
|
return getCustomNotFoundResponse();
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
// Эндпоинт для конфигурационного JSON из toggles.js
|
// Возвращаем данные
|
||||||
app.get('/api/config/toggles', async (req, res) => {
|
return data;
|
||||||
try {
|
|
||||||
const toggles = await getToggles();
|
|
||||||
res.json(toggles);
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
res.status(500).json({ error: error.message });
|
if (error.response && error.response.status === 404) {
|
||||||
|
return getCustomNotFoundResponse();
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
// Старый эндпоинты Открываем
|
console.error("Ошибка при запросе к Seele API:", error.message);
|
||||||
|
throw new Error("Ошибка при получении данных из Seele API");
|
||||||
// Эндпоинт для получения информации об эпизоде (Старый эндпоинт)
|
|
||||||
app.get('/api/extension/episode/:releaseId', async (req, res) => {
|
|
||||||
const { releaseId } = req.params;
|
|
||||||
try {
|
|
||||||
const data = await getOldEpisodeFromAnixart(releaseId);
|
|
||||||
res.json(data);
|
|
||||||
} catch (error) {
|
|
||||||
res.status(500).json({ error: error.message });
|
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
|
||||||
// Эндпоинт для конфигурационного JSON из toggles-old-1.js (Старый Toggles)
|
// Функция для создания кастомного JSON-ответа
|
||||||
app.get('/api/extension/config/toggles', (req, res) => {
|
function getCustomNotFoundResponse() {
|
||||||
res.json(configDataOld);
|
return {
|
||||||
});
|
"code": 0,
|
||||||
|
"types": [
|
||||||
|
{
|
||||||
|
"@id": 1,
|
||||||
|
"id": 1,
|
||||||
|
"name": "К сожалению, это аниме недоступно!",
|
||||||
|
"icon": "https://cloud.seele.su/images/seele.jpg",
|
||||||
|
"workers": "Это аниме полностью удалено с сервера anixart, либо его там не было изначально.",
|
||||||
|
"is_sub": false,
|
||||||
|
"episodes_count": 0,
|
||||||
|
"view_count": 0,
|
||||||
|
"pinned": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"@id": 2,
|
||||||
|
"id": 2,
|
||||||
|
"name": "Не забудьте подписаться на наш Telegram-канал 😊",
|
||||||
|
"icon": "https://cloud.seele.su/images/seele.jpg",
|
||||||
|
"workers": "Тгк: @seele_channel",
|
||||||
|
"is_sub": false,
|
||||||
|
"episodes_count": 0,
|
||||||
|
"view_count": 0,
|
||||||
|
"pinned": false
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
// --------------------------
|
module.exports = { getEpisodeFromAnixart };
|
||||||
|
|
||||||
// Обработчик для всех неизвестных маршрутов
|
|
||||||
app.use((req, res) => {
|
|
||||||
res.status(404).json({ error: "Страница не существует!", status: 404 });
|
|
||||||
});
|
|
||||||
|
|
||||||
app.listen(PORT, () => {
|
|
||||||
console.log(`Сервер запущен на http://localhost:${PORT}`);
|
|
||||||
});
|
|
||||||
|
|||||||
Reference in New Issue
Block a user