Skip to main content

Bond CLI

Project description

PyPI version

Bond Command Line Interface

EDIT: This project is in a beta state. We released it on the principle of release early & often. It is here just in case it benefits a member of the Bond Home community. Your mileage may vary!

Purpose

This tool exists to make it easy to manipulate a Bond from a command line, for use by:

  • Bond community
  • internal use in engineering and customer support

Installation

Install with

pip install bond-cli

Getting Started

Find Bonds on local network:

bond discover

Select a Bond and set the token so we can go deeper:

bond select <your Bond's ID or a prefix>

If your Bond's token is unlocked, select will retrieve and store it. Otherwise, you have a couple options. You can unlock the token yourself (a power cycle is the easiest way, it'll be unlocked for a period after a reboot), and run the following to automatically retrieve and store it:

bond token

Or, you can manually set the token, which you could find in the Bond Home app in the Bond's settings screen.

bond token <your Bond's token>

Now that you've selected a Bond and stored its token, you're ready to interact with it.

Check its firmware version:

bond version

Device Management

Create a template device:

bond devices create --name "Formidable Fan" --location "Bedroom" --template A1 --addr 101 --freq 300000 --bps 1000 --zero_gap 1234

You can then see the fan on your Bond Home app.

List existing devices:

bond devices list

Delete one or more devices:

bond devices delete <DEVICE1_ID> <DEVICE2_ID>

Device Groups

Create a device group:

bond groups create --name "All Shades" <BOND1_ID>:<DEVICE1_ID> <BOND2_ID>:<DEVICE1_ID> <BOND2_ID>:<DEVICE2_ID> 

List the existing device groups:

bond groups list

List the device groups on a single Bond (may not represent the whole group):

bond groups list --bond-id <BOND_ID>

Live Logging

You can also start a livelog:

bond livelog --level info

Upgrade Your Bond

You can upgrade your selected bond:

bond upgrade beta

Getting Help

Get more help with:

bond -h

or you can get help with any subcommand

bond select -h

Contributing

Bug reports and feature requests in the form of issues and pull requests are strongly encouraged!

To develop locally, you can clone the repository from github, remove the package if already present, then install it to pip in local editable mode:

git clone git@github.com:bondhome/bond-cli.git
cd bond-cli
pip uninstall bond-cli
pip install -e "."

Now all changes made in your local copy of bond-cli will be reflected in the bond executable.

Release Procedure

To make a release, bump the version number in setup.py on trunk, then make an annotated tag

git tag -a "v1.8.7"

with a version matching that in setup.py. You'll be prompted to write some release notes. Alternatively, use the Github repository's releases interface to create a release.

Upon pushing the tag or publishing the release, CI will deploy to PyPi.

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

bond-cli-0.3.0.tar.gz (19.4 kB view details)

Uploaded Source

Built Distribution

bond_cli-0.3.0-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file bond-cli-0.3.0.tar.gz.

File metadata

  • Download URL: bond-cli-0.3.0.tar.gz
  • Upload date:
  • Size: 19.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for bond-cli-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5106186e441f99a4c740f26f0329d5bff322d92fb286b3f587bb56d085010f0b
MD5 31fbf4eb4e533d514a9552178c5c3008
BLAKE2b-256 01e24fe813572750bf75997a87c00eedcf173ef7b24ec75148d26bbc21c5fb44

See more details on using hashes here.

File details

Details for the file bond_cli-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: bond_cli-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for bond_cli-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 97be954b8d7165928dcf29ab3a6e043cc2e9af8a0fa3c2ce105fec0c01649b10
MD5 a18a6463798156f4b4676f828c0fd80d
BLAKE2b-256 173338702746cadf20b3db0adce7801b447d0a4daeed00ad8a532f6e509ef6f7

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