Skip to main content

Upvest CLI: CLI for using the Upvest CLI

Project description

Use the Upvest API from the command line!

Installation

To install the Upvest CLI, using Python 3.6+:

pip install upvest-cli

or alternatively directly from the repository:

pip install https://github.com/toknapp/upvest-cli

Basic usage

There are three ‘layers’ of the upvest CLI commands.

  • upvest the starting point for commands to configure which endpoint to talk to

  • app or user to decide between using the application (tenant) API or the user (clientele) API and include the necessary credentials

  • commands : such as ‘createuser’ or ‘listassets’ or ‘createwallet’

For example:

Create a user:

upvest -e https://api.playground.upvest.co/ app -K keyid -S keysecret -P keypassphrase createuser username password

Configuration file

A configuration file will help to fill in most command line arguments, thus avoiding having to repeat several credentials and ensuring secrets and passwords do not linger in your bash history.

--help on each subcommand will show which environment variables to set in place of commandline arguments, however a configuration file can also be used.

This will be loaded by default from upvest.yaml or .upvest.yaml however this can be configured using the --configfile or -c flag to pass in the path to the configuration file.

The configuration file should take the following form:

endpoints:
  my_example_name:
    base_url: https://api.playground.upvest.co/
    api_key: ...
    api_key_secret: ...
    api_key_passphrase: ...
    oauth_client_id: ...
    oauth_client_secret: ...

This can then be referenced from the command line to switch between environments or applications as you define them:

upvest -e my_example_name user -l username -w password listwallets

Example Usage

Here is a quick guide on how to create a user, create a wallet for that user, then receive and send to and from it. Once you have created an API key at https://login.upvest.co, and created a configuration file as above, take the following steps.

Step 1 - Create a user

Create a single user with the given username and password:

upvest -e my_example_name app create user test_username test_password

Step 2 - Create a wallet

First list the assets available for your application to use:

upvest -e my_example_name app listassets

Symbol |                                        Name | ID
-------| ------------------------------------------- | ------------------------------------
   BTC |                           Bitcoin (testnet) | a3c18f74-935e-5d75-bd3c-ce0fb5464414
  COIN |                                Example coin | cfc59efb-3b21-5340-ae96-8cadb4ce31a8
   ETH |                               Ether (Kovan) | 1e84a803-006a-55b3-9ff8-db46f2dedeca
   ETH |                             Ether (Ropsten) | deaaa6bf-d944-57fa-8ec4-2dd45d1f5d3f

Then create a wallet for the test user using one or more asset IDs from that list. In this example, creating an Ether Ropsten wallet:

upvest -e my_example_name user --login test_username --password test_password createwallet deaaa6bf-d944-57fa-8ec4-2dd45d1f5d3f

2bd5f676-e86c-4cb4-bdaf-4afefffed3f4 0x16edb0e94d0baa4d0a528b501e9dcffbd7752d5d

This returns firstly the unique ID of the wallet, as well as the public address.

Step 3 - Receive tokens

Go to a public faucet - for example, the public ropsten faucet - and send to the address of the user’s wallet.

Now, once the transfer has been confirmed, you can see the balances of the user’s wallet:

upvest -e my_example_name user --login test_username --password test_password listwallets

2bd5f676-e86c-4cb4-bdaf-4afefffed3f4 0x16edb0e94d0baa4d0a528b501e9dcffbd7752d5d
   deaaa6bf-d944-57fa-8ec4-2dd45d1f5d3f Ether (Ropsten) 1000000000000000000 10^18

This returns the unique wallet ID followed by the public address, then a balance of each of the tokens the wallet can hold. In this case, the balance is 1*10^18.

Step 4 - Sending

Now that you have a wallet containing some tokens, you can send them to another wallet. For example, to send the tokens back to the faucet wallet:

# example:
upvest -e my_example_name user -l test_username -w test_password send <walletid> <assetid> <quantity> <fee> <recipient>
# real transaction:
upvest -e my_example_name user -l test_username -w test_password send 2bd5f676-e86c-4cb4-bdaf-4afefffed3f4 deaaa6bf-d944-57fa-8ec4-2dd45d1f5d3f 900000000000000000 5000000000 0x687422eea2cb73b5d3e242ba5456b782919afc85
Transaction successfully created: 0xa536ffdfcee7d6cf49bd68eb8186089dd7588797daf8b9e8db88a84a732e8cf2

This will return the transaction ID.

Advanced API usage

The Upvest CLI is meant as a simple tool to test and inspect how the Upvest API works and responds. When you have more complicated applications to build, head over to the Upvest documentation to read more about how the API works. This CLI tool uses the Upvest Python SDK however there are tools for other languages too. Happy hacking!

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

upvest_cli-0.2-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file upvest_cli-0.2-py3-none-any.whl.

File metadata

  • Download URL: upvest_cli-0.2-py3-none-any.whl
  • Upload date:
  • Size: 8.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.2

File hashes

Hashes for upvest_cli-0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1874a4298f77bacec33866fcc4539ea2f0fd0a261ee6c587fd8aa35e57b5c380
MD5 03ffd80c859fed0569f78505275bd88a
BLAKE2b-256 134cd4063f447853f73998c6cbb4a5acbd1da4aeff0de7672491c888151ceff3

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