Create app.py
Browse files
app.py
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import gradio as gr
|
| 2 |
+
import requests
|
| 3 |
+
import json
|
| 4 |
+
import os
|
| 5 |
+
|
| 6 |
+
|
| 7 |
+
# Функция для генерации текста
|
| 8 |
+
def generate(whomtb="Бабушке", fromtb="Внука", pricesl=-1, whattb="Новый Год", doptb=""):
|
| 9 |
+
if not whomtb or not whattb:
|
| 10 |
+
return "Здесь будут идеи для подарков, цены и ссылки на ресурсы."
|
| 11 |
+
|
| 12 |
+
system_role = """Ты - Поисковик Подарков (ищи актуальное в интернете, желательно но не обязательно в Яндекс). Пользователь будет давать тебе запрос (если максимальную цену подарка пользователь указал '-1', то значит любая, '0', значит бесплатно, своими руками (подручными материалами)), а ты по нему должен подобрать подарки (по запросу). Модешь предоставлять ссылки на ресурсы, акиуальные цены на доступных в России маркетплейсах. ТОЛЬКО АКТУАЛЬНЫЕ, ТЕКУЩИЕ, РАБОЧИЕ ССЫЛКИ, проверяй. (В основном бери ссылки ozon, wildberries, AliExpress. Ещё если попадётся, то и на товары в физических магазинах на оффициальных сайтах) (Товар, цена и маркдовном ссылка или просто идеи.) В конце ещё идеи как можно красиво оформить подарок). НЕ В КОЕМ СЛУЧАЕ НЕ ДАВАЙ НЕРАБОЧИЕ ССЫЛКИ, ИЛИ ССЫЛКИ НА УЖЕ НЕ СУЩЕСТВУЮЩИЕ ТОВАРЫ! ВСЕГДА СНАЧАЛА ПРОВЕРЯЙ СТРАНИЦЫ ИНАЧЕ НЕ ДОБАВЛЯЙ ССЫЛКУ!"""
|
| 13 |
+
user_msg = f"Подарок на праздник: '{whattb}', кому: '{whomtb}', от: '{fromtb}', цена подарка до {pricesl}₽, дополнительно: '{doptb}'"
|
| 14 |
+
|
| 15 |
+
headers = {
|
| 16 |
+
'Content-Type': 'application/json',
|
| 17 |
+
# 'Authorization': f'Bearer {os.getenv("API_KEY")}'
|
| 18 |
+
}
|
| 19 |
+
|
| 20 |
+
payload = {
|
| 21 |
+
'messages': [{'role': 'system', 'content': system_role}, {'role': 'user', 'content': user_msg}],
|
| 22 |
+
'max_tokens': 2500,
|
| 23 |
+
'model': "searchgpt"
|
| 24 |
+
}
|
| 25 |
+
|
| 26 |
+
try:
|
| 27 |
+
response = requests.post(os.getenv("BASE_URL"), headers=headers, json=payload, timeout=200)
|
| 28 |
+
response.raise_for_status() # Проверяем на ошибки HTTP
|
| 29 |
+
data = response.json() # Используем response.json() вместо json.loads()
|
| 30 |
+
|
| 31 |
+
if 'choices' in data and len(data['choices']) > 0:
|
| 32 |
+
congratulation = data['choices'][0]['message']['content'].strip()
|
| 33 |
+
print("Генерация успешна")
|
| 34 |
+
return congratulation
|
| 35 |
+
elif 'error' in data:
|
| 36 |
+
error_message = data['error']['message']
|
| 37 |
+
print(f'Ошибка: {error_message}')
|
| 38 |
+
return f"Ошибка сервера!"
|
| 39 |
+
else:
|
| 40 |
+
print(f'Не удалось написать текст. Ответ сервера: {data}') # Выводим ответ сервера для отладки
|
| 41 |
+
return "Неизвестная ошибка!"
|
| 42 |
+
except requests.exceptions.RequestException as e:
|
| 43 |
+
print(f"Ошибка запроса: {e}")
|
| 44 |
+
return f"Ошибка запроса!"
|
| 45 |
+
|
| 46 |
+
# Ссылка на файл CSS
|
| 47 |
+
css_url = "https://neurixyufi-aihub.static.hf.space/style.css"
|
| 48 |
+
|
| 49 |
+
# Получение CSS по ссылке
|
| 50 |
+
response = requests.get(css_url)
|
| 51 |
+
css = response.text + ".gradio-container{max-width: 700px !important} h1, h3 {text-align:center}"
|
| 52 |
+
|
| 53 |
+
|
| 54 |
+
# UI
|
| 55 |
+
with gr.Blocks(css=css) as demo:
|
| 56 |
+
gr.Markdown("# Поиск Magisk модулей\n### На 4pda, Rooni_Studio")
|
| 57 |
+
with gr.Column():
|
| 58 |
+
with gr.Row():
|
| 59 |
+
fromtb = gr.Textbox(show_label=True, placeholder="Внука", label="От кого", interactive=True, container=True,)
|
| 60 |
+
#whomtb = AutocompleteTextbox(show_label=True, value="Бабушке", label="Кому", commands=whom, interactive=True, container=True,)
|
| 61 |
+
whomtb = gr.Textbox(show_label=True, placeholder="Бабушке", label="Кому", interactive=True, container=True,)
|
| 62 |
+
with gr.Row():
|
| 63 |
+
#whattb = AutocompleteTextbox(show_label=True, value="Новый Год", label="Праздник", commands=what, interactive=True, container=True,)
|
| 64 |
+
whattb = gr.Textbox(show_label=True, placeholder="Новый Год", label="Праздник", interactive=True, container=True,)
|
| 65 |
+
pricesl = gr.Slider(show_label=True, label="Ценовая категория в ₽, до", minimum=-1, maximum=500000, value=-1, step=1)
|
| 66 |
+
with gr.Row():
|
| 67 |
+
doptb = gr.Textbox(show_label=True, placeholder="50-летней", label="Дополнительно")
|
| 68 |
+
with gr.Row():
|
| 69 |
+
text_button = gr.Button("Придумать", variant='primary')
|
| 70 |
+
with gr.Row():
|
| 71 |
+
with gr.Column():
|
| 72 |
+
text_output = gr.Markdown(show_label=False, value="Здесь будут идеи для подарков, цены и ссылки на ресурсы.", container=True)
|
| 73 |
+
|
| 74 |
+
text_button.click(generate, inputs=[whomtb, fromtb, pricesl, whattb, doptb], outputs=[text_output], concurrency_limit=250)
|
| 75 |
+
|
| 76 |
+
demo.queue(max_size=250, api_open=False).launch()
|