Добавлены новые функции для работы с промокодами в integration_api.py, включая создание и получение промокодов для Telegram-агентов. Обновлены модели и добавлен новый файл generate_sql.py для генерации SQL-скрипта создания таблиц. Обновлены fill_db.py для генерации промокодов при заполнении базы данных. Также обновлены sql_models.py для добавления модели PromoCode и соответствующих связей. Улучшена структура кода и добавлены отладочные сообщения.
This commit is contained in:
23
generate_sql.py
Normal file
23
generate_sql.py
Normal file
@@ -0,0 +1,23 @@
|
||||
from sqlmodel import SQLModel
|
||||
from sql_models import Company, TgAgent, Ref, Sale, AgentTransaction, PartnerTransaction, CompanyBalance, AgentBalance, Account, IntegrationToken, PromoCode
|
||||
from helpers_bff import AUTH_DB_ENGINE
|
||||
from sqlalchemy.schema import CreateTable
|
||||
import os
|
||||
|
||||
# --- Отладочный вывод ---
|
||||
print("Таблицы в metadata:", SQLModel.metadata.sorted_tables)
|
||||
print("Все зарегистрированные модели:", SQLModel.__subclasses__())
|
||||
|
||||
# --- Генерация и сохранение SQL-скрипта создания таблиц ---
|
||||
def get_sql_create_script():
|
||||
script = []
|
||||
for table in SQLModel.metadata.sorted_tables:
|
||||
create_table_sql = str(CreateTable(table).compile(dialect=AUTH_DB_ENGINE.dialect))
|
||||
script.append(f"{create_table_sql};")
|
||||
return "\n\n".join(script)
|
||||
|
||||
sql_script = get_sql_create_script()
|
||||
sql_file_path = os.path.join(os.path.dirname(__file__), "sql_create.sql")
|
||||
with open(sql_file_path, "w", encoding="utf-8") as f:
|
||||
f.write(sql_script)
|
||||
print("SQL-скрипт успешно сгенерирован!")
|
||||
Reference in New Issue
Block a user