Skip to main content

Andlake platform SDK — pre-configured connections to Trino, Nessie, MLflow, S3, and Iceberg.

Project description

andlake-sdk

Pre-configured Python SDK for the Andlake data platform. Provides zero-config access to Trino, Nessie, MLflow, S3, and Iceberg from JupyterHub notebooks.

Quick Start

from andlake import get_trino_connection, configure_mlflow
import pandas as pd

# Connect to Trino via the Andlake gateway
conn = get_trino_connection()
df = pd.read_sql("SELECT * FROM lake.silver.transactions LIMIT 1000", conn)

# Set up MLflow experiment tracking
configure_mlflow(experiment_name="fraud-detection")

Available Functions

Function Description
get_trino_connection() Trino DBAPI connection via the gateway
get_trino_engine() SQLAlchemy engine for pd.read_sql()
get_nessie_client() Nessie catalog client for branch management
configure_mlflow() Set MLflow tracking URI and experiment
get_mlflow_client() Pre-configured MlflowClient
get_s3_client() boto3 S3 client (uses IRSA)
get_s3_resource() boto3 S3 resource (uses IRSA)
get_iceberg_catalog() PyIceberg REST catalog via Nessie

Environment Variables

Static service URLs are set by JupyterHub extraEnv. Per-user values are injected by the pre_spawn_hook from Keycloak auth_state.

Variable Default Source
ANDLAKE_GATEWAY_URL http://notebook-service:8082 extraEnv
TRINO_HOST notebook-service extraEnv
TRINO_PORT 8082 extraEnv
NESSIE_URI http://nessie:19120/api/v2 extraEnv
MLFLOW_TRACKING_URI http://mlflow:5000 extraEnv
ANDLAKE_DEFAULT_CATALOG lake extraEnv
ANDLAKE_S3_BUCKET andlake-app extraEnv
ANDLAKE_TENANT_ID (required) pre_spawn_hook
ANDLAKE_ACCESS_TOKEN (required) pre_spawn_hook

Development

pip install -e ".[dev]"
pytest

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

andlake-0.1.0.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

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

andlake-0.1.0-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file andlake-0.1.0.tar.gz.

File metadata

  • Download URL: andlake-0.1.0.tar.gz
  • Upload date:
  • Size: 12.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for andlake-0.1.0.tar.gz
Algorithm Hash digest
SHA256 43ce419c5d24f78cc341ca26c63ee86d0f6048b89762f9ef0f71cfc1bfa86dc3
MD5 b7708d621f49c0d8677e693b3c271372
BLAKE2b-256 5762df4d321090fb0a687a3619c2471fe9466fa72c85f39e396e71e185e28527

See more details on using hashes here.

File details

Details for the file andlake-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: andlake-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 13.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for andlake-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4259d47dcf817e03a1075f488058f8d7573c5e1751484452b2ad630c58d9995e
MD5 fac8f028587816ec197cc9f25f22ac32
BLAKE2b-256 e6ef7395c754e2833d8449e37b4b3429c58e685d3b642ba6abf918a4ec52d006

See more details on using hashes here.

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