Skip to main content

Framework for 3phi project

Project description

3phi Framework

Utility classes for DB access, S3 interactions, and data processing via Controller Classes.
Distributed on PyPi.

Install name: 3phi-framework
Import package: threephi_framework


Installation

Install from PyPi

pip install 3phi-framework

Installing a Development Build (from CI)

Development builds are generated for each pull request and attached as workflow artifacts.

Download the artifact

  1. Open the pull request on GitHub
  2. Go to the Checks tab
  3. Open the CI and Release workflow run
  4. Download the artifact named dist-pr
  5. Extract the archive locally

It will contain files like:

dist/ 3phi_framework-.whl 3phi_framework-.tar.gz

Install the wheel (recommended)

From the extracted directory:

pip install dist/3phi_framework-*.whl

Alternatively, install the source distribution:

pip install dist/3phi_framework-*.tar.gz

Notes: Wheels are preferred and install faster. Make sure you are using Python ≥ 3.12 (project requirement). Dev builds are temporary and may be deleted after 7 days.

Quickstart

The framework is set up for local development as well as for being used in a deployment. To set up your environment for local development, follow these steps:

Set up virtual environment

execute_data_app.sh expects a virtual environment to be set up under [.venv]. See the python docs on how to set it up.

Seed data

Obtain seed data for the database and the object storage and copy it to:

  • 3_db_seed.sql: This should be a sql dump/snapshot of a working 3phi Database, PSQL will automatically seed the DB when it is created using docker compose.
  • 3phi: This should be a copy of a bucket from a working object storage. It will be mounted in the minio object storage as a bucket.

Spin up DB and Object Storage

Navigate to docker and run

docker compose up -d

This will bring up a local DB and a MinIO Object Storage seeded with the data you provided.

Run a data app locally

Use the utility script execute_data_app.sh and pass the data app name as an argument, e.g.:

./execute_data_app.sh sm_classifier

In case the script is not executable, make it executable:

chmod +x execute_data_app.sh

The script will install the dependencies in requirements.txt in your virtual environment, set up environment variables as they are listed in .env and execute the data app as a python module.

Object Storage Connectors

The framework abstracts object storage behind BaseConnector so data apps are decoupled from the underlying storage backend. Two implementations are provided out of the box.

S3Connector

For AWS S3 or any S3-compatible storage (the default local dev setup uses MinIO).

from threephi_framework import S3Connector

connector = S3Connector(data_dir_path="timeseries/ready")
Environment variable Required Description
S3_ENDPOINT_URL Yes Full URL of the S3 endpoint, e.g. http://localhost:19000 for MinIO
S3_ACCESS_KEY Yes Access key / username
S3_SECRET_KEY Yes Secret key / password

The bucket name is fixed to 3phi. All paths are rooted at s3://3phi/<data_dir_path>.

AzureBlobConnector

For Azure Blob Storage. Requires the adlfs package (pip install adlfs).

from threephi_framework import AzureBlobConnector

connector = AzureBlobConnector(data_dir_path="timeseries/ready")
Environment variable Required Description
AZURE_STORAGE_ACCOUNT_NAME Yes Azure Storage Account name
AZURE_STORAGE_CONTAINER_NAME Yes Blob container name (equivalent to the S3 bucket)
AZURE_STORAGE_ACCOUNT_KEY No Account key for key-based auth. If omitted, DefaultAzureCredential is used automatically

All paths are rooted at az://<container>/<data_dir_path>.

Authentication — when AZURE_STORAGE_ACCOUNT_KEY is not set, the connector falls back to DefaultAzureCredential, which transparently supports managed identity, service principal (via environment variables), and az login for local development. No code changes are needed between environments.

Writing a custom connector

Subclass BaseConnector and implement all abstract methods. The connector is injected into TimeSeriesController at construction time, so any conforming implementation works as a drop-in replacement:

from threephi_framework.object_storage.base_connector import BaseConnector

class MyConnector(BaseConnector):
    ...

controller = TimeSeriesController(connector=MyConnector(data_dir_path="..."))

Data Model

The currently assumed datamodel is illustrated in the diagram below:

Data Model

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

3phi_framework-0.2.8.tar.gz (432.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

3phi_framework-0.2.8-py3-none-any.whl (108.1 kB view details)

Uploaded Python 3

File details

Details for the file 3phi_framework-0.2.8.tar.gz.

File metadata

  • Download URL: 3phi_framework-0.2.8.tar.gz
  • Upload date:
  • Size: 432.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for 3phi_framework-0.2.8.tar.gz
Algorithm Hash digest
SHA256 a57235b0b2292b732228c1e187eeb2d989214260ed46bcd1332d77bdeb57ff3d
MD5 1ee767e3e20a84202770b2428a5491e1
BLAKE2b-256 8db3e49c211578549f83168e5a1b9c0227c184d4abf1830355cf667d2c126412

See more details on using hashes here.

Provenance

The following attestation bundles were made for 3phi_framework-0.2.8.tar.gz:

Publisher: ci-release.yml on 3PhaseInsight/3phi-framework

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file 3phi_framework-0.2.8-py3-none-any.whl.

File metadata

  • Download URL: 3phi_framework-0.2.8-py3-none-any.whl
  • Upload date:
  • Size: 108.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for 3phi_framework-0.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 e507b3841ecffda7a6ca2df194aab629546b8e6dfca454b83b56bf9e71be10bf
MD5 583690b84be1ec9265795e9cb1d72bc9
BLAKE2b-256 b3cc1dc568be8880de3f695006ddd9ac3ebba9b77d786096b4b850d445e5f9fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for 3phi_framework-0.2.8-py3-none-any.whl:

Publisher: ci-release.yml on 3PhaseInsight/3phi-framework

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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