Skip to main content

Pythonic HTTP client for Cube.js REST API (sync + async)

Project description

cube-http-client

Pythonic HTTP client for Cube.dev REST API (sync + async support)

Installation

pip install cube-http-client

Quickstart

import cube_http

cube = cube_http.Client({"url": "...", "token": "..."})

# get metadata
meta = cube.v1.meta()

# load query results
results = cube.v1.load({
    "measures": ["..."],
    "dimensions": ["..."],
})

# compile to SQL
compiled_sql = cube.v1.sql({
    "measures": ["..."],
    "dimensions": ["..."],
})

Support Coverage

Endpoint Description Supported?
/v1/load Get the data for a query.
/v1/sql Get the SQL Code generated by Cube to be executed in the database.
/v1/meta Get meta-information for cubes and views defined in the data model. Information about cubes and views with public: false will not be returned.
/v1/run-scheduled-refresh Trigger a scheduled refresh run to refresh pre-aggregations.
/v1/pre-aggregations/jobs Trigger pre-aggregation build jobs or retrieve statuses of such jobs.
/readyz Returns the ready state of the deployment.
/livez Returns the liveness state of the deployment. This is confirmed by testing any existing connections to dataSource. If no connections exist, it will report as successful.

Usage

Synchronous

import cube_http

cube = cube_http.Client(...)

Asynchronous

import cube_http

cube = cube_http.AsyncClient(...)

Error handling

Error classes are available for each endpoint. For example, handling an API error when calling /v1/meta endpoint:

import cube_http
from cube_http.exc.v1 import V1MetaError

cube = cube_http.Client(...)

try:
    meta = cube.v1.meta()
except V1MetaError as e:
    print(e)

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

cube_http_client-0.3.2.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

cube_http_client-0.3.2-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

Details for the file cube_http_client-0.3.2.tar.gz.

File metadata

  • Download URL: cube_http_client-0.3.2.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.5 Darwin/23.5.0

File hashes

Hashes for cube_http_client-0.3.2.tar.gz
Algorithm Hash digest
SHA256 5d9c2d67767e7ff5e344842b5d180134ae1ec83ec5bd9ce43f0c50d5418bcaeb
MD5 817939c6aaaf596d55255286d334eda5
BLAKE2b-256 85c3d6253ed9bf30605f6eec06c25a498155207738b5f614ce2a281bda970ad9

See more details on using hashes here.

File details

Details for the file cube_http_client-0.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for cube_http_client-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 934c51432ddb09156d6dee4db634c8edfd1fccfab38ae9027563f536caaaa289
MD5 c3a11d8e2d573bf4a7f680c703b8306e
BLAKE2b-256 e22bad0d49360085a78e33b03e7ab74ff942c504b2660ac80701f166a54ab569

See more details on using hashes here.

Supported by

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