Metadata-Version: 2.1
Name: cloudscale
Version: 0.0.2
Summary: A library and command line interface for cloudscale.ch
Home-page: https://github.com/resmo/python-cloudscale
Author: René Moser
Author-email: mail@renemoser.net
License: MIT
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Environment :: Console
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: requests
Requires-Dist: click
Requires-Dist: tabulate
Requires-Dist: pygments

![license](https://img.shields.io/pypi/l/cloudscale.svg)
![python versions](https://img.shields.io/pypi/pyversions/cloudscale.svg)
![status](https://img.shields.io/pypi/status/cloudscale.svg)
[![pypi version](https://img.shields.io/pypi/v/cloudscale.svg)](https://pypi.org/project/cloudscale/)

# Cloudscale

A cloudscale.ch API client for Python3 and your command line.

## Install

~~~
pip3 install cloudscale
~~~

## Command Line Interface

### Autocompletion

zsh:
~~~
eval "$(_CLOUDSCALE_CLI_COMPLETE=source_zsh cloudscale-cli)"
~~~

bash:
~~~
eval "$(_CLOUDSCALE_CLI_COMPLETE=source cloudscale-cli)"
~~~


### Authentication

Using the ENV `CLOUDSCALE_API_TOKEN` variable:

~~~
export CLOUDSCALE_API_TOKEN=<your token>
cloudscale-cli flavor list
~~~

or by passing the `--api-token` parameter:

~~~
cloudscale-cli server --api-token <your_token> create ...
~~~

### Usage Examples

#### Create a Server

~~~
cloudscale-cli server create --flavor flex-2 --name my-server --image centos-7 --ssh-keys "$(cat ~/.ssh/id_rsa.pub)"
~~~

#### List all Servers

~~~
cloudscale-cli server list
~~~

#### Get Servers having the tag project=gemini

~~~
cloudscale-cli server list --filter-tag project=gemini
~~~

## Usage in Python

### List the slug of all flavors
~~~python
import os
from cloudscale import Cloudscale, CloudscaleApiException

api_token = os.getenv('CLOUDSCALE_API_TOKEN')

cloudscale = Cloudscale(api_token=api_token)
flavors = cloudscale.flavor.get_all()
for flavor in flavors:
    print(flavor['slug'])
~~~

### Print the server names of running servers
~~~python
import os
from cloudscale import Cloudscale, CloudscaleApiException

api_token = os.getenv('CLOUDSCALE_API_TOKEN')

cloudscale = Cloudscale(api_token=api_token)
servers = cloudscale.server.get_all()
for server in servers:
    if server['status'] == "running":
        print(server['name'])
~~~

### Get resource by UUID
~~~python
from cloudscale import Cloudscale, CloudscaleApiException

try:
    cloudscale = Cloudscale(api_token=api_token)
    server_group = cloudscale.server_group.get_by_uuid(uuid="5a1e5b28-d354-47a8-bfb2-01b048c20204")
    print(server_group['name'])
except CloudscaleApiException as e:
    print(e)
~~~

### Error handling
~~~python
from cloudscale import Cloudscale, CloudscaleApiException
try:
    cloudscale = Cloudscale(api_token=api_token)
    server = cloudscale.server.get_by_uuid(uuid="does-not-exist")
    print(server['name'])
except CloudscaleApiException as e:
    # Prints "API Response Error (404): Not found."
    print(e)
    # Prints "404"
    print(e.status_code)
    # Prints raw API response
    print(e.response)
~~~


