Skip to main content

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:

  1. 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.

  1. 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

  1. 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")
  1. 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

  1. Update the Project Version

Open pyproject.toml and increment the minor version number.

  1. Build the Project
poetry build
  1. 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:

  1. Modify the Model
  2. Create an Alembic Revision
alembic revision --autogenerate -m "Description of changes"
  1. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

artemis_model-0.1.80.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

artemis_model-0.1.80-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file artemis_model-0.1.80.tar.gz.

File metadata

  • Download URL: artemis_model-0.1.80.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for artemis_model-0.1.80.tar.gz
Algorithm Hash digest
SHA256 41cf2f094a4d58e3c6f45a953bfe6b04d60f51bdd0ae6e4b5332424cabcadd0f
MD5 34961ecbd663eec49b85e4a3582ccb81
BLAKE2b-256 00f9ab3653cfd263d8f64be0468ed9ddf26292890d0845eeafc3163b05367b08

See more details on using hashes here.

Provenance

The following attestation bundles were made for artemis_model-0.1.80.tar.gz:

Publisher: deploy-model-pypi.yml on jukeboxy/artemis

Attestations:

File details

Details for the file artemis_model-0.1.80-py3-none-any.whl.

File metadata

File hashes

Hashes for artemis_model-0.1.80-py3-none-any.whl
Algorithm Hash digest
SHA256 5f8af996b39e6fa2214c517563a8793e181be897ae9a5d47b77363fd8d664f8a
MD5 2d17e9649f7e6b51860811c0b8d1e7cd
BLAKE2b-256 a95fb6b58522dc74f88614020a1715f687c0ae1e75ea98c372fcb2b692b6f897

See more details on using hashes here.

Provenance

The following attestation bundles were made for artemis_model-0.1.80-py3-none-any.whl:

Publisher: deploy-model-pypi.yml on jukeboxy/artemis

Attestations:

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page