KmnNew2.1 / server.js
Rooni's picture
Update server.js
6771456 verified
raw
history blame
4.46 kB
const express = require('express');
const rateLimit = require('express-rate-limit');
const axios = require('axios');
const app = express();
app.use(express.json());
// Доверие к одному прокси (например, Heroku)
app.set('trust proxy', 1);
const openai_keys = process.env.OPENAI_KEY.split(',');
function getRandomApiKey() {
const randomIndex = Math.floor(Math.random() * openai_keys.length);
return openai_keys[randomIndex];
}
const limiter = rateLimit({
windowMs: 60 * 1000, // 60 секунд
max: 15, // лимит каждые 60 секунд на IP
handler: function (req, res) {
return res.status(429).json({ content: "wait" });
},
});
// Применение ограничителя скорости перед обработчиком маршрута /pl и /plbeta
app.use('/pl', limiter);
app.use('/plbeta', limiter);
const start = `${process.env.start}`;
const startconnect = `${process.env.startconnect}`;
app.post('/update', async (req, res) => {
res.json({ content: `{"error":"", "title":"Требуется обновление", "text":"Текущая версия приложения устарела. Установите новую из нашего телеграм канала: @yufi_ru", "okb":"Обновить", "oklink":"https://t.me/yufi_ru", "cancelable":"false"}` });
});
async function sendRequest(prompt, prs) {
const firstUrl = 'https://text.pollinations.ai/openai';
const secondUrl = 'https://text.pollinations.ai/openai';
try {
const response = await axios.post(firstUrl, {
messages: [{'role': 'system', 'content': prs}, {'role': 'user', 'content': prompt}],
max_tokens: 1200,
temperature: 0.19,
}, {
headers: {
'Content-Type': 'application/json',
},
});
if (response.data.choices && response.data.choices.length > 0 && response.data.choices[0].message) {
return response.data.choices[0].message.content.trim();
} else {
throw new Error("Ошибка прочтения на первой ссылке");
}
} catch (error) {
console.error("Первая попытка не удалась:", error);
// Попытка с другой ссылкой
try {
const response = await axios.post(secondUrl, {
messages: [{'role': 'system', 'content': prs}, {'role': 'user', 'content': prompt}],
max_tokens: 1200,
temperature: 0.19,
}, {
headers: {
'Content-Type': 'application/json',
},
});
if (response.data.choices && response.data.choices.length > 0 && response.data.choices[0].message) {
return response.data.choices[0].message.content.trim();
} else {
throw new Error("Ошибка прочтения на второй ссылке");
}
} catch (secondError) {
console.error("Вторая попытка не удалась:", secondError);
throw new Error("Ошибка при генерации");
}
}
}
app.post('/pl', async (req, res) => {
const prompt = req.body.prompt;
let prs;
if (req.body.mode === "1") {
prs = start;
} else {
prs = startconnect;
}
if (!prompt) {
return res.status(400).json({ content: "wait" }); // Не удалось принять данные
}
try {
const content = await sendRequest(prompt, prs);
res.json({ content });
} catch (error) {
res.json({ content: `{"error":"", "title":"Ошибка", "text":"Произошла ошибка на сервере. (${error.message})", "okb":"Ок", "oklink":"", "cancelable":"true"}` });
}
});
app.post('/plbeta', async (req, res) => {
const prompt = req.body.prompt;
let prs;
if (req.body.mode === "1") {
prs = start;
} else {
prs = startconnect;
}
if (!prompt) {
return res.status(400).json({ content: "wait" }); // Не удалось принять данные
}
try {
const content = await sendRequest(prompt, prs);
console.log(`\n---\nПользователь: ${prompt}\n Ответ:\n ${content}`);
res.json({ content });
} catch (error) {
res.json({ content: `{"error":"", "title":"Ошибка", "text":"Произошла ошибка на сервере. (${error.message})", "okb":"Ок", "oklink":"", "cancelable":"true"}` });
}
});
const port = 7860;
app.listen(port, () => {
console.log(`API сервер запущен на порту ${port}`);
});