[WIP] Work in progress
This commit is contained in:
0
app/api/__init__.py
Normal file
0
app/api/__init__.py
Normal file
0
app/api/config/__init__.py
Normal file
0
app/api/config/__init__.py
Normal file
0
app/api/config/cruds/__init__.py
Normal file
0
app/api/config/cruds/__init__.py
Normal file
8
app/api/config/cruds/env/create.py
vendored
Normal file
8
app/api/config/cruds/env/create.py
vendored
Normal 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
9
app/api/config/cruds/env/delete.py
vendored
Normal 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
11
app/api/config/cruds/env/read.py
vendored
Normal 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
8
app/api/config/cruds/env/update.py
vendored
Normal 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()
|
||||
6
app/api/config/cruds/library/create.py
Normal file
6
app/api/config/cruds/library/create.py
Normal 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()
|
||||
7
app/api/config/cruds/library/delete.py
Normal file
7
app/api/config/cruds/library/delete.py
Normal 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()
|
||||
8
app/api/config/cruds/library/read.py
Normal file
8
app/api/config/cruds/library/read.py
Normal 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()
|
||||
6
app/api/config/cruds/library/update.py
Normal file
6
app/api/config/cruds/library/update.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from sqlalchemy.orm import Session
|
||||
|
||||
from .....schema.config.library import LibraryConfig
|
||||
|
||||
def update(session:Session, library:LibraryConfig):
|
||||
session.commit()
|
||||
0
app/api/library/__init__.py
Normal file
0
app/api/library/__init__.py
Normal file
0
app/api/library/cruds/__init__.py
Normal file
0
app/api/library/cruds/__init__.py
Normal file
6
app/api/library/cruds/book/create.py
Normal file
6
app/api/library/cruds/book/create.py
Normal 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()
|
||||
7
app/api/library/cruds/book/delete.py
Normal file
7
app/api/library/cruds/book/delete.py
Normal 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()
|
||||
8
app/api/library/cruds/book/read.py
Normal file
8
app/api/library/cruds/book/read.py
Normal 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()
|
||||
6
app/api/library/cruds/book/update.py
Normal file
6
app/api/library/cruds/book/update.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from sqlalchemy.orm import Session
|
||||
|
||||
from .....schema.library.book import Book
|
||||
|
||||
def update(session:Session, book:Book):
|
||||
session.commit()
|
||||
0
app/api/library/cruds/tag.py
Normal file
0
app/api/library/cruds/tag.py
Normal file
0
app/db/__init__.py
Normal file
0
app/db/__init__.py
Normal file
1
app/db/config/__init__.py
Normal file
1
app/db/config/__init__.py
Normal file
@@ -0,0 +1 @@
|
||||
from .engine import engine
|
||||
2
app/db/config/config.py
Normal file
2
app/db/config/config.py
Normal file
@@ -0,0 +1,2 @@
|
||||
engine_string = "sqlite://"
|
||||
echo = True
|
||||
4
app/db/config/engine.py
Normal file
4
app/db/config/engine.py
Normal file
@@ -0,0 +1,4 @@
|
||||
from sqlalchemy import create_engine
|
||||
from .config import engine_string, echo
|
||||
|
||||
engine = create_engine(engine_string, echo=echo)
|
||||
1
app/db/library/__init__.py
Normal file
1
app/db/library/__init__.py
Normal file
@@ -0,0 +1 @@
|
||||
from .engine import engine
|
||||
2
app/db/library/config.py
Normal file
2
app/db/library/config.py
Normal file
@@ -0,0 +1,2 @@
|
||||
engine_string = "sqlite://"
|
||||
echo = True
|
||||
4
app/db/library/engine.py
Normal file
4
app/db/library/engine.py
Normal file
@@ -0,0 +1,4 @@
|
||||
from sqlalchemy import create_engine
|
||||
from .config import engine_string, echo
|
||||
|
||||
engine = create_engine(engine_string, echo=echo)
|
||||
0
app/schema/config/__init__.py
Normal file
0
app/schema/config/__init__.py
Normal file
22
app/schema/config/env.py
Normal file
22
app/schema/config/env.py
Normal 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})"
|
||||
23
app/schema/config/library.py
Normal file
23
app/schema/config/library.py
Normal 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})"
|
||||
3
app/schema/library/__init__.py
Normal file
3
app/schema/library/__init__.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from .base import Base
|
||||
from .book import Book
|
||||
from .tag import Tag
|
||||
4
app/schema/library/base.py
Normal file
4
app/schema/library/base.py
Normal file
@@ -0,0 +1,4 @@
|
||||
from sqlalchemy.orm import DeclarativeBase
|
||||
|
||||
class Base(DeclarativeBase):
|
||||
pass
|
||||
@@ -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:
|
||||
@@ -1,3 +1,4 @@
|
||||
flask
|
||||
sqlalchemy
|
||||
requests
|
||||
requests
|
||||
py-dotenv
|
||||
Reference in New Issue
Block a user