File size: 3,717 Bytes
abed4cc
5d38af1
e6227e8
587da90
abed4cc
5d38af1
 
587da90
 
bad8307
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e6227e8
bad8307
5d38af1
e6227e8
 
 
 
 
 
587da90
 
e6227e8
bad8307
5d38af1
587da90
5d38af1
 
 
587da90
5d38af1
587da90
bad8307
6814fd7
bad8307
587da90
 
 
5d38af1
 
587da90
 
bad8307
5d38af1
587da90
5d38af1
6814fd7
587da90
 
 
abed4cc
 
5d38af1
abed4cc
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
const express = require('express');
const rateLimit = require('express-rate-limit');
const axios = require('axios');

const app = express();
app.use(express.json());

const openai_key = process.env.OPENAI_KEY;

const start = `Ты генератор рецептов. В этом чате, тебе будут присылать названия блюд или описывать их или присылать название категории, а ты должен будешь написать идеальный, понятный, подробный, лёгкий или сложный рецепт со всеми пропорциями, количествами и этапами готовки (этапы готовки должны быть разделены, например 1.1., 1.2., 2.1., 2.2. (Обязательно со звёздочками, это жирный шрифт) С эмодзи.

Ответ должен выглядить ТОЛЬКО так (чтобы потом regexp его исправил):
"
+название+Название рецепта, блюда-название-
+время+Примерное время готовки (только время, например: "40 минут", "2 часа" и т.д.)-время-

+кат+Категория: На каждый день, Основные блюда, Супы, Десерты и выпечка, Салаты, Несладкая выпечка, Завтраки, Закуски, Напитки, Ресторанные-кат-

+ингр+Ингридиенты: В именительном падеже - то есть например: "Яйцо -
2 штуки", а не "2 яйца"; Здесь обязательно заменяй ВСЕ новые строки ("
") на "÷"-ингр-

+рец+Рецепт; Здесь обязательно заменяй ВСЕ новые строки ("
") на "÷"-рец-

📙 Рецепт сгенерирова в приложении АромаАрт (yufi.rf.gd/aromaart)
"

Если ты не можешь сгенерировать такой рецепт, то напиши так:
"
+ошибка+Причина-ошибка-
"`

// Определяем лимитер с задержкой 30 секунд на IP
const generateLimiter = rateLimit({
  windowMs: 30 * 1000, // 30 секунд
  max: 1, // лимит: 1 запрос на IP
  handler: function (req, res /*next*/) {
    return res.status(429).json({
      error: "Слишком много запросов с этого IP, пожалуйста, попробуйте позже. (Лимит 1 генерация в 30 секунд)"
    });
  }
});

// Применяем лимитер только к определенному маршруту
app.post('/generate', generateLimiter, async (req, res) => {
  const prompt = req.body.prompt;

  if (!prompt) {
    return res.status(400).json({ error: 'Требуется параметр "prompt".' });
  }

  try {
    const response = await axios.post('https://api.openai.com/v1/images/generations', {
      messages: [{'role': 'system', 'content': start}, {'role': 'system', 'content': prompt}],
      max_tokens: 2000,
      model: "gpt-4-1106-preview",
    }, {
      headers: {
        'Authorization': `Bearer ${openai_key}`,
        'Content-Type': 'application/json',
      },
    });

    print(response.data)
    res.json(response.data);
  } catch (error) {
    console.error(error);
    res.status(500).json({ error: 'Произошла ошибка сервера при генерации.' });
  }
});

const port = 7860;
app.listen(port, () => {
  console.log(`API сервер запущен на порту ${port}`);
});