Python SDK for oleander: query lake, list and launch Spark jobs
Project description
oleander Python SDK
Use the oleander API from Python: run lake queries, list Spark jobs, and launch Spark jobs.
Install
pip install oleanderhq-sdk
Get your API key
Create an API key in oleander settings, or run oleander configure if you use the CLI. You can pass the key when creating the client or set the OLEANDER_API_KEY environment variable.
Quick start
import asyncio
from oleander_sdk import Oleander
async def main():
oleander = Oleander()
result = await oleander.list_spark_jobs()
print(result.artifacts)
asyncio.run(main())
API
All methods are async. Use await when calling them.
Query (lake)
Run a SQL query against the oleander lake. The second parameter is optional; save defaults to False. Use save=True to persist results as a table.
from oleander_sdk import Oleander, QueryOptions
oleander = Oleander()
result = await oleander.query(
"SELECT * FROM oleander.default.flowers LIMIT 10",
)
print(result.results.columns, result.results.rows)
print(result.row_count, result.execution_time)
if result.saved_table_name:
print("Saved to:", result.saved_table_name)
List Spark jobs
List your Spark artifacts. Options: limit (default 20), offset (default 0).
from oleander_sdk import Oleander, ListSparkJobsOptions
oleander = Oleander()
result = await oleander.list_spark_jobs()
print(result.artifacts, result.has_more)
next_page = await oleander.list_spark_jobs(ListSparkJobsOptions(offset=20))
Launch Spark job
Submit a Spark job. Required: namespace, name, entrypoint. cluster defaults to "oleander". The legacy script_name argument is still accepted as an alias for entrypoint.
from oleander_sdk import Oleander, SparkJobSubmitOptions
oleander = Oleander()
result = await oleander.submit_spark_job(SparkJobSubmitOptions(
namespace="my-namespace",
name="my-job-name",
entrypoint="my_script.py",
))
print("Run ID:", result.run_id)
To target an external cluster, set cluster and provide the cluster-specific properties that match the current API:
result = await oleander.submit_spark_job(SparkJobSubmitOptions(
cluster="emr-prod",
namespace="my-namespace",
name="my-job-name",
entrypoint="s3://bucket/jobs/main.py",
args=["--date", "2026-03-11"],
py_files="s3://bucket/deps.zip",
packages=["org.example:my-lib:1.0.0"],
))
Wait for a run to finish
Submit and poll until the run completes. Optional: poll_interval_ms (default 10000), timeout_ms (default 600000).
from oleander_sdk import Oleander, SubmitSparkJobAndWaitOptions
oleander = Oleander()
result = await oleander.submit_spark_job_and_wait(SubmitSparkJobAndWaitOptions(
namespace="my-namespace",
name="my-job-name",
entrypoint="my_script.py",
))
print(result.run_id, result.state) # COMPLETE | FAIL | ABORT
Get run status
run = await oleander.get_run(run_id)
print(run.state, run.duration)
Get Spark cluster information
cluster = await oleander.get_spark_cluster("emr-prod")
print(cluster.type, cluster.properties)
Typed error handling
The SDK raises structured errors for HTTP failures:
OleanderHttpErrorfor any non-2xx response (status,method,path,url,body,api_error,api_details)RunNotFoundError(subclass ofOleanderHttpError) whenget_run(run_id)returns 404
from oleander_sdk import Oleander, OleanderHttpError, RunNotFoundError
try:
await oleander.get_run(run_id)
except RunNotFoundError as err:
print("Run is not visible yet:", err.run_id)
except OleanderHttpError as err:
print(err.status, err.path, err.api_error or err.api_details)
Options
- Constructor:
Oleander(api_key=..., base_url=...). Omitapi_keyto useOLEANDER_API_KEY. Setbase_urlto use a different endpoint (e.g.http://localhost:3000). - Models: The package exports Pydantic models (e.g.
OleanderOptions,SparkJobSubmitOptions) if you want to validate config or options yourself. - Errors: The package exports
OleanderHttpErrorandRunNotFoundErrorfor structured error handling.
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
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 oleanderhq_sdk-0.3.0.tar.gz.
File metadata
- Download URL: oleanderhq_sdk-0.3.0.tar.gz
- Upload date:
- Size: 9.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
390964a150859383f26319bba83e31041357ea5cfc2685ed624760828b969729
|
|
| MD5 |
14bad73200cc99a8d4c1bdd9fed440f2
|
|
| BLAKE2b-256 |
4d90ec0ad5a645b8cbf19989c4c5ed8570175b26148798de4395b74afd2771dd
|
File details
Details for the file oleanderhq_sdk-0.3.0-py3-none-any.whl.
File metadata
- Download URL: oleanderhq_sdk-0.3.0-py3-none-any.whl
- Upload date:
- Size: 9.2 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 |
6db8acbe35014a3b90c10989fec6a42f854922a5a12bbe89d4ef172a6c8a55fb
|
|
| MD5 |
9867d1d1adfaddfe6f1c28df3e84f9d6
|
|
| BLAKE2b-256 |
576dbd1f43f8bfb59009615cba3200abc1134eb038b6622c2083f0faf2381be5
|