Create project
This commit is contained in:
84
db.py
Normal file
84
db.py
Normal file
@@ -0,0 +1,84 @@
|
||||
from sqlalchemy import create_engine, Column, String, Integer, Numeric, DateTime, ForeignKey, Text
|
||||
from sqlalchemy.ext.declarative import declarative_base
|
||||
from sqlalchemy.orm import sessionmaker, relationship
|
||||
from datetime import datetime
|
||||
import uuid
|
||||
|
||||
Base = declarative_base()
|
||||
|
||||
def generate_uuid():
|
||||
return str(uuid.uuid4())
|
||||
|
||||
#Пользователи
|
||||
class User(Base):
|
||||
__tablename__ = 'users'
|
||||
|
||||
id = Column(String, primary_key=True, default=generate_uuid)
|
||||
telegram_id = Column(String, unique=True, nullable=False)
|
||||
username = Column(String) # email 3x-ui
|
||||
balance = Column(Numeric(10, 2), default=0.0)
|
||||
created_at = Column(DateTime, default=datetime.now)
|
||||
updated_at = Column(DateTime, default=datetime.now, onupdate=datetime.now)
|
||||
|
||||
subscriptions = relationship("Subscription", back_populates="user")
|
||||
transactions = relationship("Transaction", back_populates="user")
|
||||
|
||||
#Подписки
|
||||
class Subscription(Base):
|
||||
__tablename__ = 'subscriptions'
|
||||
|
||||
id = Column(String, primary_key=True, default=generate_uuid)
|
||||
user_id = Column(String, ForeignKey('users.id'))
|
||||
vpn_server_id = Column(String, ForeignKey('vpn_servers.id'))
|
||||
plan = Column(String)
|
||||
expiry_date = Column(DateTime)
|
||||
created_at = Column(DateTime, default=datetime.now)
|
||||
updated_at = Column(DateTime, default=datetime.now, onupdate=datetime.now)
|
||||
|
||||
user = relationship("User", back_populates="subscriptions")
|
||||
vpn_server = relationship("VPNServer", back_populates="subscriptions")
|
||||
|
||||
#Транзакции
|
||||
class Transaction(Base):
|
||||
__tablename__ = 'transactions'
|
||||
|
||||
id = Column(String, primary_key=True, default=generate_uuid)
|
||||
user_id = Column(String, ForeignKey('users.id'))
|
||||
amount = Column(Numeric(10, 2))
|
||||
transaction_type = Column(String)
|
||||
created_at = Column(DateTime, default=datetime.now)
|
||||
|
||||
user = relationship("User", back_populates="transactions")
|
||||
|
||||
# VPN-серверы
|
||||
class VPNServer(Base):
|
||||
__tablename__ = 'vpn_servers'
|
||||
|
||||
id = Column(String, primary_key=True, default=generate_uuid)
|
||||
server_name = Column(String)
|
||||
ip_address = Column(String)
|
||||
port = Column(Integer)
|
||||
login_data = Column(Text)
|
||||
inbound = Column(Text)
|
||||
config = Column(Text)
|
||||
current_users = Column(Integer, default=0)
|
||||
max_users = Column(Integer, default=4)
|
||||
|
||||
subscriptions = relationship("Subscription", back_populates="vpn_server")
|
||||
|
||||
# Настройка подключения к базе данных
|
||||
DATABASE_URL = "postgresql://vpn_bot_user:yourpassword@localhost/vpn_bot_db"
|
||||
|
||||
engine = create_engine(DATABASE_URL)
|
||||
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
||||
|
||||
def init_db():
|
||||
Base.metadata.create_all(bind=engine)
|
||||
|
||||
def get_db_session():
|
||||
db = SessionLocal()
|
||||
try:
|
||||
yield db
|
||||
finally:
|
||||
db.close()
|
||||
|
||||
Reference in New Issue
Block a user