Skip to main content

SDK to interact with the boum API

Project description

Boum Python SDK

Status: GitHub Actions

Overview

This project provides an api client to interact with the Boum API and abstractions to simplify interactions with the underlying resources.

Installation

The package is available on PyPI, and can be installed with pip or similar tools:

    python -m pip install boum
    poetry add boum
    pipenv install boum
    ...

Usage

API Client

The API client models the topology of the API and provides a class hierarchy that is organized in the same way as the endpoint paths. Email and password or a token are required to use it.

The client can either connect to the API with client.connect() and client.disconnect()methods or it can be used as a context manager as with client: ... In the former case the disconnect method should be called explicitly in the end.

>>> from boum.api_client.v1.client import ApiClient
>>> from boum.api_client.v1.models import DeviceModel
>>> 
>>> client = ApiClient(email, password, base_url=base_url)
>>> # or ApiClient(refresh_token='token', base_url=base_url)
>>>
>>> with client:
...     # Get call to the devices collection
...     device_ids = client.root.devices.get()
...     # Get call to a specific device 
...     device_states = client.root.devices(device_id).get()
...     # Patch call to a specific device
...     client.root.devices(device_id).patch(DeviceModel())
...     # Get call to a devices data
...     data = client.root.devices(device_id).data.get()

Resource Abstractions

The resource abstractions provide a more intuitive interface to interact with the underlying resources.

>>> from datetime import time, datetime, timedelta
>>> import pandas as pd
>>> from boum.api_client.v1.client import ApiClient
>>> from boum.resources.device import Device
>>> from boum.api_client.v1.models import DeviceStateModel
>>>
>>> client = ApiClient(email, password, base_url=base_url)
>>> # or ApiClient(refresh_token='token', base_url=base_url)
>>>
>>> with client:
...    # Get available device ids
...    device_ids = Device.get_device_ids(client)
...    # Create a device instance
...    device = Device(device_id, client)
...    # Remove device claim
...    # device.unclaim()
...    # Claim a device
...    # device.claim()
...    # Set desired device state
...    desired_device_State = DeviceStateModel(
...        pump_state=True,
...        refill_time=time(3, 32),
...        refill_interval_days=3,
...        max_pump_duration_minutes=5
...    )
...    device.set_desired_device_state(desired_device_State)
...    # Get reported and desired device state
...    reported, desired = device.get_device_states()
...    # Get device telemetry data
...    data = device.get_telemetry_data(start=datetime.now() - timedelta(days=1),
...        end=datetime.now())
...    # Convert telemetry data to pandas dataframe
...    df = pd.DataFrame(data)

Jupyter Notebook Demo

A Jupyter notebook demo is available here.

Loging

The SDK uses the standard python logging module.

Development

Dependecy management

Poetry is used for depency management and publishing.

Versioning

Versioning is done using bumpver with semantic versioning When the version is updated, a new tag is created and pushed to the remote repository.

Testing

Unit tests

These are completely self-contained and have no external dependencies.

IMPORTANT: There are fixtures that model the API responses and expected calls. These mnust be kept up to date with the API, otherwise the unit tests will not test the correct behavior.

End-to-end tests

These test the entire flow from user facing python classes to the underlying api calls. They require an instance (fake or real) of the API to run against. They also require a registered user with a clamied device. API Base URL, email and password are required as environmental variables.

    BOUM_SDK_TEST_BASE_URL
    BOUM_SDK_TEST_EMAIL
    BOUM_SDK_TEST_PASSWORD
    BOUM_SDK_TEST_DEVICE_ID
    BOUM_SDK_TEST_USER_ID

Doctests

Part of the end-to-end tests are document tests executed using doctest. These tests ensure that all the examples in this README and in the docstrings are up-to-date and working.

CI/CD

Integration

The GitHub action workflow .github/workflows/checks_on_push_to_branch.yml is triggered on every push on a branch except main. It provides the following checks:

  • Unit and end-to-end/contract tests with pytest
  • Linting with pylint
  • Security checks with bandit

The repository settings require that all checks pass before a pull request can be merged.

Deployment

The GitHub action workflow .github/workflows/deploy_on_push_to_main.yml is triggered on every push to main. It runs a test deployment to the test PyPI repository.

The GitHub action workflow .github/workflows/deploy_on_release.yml is triggered on a tag with the format v*.*.* and runs a deployment to the production PyPI. It is recommended to set these tags using the GitHub release feature.

Technical debt

  • Doctest requires a specific format to make examples in documentation executable. This makes the examples in this README harder to copy and paste. There exist other packages and add-ons that could be used to make the examples easier to manage.

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

boum-1.4.0.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

boum-1.4.0-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

Details for the file boum-1.4.0.tar.gz.

File metadata

  • Download URL: boum-1.4.0.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.10.12 Linux/5.15.0-1041-azure

File hashes

Hashes for boum-1.4.0.tar.gz
Algorithm Hash digest
SHA256 78ba52921b75ed3796ab73ab83e7d76bdfc37a16e45cac8d755e45750e7d2c0b
MD5 0d9f598faa258ab209505f75870fc335
BLAKE2b-256 0e040f784a9a620964b752a5d579f872f66c4d085d6433f22fbce6139e9b02dd

See more details on using hashes here.

File details

Details for the file boum-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: boum-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 14.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.10.12 Linux/5.15.0-1041-azure

File hashes

Hashes for boum-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 032b79c2b32674cf3a2e7d8cae3c8d9b2a3b123ca4b6fe1378a3a70a8b689990
MD5 c985156df16b5a4c10e5e5c6ebcdc83e
BLAKE2b-256 b51e8b41dd0c983b9380f3fea6a37ba44643570c10f1bea99ee4a0187f958938

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