generated from jackhadrill/container-spawner
	
		
			All checks were successful
		
		
	
	continuous-integration/drone/push Build is passing
				
			Container Director
A tool to proxy an HTTP backend, and failover to a "container spawner" if the backend does not exist.
Usage
This container listens on port 8080, and relies on OAuth2 Proxy for authentication.
Environment variables:
| Variable name | Example value | Description | 
|---|---|---|
| SPAWNER_HOST | container-spawner | The hostname of the Container Spawner, responsible for spawning new containers. | 
| CONTAINER_HOST_PREFIX | vscode | A prefix used by the Container Spawner which, when prepended to the user's username, represents the user's bespoke container hostname. Example: vscode-jack | 
| CONTAINER_PORT | 8080 | The port number used by the spawned container for incoming connections. | 
An example docker-compose.yml is shown below.
version: '3'
services:
  auth:
    image: bitnami/oauth2-proxy:latest
    restart: always
    networks:
      - proxy
      - backend
    command:
      - '--upstream=http://container-director:8080/'
      - '--http-address=0.0.0.0:4180'
      - '--skip-provider-button=true'
      - '--whitelist-domain=...'
    environment:
      OAUTH2_PROXY_COOKIE_SECRET: '...'
      OAUTH2_PROXY_INSECURE_OIDC_ALLOW_UNVERIFIED_EMAIL: 'true'
      OAUTH2_PROXY_EMAIL_DOMAINS: '*'
      OAUTH2_PROXY_PROVIDER: 'oidc'
      OAUTH2_PROXY_OIDC_ISSUER_URL: '...'
      OAUTH2_PROXY_CLIENT_ID: '...'
      OAUTH2_PROXY_CLIENT_SECRET: '...'
  container-director:
    image: git.jacknet.io/jackhadrill/container-director:latest
    restart: always
    environment:
      SPAWNER_HOST: "container-spawner"
      CONTAINER_HOST_PREFIX: "vscode"
      CONTAINER_PORT: 8080
  container-spawner:
    image: git.jacknet.io/jackhadrill/container-spawner:latest
    restart: always
    environment:
      CONTAINER_IMAGE: "git.jacknet.io/jackhadrill/code-server:latest"
      CONTAINER_PREFIX: "vscode"
      CONTAINER_NETWORK: "vscode_backend"
      CONTAINER_PERSIST: "/home/coder"
networks:
  backend:
  proxy:
    name: web_proxy
    external: True
Process description
The following steps describe how Container Spawner and Container Director work together in order to spawn bespoke containers, on behalf of users authenticated through OAuth2 Proxy.
- A user logs in via OAuth2 Proxy.
- After a successful login OAuth2 Proxy proxies the original request to Container Director, adding a X-Forwarded-Preferred-Usernamerequest header, which contains the user's username.
 
- After a successful login OAuth2 Proxy proxies the original request to Container Director, adding a 
- Container Director tries to proxy the original request once more to the user's bespoke container http://<CONTAINER_HOST_PREFIX>-<X-Forwarded-Preferred-Username>:<CONTAINER_PORT>.- For example: http://vscode-jack:8080.
 
- For example: 
- If the bespoke container does not respond, Container Director will proxy the same request to Container Spawner.
- Container Spawner returns a loading page with a refresh timer. Meanwhile, it will check to see if the user's bespoke container exists.
- If not, the user's bespoke container will be created.
- If it does, something has gone wrong. Return a useful error message!
 
Description
				
					Languages
				
				
								
								
									Dockerfile
								
								100%