[WIP] Work in progress

This commit is contained in:
2026-02-08 11:20:42 +01:00
parent bd135f2265
commit a2fa1c7c9b
34 changed files with 159 additions and 2 deletions

0
app/api/__init__.py Normal file
View File

View File

View File

8
app/api/config/cruds/env/create.py vendored Normal file
View File

@@ -0,0 +1,8 @@
import os
from sqlalchemy.orm import Session
from .....schema.config.env import Env
def create(session:Session, env:Env):
session.add(env)
os.environ[env.key] = env.value
session.commit()

9
app/api/config/cruds/env/delete.py vendored Normal file
View File

@@ -0,0 +1,9 @@
import os
from sqlalchemy.orm import Session
from .....schema.config.env import Env
def delete(session:Session, env:Env):
session.delete(env)
delete(os.environ[env.key])
session.commit()

11
app/api/config/cruds/env/read.py vendored Normal file
View File

@@ -0,0 +1,11 @@
import os
from sqlalchemy.orm import Session
from sqlalchemy import select
from .....schema.config.env import Env
def read(session:Session, _id:int):
stmt = select(Env).where(Env.id == _id)
env:Env = session.scalars(stmt).one()
os.environ[env.key] = env.value
return env

8
app/api/config/cruds/env/update.py vendored Normal file
View File

@@ -0,0 +1,8 @@
import os
from sqlalchemy.orm import Session
from .....schema.config.env import Env
def update(session:Session, env:Env):
os.environ[env.key] = env.value
session.commit()

View File

@@ -0,0 +1,6 @@
from sqlalchemy.orm import Session
from .....schema.config.library import LibraryConfig
def create(session:Session, library:LibraryConfig):
session.add(library)
session.commit()

View File

@@ -0,0 +1,7 @@
from sqlalchemy.orm import Session
from .....schema.config.library import LibraryConfig
def delete(session:Session, library:LibraryConfig):
session.delete(library)
session.commit()

View File

@@ -0,0 +1,8 @@
from sqlalchemy.orm import Session
from sqlalchemy import select
from .....schema.config.library import LibraryConfig
def read(session:Session, _id:int):
stmt = select(LibraryConfig).where(LibraryConfig.id == _id)
return session.scalars(stmt).one()

View File

@@ -0,0 +1,6 @@
from sqlalchemy.orm import Session
from .....schema.config.library import LibraryConfig
def update(session:Session, library:LibraryConfig):
session.commit()

View File

View File

View File

@@ -0,0 +1,6 @@
from sqlalchemy.orm import Session
from .....schema.library.book import Book
def create(session:Session, book:Book):
session.add(book)
session.commit()

View File

@@ -0,0 +1,7 @@
from sqlalchemy.orm import Session
from .....schema.library.book import Book
def delete(session:Session, book:Book):
session.delete(book)
session.commit()

View File

@@ -0,0 +1,8 @@
from sqlalchemy.orm import Session
from sqlalchemy import select
from .....schema.library.book import Book
def read(session:Session, _id:int):
stmt = select(Book).where(Book.id == _id)
return session.scalars(stmt).one()

View File

@@ -0,0 +1,6 @@
from sqlalchemy.orm import Session
from .....schema.library.book import Book
def update(session:Session, book:Book):
session.commit()

View File

0
app/db/__init__.py Normal file
View File

View File

@@ -0,0 +1 @@
from .engine import engine

2
app/db/config/config.py Normal file
View File

@@ -0,0 +1,2 @@
engine_string = "sqlite://"
echo = True

4
app/db/config/engine.py Normal file
View File

@@ -0,0 +1,4 @@
from sqlalchemy import create_engine
from .config import engine_string, echo
engine = create_engine(engine_string, echo=echo)

View File

@@ -0,0 +1 @@
from .engine import engine

2
app/db/library/config.py Normal file
View File

@@ -0,0 +1,2 @@
engine_string = "sqlite://"
echo = True

4
app/db/library/engine.py Normal file
View File

@@ -0,0 +1,4 @@
from sqlalchemy import create_engine
from .config import engine_string, echo
engine = create_engine(engine_string, echo=echo)

View File

22
app/schema/config/env.py Normal file
View File

@@ -0,0 +1,22 @@
from typing import List
from typing import Optional
from sqlalchemy import String
from sqlalchemy.orm import Mapped
from sqlalchemy.orm import mapped_column
from sqlalchemy.orm import relationship
from .base import Base
class Env(Base):
__tablename__ = "env"
id: Mapped[int] = mapped_column(primary_key=True)
key: Mapped[str] = mapped_column(String(255))
value: Mapped[str] = mapped_column(String(65656))
libraries: Mapped[List["Library"]] = relationship(
back_populates="libraries", cascade="all, delete-orphan"
)
def __repr__(self) -> str:
return f"Book(id={self.id!r}, name={self.name!r}, publisher={self.publisher!r}," \
" notes={self.notes!r}, classification={self.classification!r})"

View File

@@ -0,0 +1,23 @@
from typing import List
from typing import Optional
from sqlalchemy import String
from sqlalchemy.orm import Mapped
from sqlalchemy.orm import mapped_column
from sqlalchemy.orm import relationship
from .base import Base
class LibraryConfig(Base):
__tablename__ = "library_config"
id: Mapped[int] = mapped_column(primary_key=True)
name: Mapped[str] = mapped_column(String(255))
notes: Mapped[str] = mapped_column(String(65656))
connection_string = Mapped[str] = mapped_column(String(65656))
env: Mapped[List["Env"]] = relationship(
back_populates="env", cascade="all, delete-orphan"
)
def __repr__(self) -> str:
return f"Book(id={self.id!r}, name={self.name!r}, publisher={self.publisher!r}," \
" notes={self.notes!r}, classification={self.classification!r})"

View File

@@ -0,0 +1,3 @@
from .base import Base
from .book import Book
from .tag import Tag

View File

@@ -0,0 +1,4 @@
from sqlalchemy.orm import DeclarativeBase
class Base(DeclarativeBase):
pass

View File

@@ -16,7 +16,7 @@ class Book(Base):
classification: Mapped[int] = mapped_column(primary_key=True)
tags: Mapped[List["Tags"]] = relationship(
back_populates="book", cascade="all, delete-orphan"
back_populates="books", cascade="all, delete-orphan"
)
def __repr__(self) -> str:

View File

@@ -1,3 +1,4 @@
flask
sqlalchemy
requests
requests
py-dotenv