2021-10-06 05:34:55 -05:00
|
|
|
"""
|
|
|
|
See the Base class docstring for details on this module
|
|
|
|
"""
|
|
|
|
|
2021-10-05 05:14:45 -05:00
|
|
|
import sqlalchemy.orm
|
|
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
|
|
|
|
|
|
|
|
|
|
@sqlalchemy.orm.as_declarative()
|
|
|
|
class Base:
|
|
|
|
"""
|
|
|
|
Standard base class to define a table in a postgresql database
|
|
|
|
|
|
|
|
Default Columns:
|
|
|
|
-> id
|
|
|
|
- Defines a UUID generated via postgresql's in-built "uuid_generate_v4" function,
|
|
|
|
requires the "uuid-ossp" to be installed to the given database. The extension can be installed via
|
|
|
|
"CREATE EXTENSION IF NOT EXISTS "uuid-ossp";"
|
|
|
|
- May never be null
|
|
|
|
-> creation
|
|
|
|
- Defines the creation date in ISO 8601 format based on the sqlalchemy DateTime class and generated by the
|
|
|
|
database using func.now()
|
|
|
|
- May never be null
|
|
|
|
-> Modification
|
|
|
|
- Defines a ISO 8601 timestamp that is updated anytime the data in a column is modified for a given row
|
|
|
|
- Can be null
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
This class, "Base", must be inherited by subclasses to define tables within a database. A subclass must define
|
|
|
|
a single string with a variable name of "__tablename__" which defines the actual table name within the database.
|
|
|
|
|
|
|
|
-> Example Implementation
|
|
|
|
>>> class SomeTable(Base):
|
|
|
|
>>> __tablename__ = "Some Table"
|
|
|
|
>>> data = sqlalchemy.Column(sqlalchemy.String)
|
|
|
|
"""
|
|
|
|
|
|
|
|
__table__: sqlalchemy.Table
|
|
|
|
|
|
|
|
# This ID column expects the extension "uuid-ossp" to be installed on the postgres DB
|
|
|
|
# Can be done via "CREATE EXTENSION IF NOT EXISTS "uuid-ossp";"
|
|
|
|
id = sqlalchemy.Column(
|
|
|
|
UUID,
|
|
|
|
default=sqlalchemy.text("uuid_generate_v4()"),
|
|
|
|
primary_key=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
creation: sqlalchemy.Column = sqlalchemy.Column(
|
|
|
|
sqlalchemy.DateTime(timezone=True),
|
|
|
|
key="creation",
|
|
|
|
name="creation",
|
|
|
|
index=True,
|
|
|
|
quote=True,
|
|
|
|
unique=False,
|
|
|
|
default=None,
|
|
|
|
nullable=False,
|
|
|
|
primary_key=False,
|
|
|
|
autoincrement=False,
|
|
|
|
server_default=sqlalchemy.func.now(),
|
|
|
|
)
|
|
|
|
|
|
|
|
modification: sqlalchemy.Column = sqlalchemy.Column(
|
|
|
|
sqlalchemy.DateTime(timezone=True),
|
|
|
|
key="Modification",
|
|
|
|
name="modification",
|
|
|
|
index=True,
|
|
|
|
quote=True,
|
|
|
|
unique=False,
|
|
|
|
default=None,
|
|
|
|
nullable=True,
|
|
|
|
onupdate=sqlalchemy.func.now(),
|
|
|
|
primary_key=False,
|
|
|
|
autoincrement=False
|
|
|
|
)
|