Skip to main content

goatshell - goat shell interface to common cloud providers.

Project description

image gif

GOATSHELL

7 Clouds & 1 Shell

Installation

Manual Installation

  1. Create a virtual environment. We will call it prod:
    python3 -m venv ~/prod
    
  2. Activate virtual environment:
    cd ~/prod && source bin/activate
    
  3. Clone the repo:
    git clone git@github.com:stacksc/goat.git
    
  4. Install all required packages with 1 script from the main repository:
    cd ~/prod/goat && ./bulk.sh --action rebuild --target all
    

PIP installation (stable)

  1. Install the following packages from pypi:
    pip install goatshell goaat --force-reinstall
    
  2. Type the following command to launch goatshell:
    goatshell
    
┌───────────────────────────────────────────────────────────────────────────────────────────────────────| GOAT INTERFACE |───────────────────────────────────────────────────────────────────────────────────────────────────────┐
│                                                                                                     Purpose: Cloud Wrapper                                                                                                     │
│                                                                                             TIP: resource completion coming soon!                                                                                              │
└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘
┌──────────────────| Hotkeys |───────────────────┐┌──────────────────| Commands |──────────────────┐
│[F8]  Toggle Provider                           ││e|exit    : exit shell                          │
│[F9]  Toggle Profile                            ││c|clear   : clear screen                        │
│[F10] Toggle VIM                                ││h|help    : display usage                       │
│[F12] Toggle Safety Mode                        ││history   : shell history                       │
│[TAB] Fuzzy Complete                            ││cloud     : cloud details                       │
└────────────────────────────────────────────────┘└────────────────────────────────────────────────┘
[oci:DEFAULT]>

(back to top)

Contacts

Christopher Stacks - centerupt@gmail.com

Mechanics

The project is built with dependecies such as aws2, oci-cli, az-cli.
However, other cloud providers are configured to work but NOT packaged with the project such as ibmcloud, gcloud, and Alibaba cloud.

Each time the first token is passed (i.e. cloud provider) a function will verify if the command is avialable.
This keeps the command line clean with the cloud providers you only work with.

The following cloud providers are currently supported:
image
The latest goat-shell version holds all JSON data per cloud, correctly nested based on the cloud provider.

Toolbar

The toolbar will refresh after hitting the ENTER key or with specific hotkeys.

The toolbar is updated appropriately based on what command you ran. Once you run a command, the toolbar is refreshed with your current cloud.

The profile is updated dynamically based on your current cloud and you have the ability to toggle profiles for any cloud.

goat>
Current Cloud: AWS  F8 Usage F10 Toggle Profile: CENTERUPT F12 Quit

Toggle

The only toggle currently supported is profile switching. Everything else is dynamic based on first token.

Cloud CLI Options

# Name Status Additional Info
1 OCI-CLI Default / Supported
2 AWS Default / Supported
3 AZ Default / Supported
4 GCLOUD Supported / Manual Installation Installation Guide
5 ALIYUN Supported / Manual Installation Installation Guide
6 IBMCLOUD Supported / Manual Installation Installation Guide
7 OVHCLOUD & AI Supported / Manual Installation Installation Guide

Newly Improved Interface Now Available

image

Once the relative CLI is installed, the goatshell application will recognize that it is available & syntax completion will be provided.
The project is packaged with cloud provider JSON files which get refreshed automatically per major release with dynamic CLI scrapers.

As the first token is passed (i.e. cloud provider) it directs the goatshell application to the correct JSON file.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

goatshell-2024.7.16.1622.tar.gz (3.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

goatshell-2024.7.16.1622-py3-none-any.whl (3.5 MB view details)

Uploaded Python 3

File details

Details for the file goatshell-2024.7.16.1622.tar.gz.

File metadata

  • Download URL: goatshell-2024.7.16.1622.tar.gz
  • Upload date:
  • Size: 3.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for goatshell-2024.7.16.1622.tar.gz
Algorithm Hash digest
SHA256 8458e60eaa7c743469862887f6688855496fdec9a3fbeac20f3a11f7a42725f8
MD5 16523d715f7b5df9ab38c884cc0d9fb7
BLAKE2b-256 81f0034aac6677af638482df047b93e8a0890175595ffa7489b985c6b448ebc3

See more details on using hashes here.

File details

Details for the file goatshell-2024.7.16.1622-py3-none-any.whl.

File metadata

File hashes

Hashes for goatshell-2024.7.16.1622-py3-none-any.whl
Algorithm Hash digest
SHA256 be2f195d7efe1facb3b8304781277c43882b248abb5f5eebff4c131d397d186a
MD5 538cb478431ba4254d6b64e43f114e9c
BLAKE2b-256 ba1d2e0a8487b11cd9fb72543fdcee37b495ab8149c1bf96d92e2a4382b4d2d9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page