diego-ssh

module
v0.0.0-...-551f274 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 22, 2015 License: Apache-2.0

README

diego-ssh

Diego-ssh is an implementation of an ssh proxy server, a lightweight ssh daemon, and a Cloud Foundry cli plugin. When deployed and configured correctly, they provide a simple and scalable way to access containers associated with Diego long running processes.

Proxy

The ssh proxy hosts the user-accessible ssh endpoint and is responsible for authentication, policy enforcement, and access controls in the context of Cloud Foundry. After a user has successfully authenticated with the proxy, the proxy will attempt to locate the target container and create an ssh session to a daemon running inside the container. After both sessions have been established, the proxy will manage the communication between the user's ssh client and the container's ssh daemon.

Proxy Authentication

Clients authenticate with the proxy using a specially formed user name that describes the authentication domain and target container and a password that contains the appropriate credentials for the domain.

The proxy currently supports authentication against a diego domain and a cf domain. Each authentication domain can be enabled independently via command line arguments.

Diego via the Receptor API

For Diego, the user is of the form diego:process-guid/index and the password must hold the receptor credentials in the form user:password.

Client example:

$ ssh -p 2222 'diego:my-process-guid/1'@ssh.10.244.0.34.xip.io
$ scp -P 2222 -oUser='diego:ssh-process-guid/0' my-local-file.json ssh.10.244.0.34.xip.io:my-remote-file.json

The receptor credentials checked by the proxy are extracted from the diegoAPIURL provided on the command line. The password provided by the client to the proxy must match what is present in the URL for a successful authentication.

This support is enabled with the --enableDiegoAuth flag.

Cloud Foundry via Cloud Controller and UAA

For Cloud Foundry, the user is of the form cf:app-guid/instance and the password must be a valid OAuth 2 bearer token that represents the end user. The proxy will contact the Cloud Controller as the user to determine if the policy allows the user to access application containers via SSH.

Client example:

$ cf outh-token | tail -1 | pbcopy # paste oauth token when prompted for password
$ ssh -p 2222 cf:$(cf app app-name --guid)/0@ssh.10.244.0.34.xip.io
$ scp -P 2222 -oUser=cf:$(cf app app-name --guid)/0' my-local-file.json ssh.10.244.0.34.xip.io:my-remote-file.json

Cloud Foundry cf client example that uses the ssh plugin:

$ cf install-plugin https://github.com/cloudfoundry-incubator/diego-ssh/releases/download/${version}/ssh-plugin-${platform}-${arch}
$ cf ssh app-name

This support is enabled with the --enableCFAuth flag.

Daemon discovery

To be accessible via the SSH proxy, containers must host an ssh daemon, expose it via a mapped port, and advertise the port in a diego-ssh route. The proxy will fail end user authentication if the target LRP or a route is not found.

  "routes": {
    "diego-ssh": { "container_port": 2222 }
  }

The CC-Bridge components of Diego will generate the appropriate LRP definitions for Cloud Foundry applications which reflect the policies that are in effect.

Proxy to Container Authentication

When the proxy attempts to handshake with the SSH daemon inside the target container, it will use the information associated with the diego-ssh key in the LRP routes.

container_port [required]

container_port indicates which port inside the container the ssh daemon is listening on. The proxy will attempt to connect to host side mapping of this port after authenticating the client.

host_fingerprint [optional]

When present, host_fingerprint declares the expected fingerprint of the SSH daemon's host public key. When the fingerprint of the actual target's host key does not match the expected fingerprint, the connection is terminated. The fingerprint should only contain the hex string generated by ssh-keygen -l.

user [optional]

user declares the user ID to use during authentication with the container's SSH daemon. While it's not a required part of the routing data, it is required for password authentication and may be required for public key authentication.

password [optional]

password declares the password to use during password authentication with the container's ssh daemon.

private_key [optional]

private_key declares the private key to use when authenticating with the container's SSH daemon. If present, the key must be a PEM encoded RSA or DSA public key.

Example LRP
{
  "process_guid": "ssh-process-guid",
  "domain": "ssh-experiments",
  "rootfs": "preloaded:cflinuxfs2",
  "instances": 1,
  "start_timeout": 30,
  "setup": {
    "download": {
      "artifact": "diego-sshd",
      "from": "http://file-server.service.cf.internal:8080/v1/static/diego-sshd/diego-sshd.tgz",
      "to": "/tmp",
      "cache_key": "diego-sshd"
    }
  },
  "action": {
    "run": {
      "path": "/tmp/diego-sshd",
      "args": [
          "-address=0.0.0.0:2222",
          "-authorizedKey=ssh-rsa ..."
      ],
      "env": [],
      "resource_limits": {}
    }
  },
  "ports": [ 2222 ],
  "routes": {
    "diego-ssh": {
      "container_port": 2222,
      "private_key": "PEM encoded PKCS#1 private key"
    }
  }
}

SSH Daemon

The ssh daemon is a lightweight implementation that is built around go's ssh library. It supports command execution, interactive shells, local port forwarding, and scp. The daemon is self-contained and has no dependencies on the container root file system.

The daemon is focused on delivering basic access to application instances in Cloud Foundry. It is intended to run as an unprivileged process and interactive shells and commands will run as the daemon user. The daemon only supports one authorized key is not intended to support multiple users.

The daemon can be made available on a file server and Diego LRPs that want to use it can include a download action to acquire the binary and a run action to start it. Cloud Foundry applications will download the daemon as part of the lifecycle bundle.

CF CLI Plugin

The cf CLI plugin adds the following commands:

  • ssh - ssh to an application container instance
  • enable-ssh - enable ssh for the application
  • disable-ssh - disable ssh for the application
  • ssh-enabled - reports whether SSH is enabled on an application container instance
  • allow-space-ssh - allow SSH access for the space
  • disallow-space-ssh - disallow SSH access for the space
  • space-ssh-allowed - reports whether SSH is allowed in a space

To build and install the plugin:

cd ~/workspace/diego-release/src/github.com/cloudfoundry-incubator/diego-ssh/cf-plugin
go build
cf uninstall-plugin Diego-SSH
cf install-plugin cf-plugin

Directories

Path Synopsis
fake_authenticators
This file was generated by counterfeiter
This file was generated by counterfeiter
cmd
cmd/fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
models/app/app_fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
models/credential/credential_fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
models/info/info_fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
models/space/space_fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
terminal/terminal_helper_fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
cmd
fake_handlers
This file was generated by counterfeiter
This file was generated by counterfeiter
fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
fake_keys
This file was generated by counterfeiter
This file was generated by counterfeiter
scp
atime
+build darwin
+build darwin
fakes
This file was generated by counterfeiter
This file was generated by counterfeiter
fake_io
This file was generated by counterfeiter
This file was generated by counterfeiter
fake_net
This file was generated by counterfeiter
This file was generated by counterfeiter
fake_ssh
This file was generated by counterfeiter
This file was generated by counterfeiter

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL