Skip to main content

A python CLI client for accessing Bioto data

Project description

PyClient

Python Client for retrieving Bioto sensor data

Goals

Session management

  • create session via device login to get a valid access token

Retrieving sensor data

  • find a garden
  • subscribe to that garden
  • see subscribtion state for that garden (pending/approved/declined)
  • get an overview of your gardens
  • retrieve sensor data from garden devices

Getting started

There are two ways of installing this client. The first one using pip:

% pip install --user bioto-client

The second option is useful when developing the client. Git clone the project and use make for installation. This will setup a virtual python environment managed via poetry.

% make install
% poetry shell

How to use

Tip Use bioto-client --help to see other available commands

Start a user session

A user session is valid for 24h. When expired you're requested to create a new session. This can be done as follows:

# Call the client with the `user` command to assert a valid session
% bioto-client user

Loading session

Not logged in, please take the following steps:

1. On your computer or mobile device navigate to: https://biotoco.eu.auth0.com/activate?user_code=NEWT-OKEN
2. Enter the following code:  NEWT-OKEN

Succesfully logged in.

Bioto CLI client: 1.2.3
Environment: prod
Session token ***5OFd09w

Find a garden

Gardens can be found by name, the command to do this is:

% bioto-client search-garden {name}

Subscribe to a garden

To gain access to the data of this garden you need to subscribe to this garden using its ID:

% bioto-client subscribe-garden {garden_id}

This will create a subscription request which only the mainter(s) can approve. To check the state of your subscription see:

% bioto-client subscriptions

Read device data

Reading a device is done by device ID, these can be found via the garden command. Note that a garden might contain multiple devices.

To get the latest hourly readings for the last 24h issue the following command:

% bioto-client device {device_id}

To get these readings for a sepecific date apply a date option. The following formats are allowed: [%Y-%m-%d | %Y-%m-%dT%H:%M:%S | %H:%M:%S]:

% bioto-client device {device_id} --date={date}

And to limit or increase the number of hours returned add the hours option:

% bioto-client device {device_id} --hours={hours_limit}

Improve the client

If you want to improve the client or add something which you think is missing to the project you can either open an issue or develop the feature yourself and open a pull request with your changes.

To get started clone this project and create a branch. Now fix the bug or create the feature you want and write some tests for it to prove it works. This can be done by executing:

% make check

Note This will run both tests and linters, use make test when you're in red - green - refactor mode

When the checks are all passing, please open a PR

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

bioto_client-0.1.7.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bioto_client-0.1.7-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file bioto_client-0.1.7.tar.gz.

File metadata

  • Download URL: bioto_client-0.1.7.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.9 Darwin/22.3.0

File hashes

Hashes for bioto_client-0.1.7.tar.gz
Algorithm Hash digest
SHA256 d99a1454f5f9782c5fdcdda87a22488d4ac4d2c7a8eff2396975f0bb2afe58b4
MD5 e2037233aad8b39b8ad6ec00253938c1
BLAKE2b-256 955b3f27518db5d0aba27907cd16a27704888afa2c4ee4ee79c28fec7889f310

See more details on using hashes here.

File details

Details for the file bioto_client-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: bioto_client-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 11.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.9 Darwin/22.3.0

File hashes

Hashes for bioto_client-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 18e7fb3ac8f829ba36b1e9e7dade47119b1455505741c696cc73dbf1c9908344
MD5 cc6b185f860b5f0483281aa3b78f27da
BLAKE2b-256 9bd8727a505ea07643ce3ef54b151d18a9eb1121f78edb8653d6f66305a6ef1e

See more details on using hashes here.

Supported by

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