SDK for authoring Improvado custom pipeline workflows on Temporal
Project description
improvado-pipeline-sdk
SDK for authoring custom data pipeline workflows on Temporal.
Provides type definitions, helper functions, and constants for building ETL/ELT pipelines that run on Improvado's Temporal infrastructure.
Install
pip install improvado-pipeline-sdk
Usage
Workflow code
import dataclasses
from temporalio import workflow
with workflow.unsafe.imports_passed_through():
from pipeline_sdk.types import (
DataRef,
DateRangeRequest,
DateRangeType,
)
from pipeline_sdk.activities import (
les_extract,
ch_load,
prepare_credentials,
cleanup_credentials,
)
@dataclasses.dataclass(frozen=True)
class MyPipelineParams:
connector_id: int
@workflow.defn(sandboxed=False, name="MyPipeline")
class MyPipelineWorkflow:
@workflow.run
async def run(self, params: MyPipelineParams) -> dict:
result = await les_extract(
connector_id=params.connector_id,
data_source="facebook",
report_type="ad_insights",
date_range=DateRangeRequest(
date_range_type=DateRangeType.MANUAL,
params={"date_from": "2026-01-01", "date_to": "2026-03-31"},
),
)
return {"data_ref": result.data_ref.uri}
Activity code
from temporalio import activity
from pipeline_sdk.runtime import (
read_pipeline_secret,
get_current_tenant,
PipelineState,
)
@activity.defn
async def my_activity(creds) -> dict:
tenant = get_current_tenant()
secret = await read_pipeline_secret(creds)
# secret.s3, secret.storage, secret.connections
return {"tenant": tenant.agency_uuid}
Worker / client setup
from pipeline_sdk.tenant import (
TenantInterceptor, # worker side
TenantClientInterceptor, # client side
TenantID,
)
Type checking
pyright my_workflow.py
ruff check my_workflow.py
ruff format my_workflow.py
Both pyright and ruff are included as dependencies.
Package structure
| Module | Purpose |
|---|---|
pipeline_sdk.types |
Pure, Temporal-serializable data types and enums — DataRef, TenantID, Cluster, DateRangeRequest, DateRangeType, PipelineCredentials, PipelineSecret, S3Credentials, StorageCredentials, LesActivityWithS3Result, PipelineLoadResult. Safe to import from either workflow or activity code. |
pipeline_sdk.activities |
Predefined workflow-side wrappers — les_extract, ch_load, prepare_credentials, cleanup_credentials. Import inside workflow.unsafe.imports_passed_through(). Custom activities defined in your own module inherit the workflow's task queue — do not pass task_queue to workflow.execute_activity. |
pipeline_sdk.runtime |
Activity-side helpers — read_pipeline_secret, PipelineState, get_current_tenant, plus VAULT_ADDR / VAULT_MOUNT_POINT for Vault config overrides. |
pipeline_sdk.tenant |
Tenant propagation infrastructure — TenantInterceptor, TenantClientInterceptor, build_tenant_headers, plus TenantID / get_current_tenant re-exports. |
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file improvado_pipeline_sdk-0.3.0.tar.gz.
File metadata
- Download URL: improvado_pipeline_sdk-0.3.0.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9133ca9be19da553f039ed8201e5faf686a1c8834c1d30f3337c4e0daa0c500a
|
|
| MD5 |
660135d10a01f25348ec123816dba1d2
|
|
| BLAKE2b-256 |
51c7b021b66b23f9abd698daf9e0636f79bcbd70d52bbf04bbab8fa988211f26
|
File details
Details for the file improvado_pipeline_sdk-0.3.0-py3-none-any.whl.
File metadata
- Download URL: improvado_pipeline_sdk-0.3.0-py3-none-any.whl
- Upload date:
- Size: 17.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
496d84ddd3de0d2cf593ace96411bb50599e0f9ca5af04ad40a1075c2aac2d86
|
|
| MD5 |
26025450ab38a0771f8407d007474e4c
|
|
| BLAKE2b-256 |
51979c9e3bfe757bc711211bb6e01cf9731aff233670b6b096e36d490e7137a4
|