Skip to main content

Paradrop Developer Tools

Project description

Paradrop Developer Tools

Documentation Status

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pdtools-0.13.2.tar.gz (41.0 kB view details)

Uploaded Source

Built Distribution

pdtools-0.13.2-py2.py3-none-any.whl (49.6 kB view details)

Uploaded Python 2 Python 3

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

Hashes for pdtools-0.13.2.tar.gz
Algorithm Hash digest
SHA256 6bec563e3705ff5d59dc77c439e1d09cc3e6893f87933ec3c302be39191baa45
MD5 7ca95469e83ece0704e47103825575f9
BLAKE2b-256 972c3b65df5e7dfdd66229a78fa668aa1a4d8ecafc8006902f1fb05add9633de

See more details on using hashes here.

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

Hashes for pdtools-0.13.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8bb356c3882cf757b100976d2c3aaacfd05a71e74ab0a711390e82cdd654345c
MD5 68e09183e3b525d20059e995f9252034
BLAKE2b-256 370aeb41d6a9090fc351490835504f8831b5b3152188be9379cf52759e64f542

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