Skip to main content

A Python Beaker client

Project description




beaker-py

A lightweight, standalone, pure Python client for Beaker


CI PyPI Documentation Status License

Features

🪶 Lightweight

  • Minimal dependencies.
  • Only pure-Python dependencies.
  • Communicates directly with the Beaker server via HTTP requests (Beaker CLI not required).

💪 Robust

  • Automatically retries failed HTTP requests with exponential backoff.
  • Runtime data validation.
  • High test coverage.

📓 Exhaustively-typed and documented

  • Thorough data model for all input / output types.
  • Every expected HTTP error from the Beaker server is translated into a specific exception type.

Quick links

See also 👇

Installing

Installing with pip

beaker-py is available on PyPI. Just run

pip install beaker-py

Installing from source

To install beaker-py from source, first clone the repository:

git clone https://github.com/allenai/beaker-py.git
cd beaker-py

Then run

pip install -e .

Quick start

If you've already configured the Beaker command-line client, beaker-py will find and use the existing configuration file (usually located at $HOME/.beaker/config.yml). Otherwise just set the environment variable BEAKER_TOKEN to your Beaker user token.

Either way, you should then instantiate the Beaker client with .from_env():

from beaker import Beaker

beaker = Beaker.from_env(default_workspace="my_org/my_workspace")

The API of beaker-py is meant to mirror - as closely as possible - the API of the Beaker CLI. For example, when you do this with the CLI:

beaker dataset create --name foo .

The beaker-py equivalent would be:

beaker.dataset.create("foo", ".")

See the API Docs to learn about the Beaker client's methods.

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

beaker_py-1.32.1.tar.gz (74.5 kB view details)

Uploaded Source

Built Distribution

beaker_py-1.32.1-py3-none-any.whl (88.0 kB view details)

Uploaded Python 3

File details

Details for the file beaker_py-1.32.1.tar.gz.

File metadata

  • Download URL: beaker_py-1.32.1.tar.gz
  • Upload date:
  • Size: 74.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.18

File hashes

Hashes for beaker_py-1.32.1.tar.gz
Algorithm Hash digest
SHA256 01668f5629958bd86163c064833363b28c64597c6bcc16b6df4d64f79695b92a
MD5 f654008933727b709cae04fd1db17e76
BLAKE2b-256 a22a2e7eb097ab18c8ff31746f2e56ae8073fa9d5f0a34c868250e6b56b47c6d

See more details on using hashes here.

File details

Details for the file beaker_py-1.32.1-py3-none-any.whl.

File metadata

  • Download URL: beaker_py-1.32.1-py3-none-any.whl
  • Upload date:
  • Size: 88.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.18

File hashes

Hashes for beaker_py-1.32.1-py3-none-any.whl
Algorithm Hash digest
SHA256 af969993f0dbc870ae9c08d776305cfcbc56a7b0d93cb137ccf3243a06dc6083
MD5 3190d02da5c1cff789e5a987b5dd4cc1
BLAKE2b-256 f0c6de75dbf647579ea431cee35ed6e00097016817b89d7cbe6eac08a1317406

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