No project description provided
Project description
artemis-model
Welcome to artemis-model
, the backbone repository that contains all the essential models used in both the artemis-api
and the prophet
project. This project includes asynchronous models used by artemis-api
, such as Artist
, and synchronous models like ArtistSync
for other implementations.
Getting Started
To set up your development environment for artemis-model
, follow these initial setup steps:
- Environment Setup
cp ./alembic/.env.example ./alembic/.env
After copying the example environment file, make sure to fill in the .env
file with your specific configurations.
- Install Dependencies
poetry install --all-extras
This will install all necessary dependencies to get you started with artemis-models
and alembic
.
Creating a New Model
To introduce a new model in the project, you should start by creating a mixin and then define two different model classes that inherit from this mixin.
Example: Adding a LoginHistory
Model
- Define the Mixin This mixin will include all the common attributes of your model.
class LoginHistoryMixin:
"""
Stores the login history of users.
"""
id: Mapped[int] = mapped_column(primary_key=True, autoincrement=True, nullable=False)
account_id: Mapped[uuid.UUID] = mapped_column(ForeignKey("user_account.id"), nullable=False, index=True)
ip_address: Mapped[str] = mapped_column(nullable=True)
created_at = mapped_column(DateTime, default=datetime.utcnow)
@declared_attr
def account(cls) -> Mapped["UserAccount"]:
return relationship("UserAccount", back_populates="login_histories")
- Inherit from Base Classes Create two classes that inherit from CustomBase and CustomSyncBase respectively, using the mixin for shared attributes.
class LoginHistorySync(CustomSyncBase, LoginHistoryMixin):
pass
class LoginHistory(CustomBase, LoginHistoryMixin):
pass
Version Management and Builds
- Update the Project Version
Open pyproject.toml and increment the minor version number.
- Build the Project
poetry build
- Update Dependency in artemis-api/prophet
If the build succeeds, remember to also bump the version number in the pyproject.toml of artemis-api and prophet to match the new version of artemis-model.
Using Alembic for Model Changes
If modifications are necessary for any model:
- Modify the Model
- Create an Alembic Revision
alembic revision --autogenerate -m "Description of changes"
- Upgrade Database Schema
alembic upgrade head
Ensure that the new Alembic script in the versions directory is committed to your git repository. Repeat the build and version update steps as necessary after making changes.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file artemis_model-0.1.70.tar.gz
.
File metadata
- Download URL: artemis_model-0.1.70.tar.gz
- Upload date:
- Size: 11.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b6577ce5cc5d1350b49840dcc5d16d211f6504ce37966a6002892a0277d1d218 |
|
MD5 | f2489dc35c137a7d3ff33c7b1d0512ef |
|
BLAKE2b-256 | ba999c95b9024b9e9897ef18d81e545a24a545916272a43085aec0a5c16da01a |
File details
Details for the file artemis_model-0.1.70-py3-none-any.whl
.
File metadata
- Download URL: artemis_model-0.1.70-py3-none-any.whl
- Upload date:
- Size: 19.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4133ff6302ce6b5c745f8175d5b570dbc6eee0f7a6b429824cffbba205b70092 |
|
MD5 | d56146e516e108be7ae517becaecf2e3 |
|
BLAKE2b-256 | 28681100ecbd32c5e8ef2e82ebf0a24030be927270b6d4bee05d26d5d01cc31a |