Skip to main content

ITS Private Cloud Command Line Interface

Project description

Warning: this project has been deprecated

If you are running vsscli v0.5.x we strongly suggest using the new vss-cli available at VSS-Cli. For more information see the following Announcement.

ITS Private Cloud Command Line Interface

CI Coverage PyPI PyPI version Docker Image Pulls Docker Image Layers Docker Image Version

This package provides a unified command line interface to the ITS Private Cloud.

Documentation

Package documentation is now available at docs.

Installation

Windows users, download and install Python Releases for Windows prior running pip.

The fastest way to install VSS CLI is to use pip:

pip install vsscli

If you have the VSS CLI installed and want to upgrade to the latest version you can run:

pip install --upgrade vsscli

This will install VSS CLI as well as all dependencies. You can also just download the tarball. Once you have the vsscli directory structure on your workstation, you can just run:

cd <path_to_vsscli>
python setup.py install

CLI Releases

The release notes for the VSS CLI can be found CHANGELOG in the gitlab repo.

Getting Started

Before using VSS CLI, you need setup your VSS credentials. You can do this in a couple of ways:

  • Environment variables
  • Configuration file

The quickest way to get started is to run the vss configure command:

vss configure
Username []:
Endpoint [https://vss-api.eis.utoronto.ca]:
Passw
Repeat for confirmation:

To use environment variables, set VSS_API_USER and VSS_API_USER_PASS or VSS_API_TOKEN:

export VSS_API_USER=<vss_user>
export VSS_API_USER_PASS=<vss_user_pass>
# or
export VSS_API_TOKEN=<vss_api_token>

To use a config file, create a configuration as follows:

{
"https://vss-api.eis.utoronto.ca": {
    "auth": "<encoded_creds>",
    "token": "<access_token"
    }
}

Place it in ~/.vss/config.json (or in %UserProfile%\.vss\config.json on Windows). If you place the config file in a different location than ~/.vss/config.json you need to inform VSS CLI the full path. Do this by setting the appropriate environment variable:

export VSS_CONFIG_FILE=/path/to/config_file.json

Or use the -c/--config option in the vss command as follows:

vss -c ~/.secret/vss-config.json

By default VSS CLI output is text, and this can be configured either by -o/--output option or the VSS_DEFAULT_OUTPUT environment variable as follows:

$ export VSS_DEFAULT_OUTPUT=json
# or
$ export VSS_DEFAULT_OUTPUT=text

JSON Parameter Input

VSS CLI options vary from simple string, boolean or numeric values to JSON data structures as input parameters on the command line.

For example, consider the following command to deploy a new virtual machine from a given template and provide a guest operating system specification to reconfigure hostname, domain, dns, ip, subnet and gateway:

vss compute vm mk from-template --source $TEMPLATE_UUID \
      --description 'New virtual machine' \
      --custom-spec '{"hostname": "fe1", "domain": "eis.utoronto.ca", "interfaces": [{"dhcp": true}]}'

Where $TEMPLATE_UUID is an environment variable storing the UUID of the source template.

Bash completion

Bash completion support is provided by Click and will complete sub commands and parameters. Subcommands are always listed whereas parameters only if at least a dash has been provided. Example:

vss compute <TAB><TAB>
account    compute    configure  request    stor       token

vss -<TAB><TAB>
--config      --no-verbose  --output      --verbose     --version     -c            -o

Activating Bash completion can be done by executing the following command:

eval "$(_VSS_COMPLETE=source vss)"

The above activation example will always invoke your application on startup and may slow down the shell activation. VSS-CLI ships with a Bash completion activation script named vss_bash_completer which can be either loaded manually or added to your basrc:

. $(dirname `which vss`)/vss_bash_completer

VSS Shell

The VSS CLI provides a REPL interactive shell with tab-completion, suggestions and command history.

Usage: vss shell [OPTIONS]

  REPL interactive shell.

Options:
  -i, --history TEXT  File path to save history
  --help              Show this message and exit.

To enter the shell just execute vss shell and you will get the following welcome message:

Getting Help

We use GitLab issues for tracking bugs, enhancements and feature requests. If it turns out that you may have found a bug, please open a new issue.

Versioning

The API versions are tagged based on Semantic Versioning. Versions available in the tags section.

Contributing

Refer to the Contributing Guide for details on our code of conduct and the process of submitting code to the repository.

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

vsscli-0.5.1.tar.gz (41.3 kB view details)

Uploaded Source

Built Distribution

vsscli-0.5.1-py3-none-any.whl (40.0 kB view details)

Uploaded Python 3

File details

Details for the file vsscli-0.5.1.tar.gz.

File metadata

  • Download URL: vsscli-0.5.1.tar.gz
  • Upload date:
  • Size: 41.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for vsscli-0.5.1.tar.gz
Algorithm Hash digest
SHA256 8100758c6bd6f40107eea5bd5a27131771fa7f96becc485b5f0437181a3968cd
MD5 ad089283e81e740503a619543d410a6b
BLAKE2b-256 efdaa78f3ee47e623cad3818aff4d9d7ea85d95b0a4b32d7dc74aa5214734be4

See more details on using hashes here.

File details

Details for the file vsscli-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: vsscli-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 40.0 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.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.3

File hashes

Hashes for vsscli-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9745ddd24f4a904fcb375a7262dbf8da8c73da617e8facaca1d66c62ac763b0e
MD5 e3535e5046318502f0c0eade8de7161e
BLAKE2b-256 0cdbf9356ee95bbce1485849a0315128be463527ed2697af93abc7ba6d4cba9a

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