An unaffiliated python wrapper for dbt Cloud APIs
Project description
An unaffiliated python interface for dbt Cloud APIs
Documentation: https://dbtc.dpguthrie.com
Interactive Demo: https://dpguthrie-dbtc-streamlit-home-yy7c0b.streamlit.app/
Source Code: https://github.com/dpguthrie/dbtc
V2 Docs: https://docs.getdbt.com/dbt-cloud/api-v2
V3 Docs: https://docs.getdbt.com/dbt-cloud/api-v3
Overview
dbtc is an unaffiliated python interface to various dbt Cloud API endpoints.
This library acts as a convenient interface to two different APIs that dbt Cloud offers:
- Cloud API: This is a REST API that exposes endpoints that allow users to programatically create, read, update, and delete resources within their dbt Cloud Account.
- Metadata API: This is a GraphQL API that exposes metadata generated from a job run within dbt Cloud.
Requirements
Python 3.7+
- Requests - The elegant and simple HTTP library for Python, built for human beings.
- sgqlc - Simple GraphQL Client
- Typer - Library for building CLI applications
Installation
pip install dbtc
Basic Usage
Python
The interface to both APIs are located in the dbtCloudClient
class.
The example below shows how you use the cloud
property on an instance of the dbtCloudClient
class to to access a method, trigger_job_from_failure
, that allows you to restart a job from its last point of failure.
from dbtc import dbtCloudClient
# Assumes that DBT_CLOUD_SERVICE_TOKEN env var is set
client = dbtCloudClient()
account_id = 1
job_id = 1
payload = {'cause': 'Restarting from failure'}
run = client.cloud.trigger_job_from_failure(
account_id,
job_id,
payload,
should_poll=False,
)
# This returns a dictionary containing two keys
run['data']
run['status']
Similarly, use the metadata
property to retrieve information about certain resources within your project - the example below shows how to retrieve metadata from models related to the most recent run for a given job_id
.
from dbtc import dbtCloudClient
client = dbtCloudClient()
job_id = 1
models = client.metadata.get_models(job_id)
# Models nested inside a couple keys
models['data']['models']
# This is a list
models['data']['models'][0]
CLI
The CLI example below will map to the python cloud example above:
dbtc trigger-job-from-failure \
--account-id 1 \
--job-id 1 \
--payload '{"cause": "Restarting from failure"}' \
--no-should-poll
Similarly, for the metadata example above:
dbtc get-models --job-id 1
If not setting your service token as an environment variable, do the following:
dbtc --token this_is_my_token get_models --job-id 1
License
This project is licensed under the terms of the MIT license.
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
File details
Details for the file dbtc-0.7.0.tar.gz
.
File metadata
- Download URL: dbtc-0.7.0.tar.gz
- Upload date:
- Size: 42.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.12.0 Linux/6.2.0-1016-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 231fd2f50e9c7dc7d619bd0929cc494ec904088de5518fe8aaee1b9d9f4ef3ea |
|
MD5 | 6960d21e537d34b641ef2f1df701fcc9 |
|
BLAKE2b-256 | 5768db85c487eacf73502a90737ac3b7981907e232a8e818bed22a1d1c6899c3 |
File details
Details for the file dbtc-0.7.0-py3-none-any.whl
.
File metadata
- Download URL: dbtc-0.7.0-py3-none-any.whl
- Upload date:
- Size: 44.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.1 CPython/3.12.0 Linux/6.2.0-1016-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a86f56cac0e066afbefa0de1611b8d74ac811920be76d02ffd5fc57d4688c9ed |
|
MD5 | 000d1541b7566cd5436476d267754f4f |
|
BLAKE2b-256 | af6547bd9140a673ed23bc4061e5494600ef4fc64fd0af1e2df986cc19181c4c |