2023-03-04 13:45:26 +00:00
|
|
|
"""
|
|
|
|
OnlyLegs - Database
|
|
|
|
Database models and functions for SQLAlchemy
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
import os
|
|
|
|
from datetime import datetime
|
2023-03-04 13:45:26 +00:00
|
|
|
import platformdirs
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
from sqlalchemy import create_engine, Column, Integer, String, Boolean, DateTime, ForeignKey
|
|
|
|
from sqlalchemy.orm import declarative_base, relationship
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-01 23:29:34 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
path_to_db = os.path.join(platformdirs.user_config_dir('onlylegs'), 'gallery.sqlite')
|
|
|
|
engine = create_engine(f'sqlite:///{path_to_db}', echo=False)
|
|
|
|
base = declarative_base()
|
2023-03-01 23:29:34 +00:00
|
|
|
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
class users (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
User table
|
|
|
|
Joins with post, groups, session and log
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'users'
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
username = Column(String, unique=True, nullable=False)
|
|
|
|
email = Column(String, unique=True, nullable=False)
|
|
|
|
password = Column(String, nullable=False)
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
posts = relationship('posts')
|
|
|
|
groups = relationship('groups')
|
|
|
|
session = relationship('sessions')
|
|
|
|
log = relationship('logs')
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
def __init__(self, username, email, password):
|
|
|
|
self.username = username
|
|
|
|
self.email = email
|
|
|
|
self.password = password
|
|
|
|
self.created_at = datetime.now()
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class posts (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Post table
|
|
|
|
Joins with group_junction
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'posts'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
file_name = Column(String, unique=True, nullable=False)
|
|
|
|
description = Column(String, nullable=False)
|
|
|
|
alt = Column(String, nullable=False)
|
|
|
|
author_id = Column(Integer, ForeignKey('users.id'))
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
junction = relationship('group_junction')
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
def __init__(self, file_name, description, alt, author_id):
|
|
|
|
self.file_name = file_name
|
|
|
|
self.description = description
|
|
|
|
self.alt = alt
|
|
|
|
self.author_id = author_id
|
|
|
|
self.created_at = datetime.now()
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
class groups (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Group table
|
|
|
|
Joins with group_junction
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'groups'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
name = Column(String, nullable=False)
|
|
|
|
description = Column(String, nullable=False)
|
|
|
|
author_id = Column(Integer, ForeignKey('users.id'))
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
junction = relationship('group_junction')
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
def __init__(self, name, description, author_id):
|
|
|
|
self.name = name
|
|
|
|
self.description = description
|
|
|
|
self.author_id = author_id
|
|
|
|
self.created_at = datetime.now()
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class group_junction (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Junction table for posts and groups
|
|
|
|
Joins with posts and groups
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'group_junction'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
group_id = Column(Integer, ForeignKey('groups.id'))
|
|
|
|
post_id = Column(Integer, ForeignKey('posts.id'))
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
def __init__(self, group_id, post_id):
|
|
|
|
self.group_id = group_id
|
|
|
|
self.post_id = post_id
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class sessions (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Session table
|
|
|
|
Joins with user
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'sessions'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
user_id = Column(Integer, ForeignKey('users.id'))
|
|
|
|
session_uuid = Column(String, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
ip_address = Column(String, nullable=False)
|
2023-03-03 00:26:46 +00:00
|
|
|
user_agent = Column(String, nullable=False)
|
|
|
|
active = Column(Boolean, nullable=False)
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
def __init__(self, user_id, session_uuid, ip_address, user_agent, active): # pylint: disable=too-many-arguments, C0103
|
2023-03-03 00:26:46 +00:00
|
|
|
self.user_id = user_id
|
|
|
|
self.session_uuid = session_uuid
|
2023-03-04 13:45:26 +00:00
|
|
|
self.ip_address = ip_address
|
2023-03-03 00:26:46 +00:00
|
|
|
self.user_agent = user_agent
|
|
|
|
self.active = active
|
|
|
|
self.created_at = datetime.now()
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class logs (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Log table
|
|
|
|
Joins with user
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'logs'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
|
|
|
user_id = Column(Integer, ForeignKey('users.id'))
|
2023-03-04 13:45:26 +00:00
|
|
|
ip_address = Column(String, nullable=False)
|
2023-03-03 00:26:46 +00:00
|
|
|
code = Column(Integer, nullable=False)
|
|
|
|
msg = Column(String, nullable=False)
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
def __init__(self, user_id, ip_address, code, msg):
|
2023-03-03 00:26:46 +00:00
|
|
|
self.user_id = user_id
|
2023-03-04 13:45:26 +00:00
|
|
|
self.ip_address = ip_address
|
2023-03-03 00:26:46 +00:00
|
|
|
self.code = code
|
|
|
|
self.msg = msg
|
|
|
|
self.created_at = datetime.now()
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class bans (base): # pylint: disable=too-few-public-methods, C0103
|
|
|
|
"""
|
|
|
|
Bans table
|
|
|
|
"""
|
2023-03-03 00:26:46 +00:00
|
|
|
__tablename__ = 'bans'
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
id = Column(Integer, primary_key=True)
|
2023-03-04 13:45:26 +00:00
|
|
|
ip_address = Column(String, nullable=False)
|
2023-03-03 00:26:46 +00:00
|
|
|
code = Column(Integer, nullable=False)
|
|
|
|
msg = Column(String, nullable=False)
|
|
|
|
created_at = Column(DateTime, nullable=False)
|
2023-03-04 13:45:26 +00:00
|
|
|
|
|
|
|
def __init__(self, ip_address, code, msg):
|
|
|
|
self.ip_address = ip_address
|
2023-03-03 00:26:46 +00:00
|
|
|
self.code = code
|
|
|
|
self.msg = msg
|
|
|
|
self.created_at = datetime.now()
|
2023-01-10 12:39:29 +00:00
|
|
|
|
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
base.metadata.create_all(engine)
|