Paradrop Developer Tools
Project description
Paradrop Developer Tools
The Paradrop developer tools (pdtools
) make it easy to interact with
the Paradrop edge and cloud APIs. Use it to configure or install software
on a Paradrop node or develop and release your own applications, called
"chutes", to the Paradrop Chute Store. pdtools
can be used as a command
line utility and can also be imported into Python code as a library.
What is Paradrop?
Paradrop is a software platform for edge computing that brings the cloud closer to home by enabling applications to exist on networking equipment such as Wi-Fi routers.
By running services closer to data sources and mobile devices, applications can take advantage of low network latency and make efficient use of bandwidth. Additionally, services running on Paradrop can protect the privacy of users by processing sensitive data near its source rather than transmitting it over the wide area network. Some services can even remain functional when the Internet connection is down.
Installation
The latest version is available on PyPi.
Install it with pip
:
pip install pdtools
Using the command above will install pdtools
as a local Python
module. On Linux, you can also install pdtools
as a global package
to make it available as a command. That means you will be able to use
pdtools
in your shell instead of typing python -m pdtools
.
sudo pip install pdtools
Usage
pdtools
includes an extensive command line utility for interacting with
Paradrop nodes and our cloud controller. You can explore the commands
available with the -h
or --help
flags.
python -m pdtools --help
Use the interactive tool to begin developing a new chute:
python -m pdtools chute initialize
Install a chute on a node if you know its IP address:
python -m pdtools node --target <node-ip-address> install-chute
List the chutes installed on a node:
python -m pdtools node --target <node-ip-address> list-chutes
List chutes available in the Paradrop Chute Store:
python -m pdtools store list-chutes
Install a chute on a node from the chute store. Here you must use the name assigned to the node on paradrop.org:
python -m pdtools store install-chute <chute-name> <node-name>
All of the functions available through the command line are also available for scripting in your own Python code. For example, the following Python code queries a node for the list of chutes installed and then makes a request to remove one of them:
>>> NODE_ADDRESS = "192.0.2.1" # Use the IP address of your node.
>>> from pdtools import ParadropClient
>>> client = ParadropClient(NODE_ADDRESS)
>>> for chute in client.list_chutes():
... print(chute['name'])
...
node-hello-world
wiki
python-hello-world
sticky-board
>>> client.remove_chute('node-hello-world')
{u'change_id': 1}
Instructions for Maintainers
Use the following commands in the directory containing this file and setup.py to build the packages:
python setup.py sdist
python setup.py bdist_wheel --universal
Use the following command to upload the packages to PyPi:
twine upload dist/*
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
Built Distribution
File details
Details for the file pdtools-0.13.2.tar.gz
.
File metadata
- Download URL: pdtools-0.13.2.tar.gz
- Upload date:
- Size: 41.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/2.7.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6bec563e3705ff5d59dc77c439e1d09cc3e6893f87933ec3c302be39191baa45 |
|
MD5 | 7ca95469e83ece0704e47103825575f9 |
|
BLAKE2b-256 | 972c3b65df5e7dfdd66229a78fa668aa1a4d8ecafc8006902f1fb05add9633de |
File details
Details for the file pdtools-0.13.2-py2.py3-none-any.whl
.
File metadata
- Download URL: pdtools-0.13.2-py2.py3-none-any.whl
- Upload date:
- Size: 49.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/2.7.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8bb356c3882cf757b100976d2c3aaacfd05a71e74ab0a711390e82cdd654345c |
|
MD5 | 68e09183e3b525d20059e995f9252034 |
|
BLAKE2b-256 | 370aeb41d6a9090fc351490835504f8831b5b3152188be9379cf52759e64f542 |