Skip to main content

A lightweight wrapper for the SolusVM client API.

Project description

https://img.shields.io/pypi/status/beam.svg https://img.shields.io/pypi/v/beam.svg https://img.shields.io/pypi/pyversions/beam.svg https://travis-ci.org/gebn/beam.svg?branch=master https://coveralls.io/repos/github/gebn/beam/badge.svg?branch=master

A lightweight wrapper for the SolusVM client API.

Features

  • Query a host’s memory, bandwidth, IP addresses and storage usage.

  • Boot, reboot and shutdown machines.

  • Configurable to work with any SolusVM provider.

  • Command line client and intuitive Python module for your own scripts.

Setup

  1. Run pip install beam to download the module.

  2. Create your .beam.ini inventory file as below.

Inventory

The inventory file holds information about your hosting provider(s) and host(s), so beam knows how to contact the relevant API endpoints and what credentials to use. Here’s a sample file:

[special:vendors]
ramnode = https://vpscp.ramnode.com
vendor2 = https://vendor2-panel.com
default = ramnode

[nyc-1]
key = nyc-1_host_key
hash = nyc-1_host_hash

[ams-1]
key = ams-1_host_key
hash = ams-1_host_hash
vendor = vendor2

This file defines two hosts, nyc-1, hosted with RamNode, and ams-1, hosted with FlipHost. At the top are the vendor names in a special vendors section (all other sections are assumed to represent hosts). The format maps a vendor name to their base endpoint for the SolusVM API. The default directive indicates the implicit vendor of every host, and must be specified if more than one vendor is defined.

Each host has its own section. The correct key and hash values can be optained from the SolusVM control panel used by your vendor. If a host is not provided by the default vendor, a vendor directive specifies the correct one.

Usage

Beam provides both a Python library for programmatic access to your hosts, and a simple CLI that wraps it in a couple of lines of code.

CLI

The CLI client can be used to find information about a single host.

$ beam --help
usage: beam [-h] [-V]
            (-A {boot,reboot,shutdown} | -a ATTRIBUTES [ATTRIBUTES ...])
            [host]

A lightweight wrapper for the SolusVM client API.

positional arguments:
  host                  the identifier of the host whose information to
                        retrieve

optional arguments:
  -h, --help            show this help message and exit
  -V, --version         show program's version number and exit
  -A {boot,reboot,shutdown}, --action {boot,reboot,shutdown}
                        an action to execute against the host
  -a ATTRIBUTES [ATTRIBUTES ...], --attributes ATTRIBUTES [ATTRIBUTES ...]
                        one or more attributes of the host to retrieve
$ beam -a bandwidth.free_percentage nyc-1
0.4983459835
$ beam -a primary_ip lon-1
2604:180:2:32b::498b
$ beam -a is_online memory.used_bytes ams-1
True
34578234983
$ beam -A shutdown nyc-1
OK

Library

import beam

# shutdown a specific host
host = beam.host('nyc-1')  # name, key or hash
if host.is_online:
    host.shutdown()

# boot all offline hosts
[host.boot() for host in beam.hosts() if not host.is_online]

# get a list of hosts using above 90% of their memory
hosts = [host for host in beam.hosts()
         if host.memory.used_percentage > .9]

# get a list of hosts with less than 10 GiB of storage left
hosts = [host for host in beam.hosts()
         if host.storage.free_bytes < 1024 ** 3 * 10]

Roadmap

  • Generate documentation.

  • Increase unit test coverage to 100%, and implement some integration tests.

Etymology

Although “solus” means alone, that’s a tad depressing. Solus also conjures up images of the sun for me. The sun beams down - and the name was available on PyPI - so beam it was.

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

beam-0.6.0.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

beam-0.6.0-py2.py3-none-any.whl (18.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file beam-0.6.0.tar.gz.

File metadata

  • Download URL: beam-0.6.0.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for beam-0.6.0.tar.gz
Algorithm Hash digest
SHA256 081513f3d5820e866c928d004c0fdb0b320a3735cda6deee746bdc656841f04f
MD5 7b2216937d6491b617b4c1c3bcc60fd9
BLAKE2b-256 9d7c0abcfc58b52a952ae1e7a8d906405a8c1812b874031d6f9fa5756d92ac86

See more details on using hashes here.

File details

Details for the file beam-0.6.0-py2.py3-none-any.whl.

File metadata

  • Download URL: beam-0.6.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 18.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for beam-0.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c8e30630fcb4caa35d54cb43a9496d1f238ab886740d48d3e19bd08a16e1e3eb
MD5 a6dc37f793817b657c89a9b361967996
BLAKE2b-256 a260099731a1172b9166d92ee348b3ef3a3575124dc6518d4ed26d833f8910ce

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