# Cloudstack CLI [![Gem Version](https://badge.fury.io/rb/cloudstack-cli.png)](http://badge.fury.io/rb/cloudstack-cli) cloudstack-cli is a [CloudStack](http://cloudstack.apache.org/) API command line client written in Ruby. cloudstack-cli uses the [cloudstack_client](https://github.com/niwo/cloudstack_client) to talk to the CloudStack API. ## Installation Install the cloudstack-cli gem: ```bash $ gem install cloudstack-cli ``` ## Setup ### Create a cloudstack-cli environment cloudstack-cli expects to find a configuration file with the API URL and your CloudStack credentials in your home directory named .cloudstack.yml (or .cloudstack-cli.yml). If the file is located elsewhere you can specify the location using the --config-file option. *Create your initial environment, which defines your connection options:* ```bash $ cloudstack-cli setup ``` "cloudstack-cli setup" (or "cloudstack-cli environment add") requires the following options: - The full URL of your CloudStack API, i.e. "https://cloud.local/client/api" - Your API Key (generate it under Accounts > Users if not already available) - Your Secret Key (see above) *Add an additional environment:* ```bash $ cloudstack-cli env add production ``` cloudstack-cli supports multiple environments using the --environment option. The first environment added is always the default. You can change the default as soon as you have multiple environments: ```bash $ cloudstack-cli environment default [environment-name] ``` *List all environments:* see `cloudstack-cli help environment` for more options. Example configuration file: ```yaml # default environment :default: production # production environment production: :url: "https://my-cloudstack-server/client/api/" :api_key: "cloudstack-api-key" :secret_key: "cloudstack-api-secret" # test environment test: :url: "http://my-cloudstack-testserver/client/api/" :api_key: "cloudstack-api-key" :secret_key: "cloudstack-api-secret" ``` ### Shell tab auto-completion To enable tab auto-completion for cloudstack-cli, add the following lines to your ~/.bash_profile file. ```bash # Bash, ~/.bash_profile eval "$(cloudstack-cli completion --shell=bash)" ``` __Note__: use `~/.bashrc` on Ubuntu ## Usage *Display the cli help:* ```bash $ cloudstack-cli help ``` *Help for a specific subcommand and command:* ```bash $ cloudstack-cli vm help ``` ```bash $ cloudstack-cli vm help list ``` ### Example: Bootstrapping a server *Bootstraps a server using a template and creating port-forwarding rules for port 22 and 80:* ```bash $ cloudstack-cli server create server-01 --template CentOS-6.4-x64-v1.4 --zone DC1 --offering 1cpu_1gb --port-rules :22 :80 ``` ### Example: Run any custom API command *Run the "listAlerts" command against the CloudStack API with an argument of type=8:* ```bash $ cloudstack-cli command listAlerts type=8 ``` ### Example: Creating a complete stack of servers CloudStack CLI does support stack files in YAML or JSON. *An example stackfile could look like this (my_stackfile.yml):* ```yaml --- name: "web_stack-a" description: "Web Application Stack" version: "1.0" zone: "DC-ZRH-1" group: "my_web_stack" keypair: "mykeypair" servers: - name: "web-d1, web-d2" description: "web node" template: "CentOS-7-x64" offering: "1cpu_1gb" networks: "server_network" port_rules: ":80, :443" - name: "db-01" description: "PostgreSQL Master" iso: "CentOS-7-x64" disk_offering: "Perf Storage" disk_size: "5" offering: "2cpu_4gb" ip_network_list: - name: FrontendNetwork ip: 10.101.64.42 - name: BackendNetwork ip: 10.102.1.11 ``` *Create the stack of servers from the definition above:* ```bash $ cloudstack-cli stack create my_stackfile.yml ``` **Hint:** You can also parse a stackfile from a URI. *The following command destroys a stack using a definition gathered from a stackfile lying on a Github repository:* ```bash $ cloudstack-cli stack destroy https://raw.githubusercontent.com/niwo/cloudstack-cli/master/test/stack_example.json Destroy the following servers web-001, web-002, db-001? [y/N]: y Destroy server web-001 : job completed Destroy server web-002 : job completed Destroy server db-001 : / Completed: 2/3 (15.4s) ``` ### Example: Sort computing offerings *Sort all computing offerings by CPU and Memory grouped by domain:* (root admin privileges required) ```bash $ cloudstack-cli compute_offer sort ``` ### Example: Stop all backup routers of a given project *Stop all virtual routers of project named Demo (you could filter by zone too):* (this command is helpful if you have to deploy new major release of CloudStack when using redundant routers) ```bash $ cloudstack-cli router list --project Demo --status running --redundant-state BACKUP --command STOP ```` ## References - [Cloudstack API documentation](http://cloudstack.apache.org/docs/api/) - This tool was inspired by the Knife extension for Cloudstack: [knife-cloudstack](https://github.com/CloudStack-extras/knife-cloudstack) ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create new Pull Request ## License Released under the MIT License. See the [LICENSE](https://raw.github.com/niwo/cloudstack-cli/master/LICENSE.txt) file for further details.