Cludo (Cloud Sudo)
Distributing AWS credentials is painful and dangerous. Leaked credentials result in hours to days of operations headaches and developing an automated rotation system is expensive. Enter cludo
!
Never distribute or force developers to rotate AWS credentials again.
The cludo
command is run locally on the developer machine. It gets temporary AWS credentials from the centralized cludod
server, and then provides the credentials locally via environment variables to arbitrary commands. Those credentials expire after a short amount of time, so any leaked credentials are already outdated.
cludo
currently only supports AWS, but we plan to expand to many other backends in the future.
This README primarily documents the client (cludo
). A list of additional documentation can be found here.
Client Documentation
Installation
- For direction on installing with helm, kubectl, or kustomize see ./k8s/README.md.
go get -u github.com/superorbital/cludo/cmd/cludo/cludo
Configuration
The cludo
client will read both your user's ~/.cludo/cludo.yaml
file and the cludo.yaml
file in your current working directory. This allows you to configure per-repo and per-user aspects separately.
For example, it's common to have the following in your ~/.cludo/cludo.yaml
file to configure your user's SSH keys for authenticating with cludod
:
ssh_key_paths: ["~/.ssh/superorbial_cludo", "~/.ssh/example_cludo.pub"]
Then your team would include this cludo.yaml
file in a directory in the project's git
repository to configure the cludod
server endpoint and target environment.
- In the example below:
https://cludo.example.com/
is the endpoint where the cludod
server is listening for connections.
staging
is the name of a target that is configured in the cludod
server config file.
target: https://cludo.example.com/staging
Alternatively, you can provide the values as environment variables:
$ export CLUDO_TARGET=https://cludo.example.com/staging
Currently, only the following values are configurable for the client:
Key |
Description |
Environment Variable |
target |
cludod server URL and appended config target (e.g. dev,prod, etc) |
CLUDO_TARGET |
ssh_key_paths |
Paths to private (direct) and public keys (ssh agent) used for authentication. |
CLUDO_SSH_KEY_PATHS |
client.shell_path |
The path to the shell to launch when using cludo shell |
CLUDO_SHELL_PATH |
client.interactive |
Wether the user can be prompted for additional information (like SSH passphrases) |
CLUDO_INTERACTIVE |
target: "https://cludo.example.com/dev"
ssh_key_paths: ["~/.ssh/id_ed25519.pub", "~/.ssh/id_rsa", "~/.ssh/id_ecdsa"]
client:
shell_path: "/usr/local/bin/bash"
interactive: true
Authentication with the cludod
server
Cludo uses SSH keys for authentication. The client will try all of the private keys (directly) and public keys (via a local SSH agent) listed in the ssh_key_paths
setting when authenticating with the server until one succeeds (or they all fail).
If you want to use a local SSH agent with cludo
then you should add the local path to a public key that matches a private key which is loaded into your SSH agent. If cludo
can connect to the agent, then it will try to use that for signing requests.
Usage
cludo <command> [options]
Main commands:
exec - Runs the provided command with credentials provided through environment variables
shell - Opens an interactive shell with credentials provided through environment variables
version - Prints the cludo client and server versions
For example, to list AWS EC2 instances using the currently configured target:
$ cludo exec aws ec2 describe-instances
You can add --debug
to get some extra debugging output.
Docker
We also provide a docker image (superorbital/cludo
). Just provide a /etc/cludo/cludo.yaml
config file!
AWS
The AWS backend provides the following environment variables:
Environment Variable |
Description |
AWS_ACCESS_KEY_ID |
cludo environment AWS access key. |
AWS_SECRET_ACCESS_KEY |
cludo environment AWS secret access key. |
AWS_SESSION_TOKEN |
AWS session token generated for cludo environment. |
AWS_SESSION_EXPIRATION |
Time when generated AWS session token will expire. |
Each time a cludo
command that uses an environment is run, a new AWS session token is generated.
Other Documentation
Cludo is heavily inspired by the venerable aws-vault
tool. aws-vault
is entirely client-side, meaning you don't need a centralized authentication server. But this also means that each developer is responsible for configuring the tool correctly and consistently. This also requires that the master credentials be stored on each workstation (via one of many encrypted backends). If you're a solo developer, then Cludo is overkill, and aws-vault
is the right tool for you.