ohmyzsh/plugins/aptible/_aptible
2017-11-29 16:40:21 +11:00

370 lines
19 KiB
Text

#compdef aptible
_aptible() {
_arguments \
'1: :_aptible_cmds' \
'*:: :->args'
local -a counts; counts=(0 1 2 3 4 5 6 7 8 9);
local -a sizes; sizes=(512 1024 2048 4096 8192 16384 32768 65536);
case $state in
args)
case $words[1] in
help)
_arguments \
'*: :_aptible_cmds'
;;
apps|db:list)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs'
;;
apps:create)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs'
;;
apps:deprovision|config*|ps|rebuild|services)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]'
;;
apps:scale)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--container-count=[Number of container(s)]: :{_describe "values" counts}' \
'--container-size=[Size of container(s)]: :{_describe "values" sizes}' \
'--size=[DEPRECATED, use --container-size]: :{_describe "values" sizes}'
;;
backup:list)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'--max-age=[MAX_AGE]' \
':: :_aptible_dbs'
;;
backup:restore)
_arguments \
'--handle=[HANDLE]: :_aptible_dbs' \
'--container-size=[Size of container(s)]: :{_describe "values" sizes}' \
'--size=[N]: :{_describe "N" sizes}'
;;
db:backup|db:clone|db:deprovision|db:dump)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
':: :_aptible_dbs'
;;
db:create)
_arguments \
'--type=[TYPE, Default\: postgresql]' \
'--version=[VERSION]' \
'--container-size=[Size of container(s)]: :{_describe "values" sizes}' \
'--size=[N, Default\: 10]' \
'--environment=[ENVIRONMENT]: :_aptible_envs'
;;
db:execute)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'1: :_aptible_dbs' \
'2: :_files'
;;
db:tunnel)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'--port=[N]' \
':: :_aptible_dbs'
;;
db:reload)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
':: :_aptible_dbs'
;;
db:restart)
_arguments \
'--container-size=[Size of container(s)]: :{_describe "values" sizes}' \
'--disk-size=[N]' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
':: :_aptible_dbs'
;;
db:url)
_arguments \
'--type=[TYPE, Default\: postgresql]' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
':: :_aptible_dbs'
;;
deploy)
_arguments \
'--git-commitish=[GIT_COMMITISH, Deploy a specific git commit or branch: the commitish must have been pushed to Aptible beforehand]' \
'--git-detach[Detach this app from its git repository: its Procfile, Dockerfile, and .aptible.yml will be ignored until you deploy again with git]' \
'--no-git-detach[Detach this app from its git repository: its Procfile, Dockerfile, and .aptible.yml will be ignored until you deploy again with git]' \
'--docker-image=[APTIBLE_DOCKER_IMAGE, Shorthand for APTIBLE_DOCKER_IMAGE=...]' \
'--private-registry-email=[APTIBLE_PRIVATE_REGISTRY_EMAIL, Shorthand for APTIBLE_PRIVATE_REGISTRY_EMAIL=...]' \
'--private-registry-username=[APTIBLE_PRIVATE_REGISTRY_USERNAME, Shorthand for APTIBLE_PRIVATE_REGISTRY_USERNAME=...]' \
'--private-registry-password=[APTIBLE_PRIVATE_REGISTRY_PASSWORD, Shorthand for APTIBLE_PRIVATE_REGISTRY_PASSWORD=...]' \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]'
;;
domains)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'--app=[APP]: :_aptible_apps' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'(-v, --verbose)'{-v,--verbose}'[VERBOSE]'
;;
endpoints:database:create)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]'
;;
endpoints:deprovision|endpoints:list)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--database=[DATABASE]: :_aptible_dbs'
;;
endpoints:https:create)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--default-domain[Enable Default Domain on this Endpoint]' \
'--no-default-domain[Disable Default Domain on this Endpoint]' \
'--internal[Restrict this Endpoint to internal traffic]' \
'--no-internal[Make this Endpoint public]' \
'--port=[N, A port to expose on this Endpoint]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]' \
'--certificate-file=[CERTIFICATE_FILE, A file containing a certificate to use on this Endpoint]: :_files' \
'--private-key-file=[PRIVATE_KEY_FILE, A file containing a private key to use on this Endpoint]: :_files' \
'--managed-tls[Enable Managed TLS on this Endpoint]' \
'--no-managed-tls[Disable Managed TLS on this Endpoint]' \
'--managed-tls-domain=[MANAGED_TLS_DOMAIN, A domain to use for Managed TLS]' \
'--certificate-fingerprint=[CERTIFICATE_FINGERPRINT, The fingerprint of an existing Certificate to use on this Endpoint]'
;;
endpoints:https:modify)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--port=[N, A port to expose on this Endpoint]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]' \
'--no-ip-whitelist[Disable IP Whitelist]' \
'--certificate-file=[CERTIFICATE_FILE, A file containing a certificate to use on this Endpoint]: :_files' \
'--private-key-file=[PRIVATE_KEY_FILE, A file containing a private key to use on this Endpoint]: :_files' \
'--managed-tls[Enable Managed TLS on this Endpoint]' \
'--no-managed-tls[Disable Managed TLS on this Endpoint]' \
'--managed-tls-domain=[MANAGED_TLS_DOMAIN, A domain to use for Managed TLS]' \
'--certificate-fingerprint=[CERTIFICATE_FINGERPRINT, The fingerprint of an existing Certificate to use on this Endpoint]'
;;
endpoints:renew)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]'
;;
endpoints:tcp:create)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--default-domain[Enable Default Domain on this Endpoint]' \
'--no-default-domain[Disable Default Domain on this Endpoint]' \
'--internal[Restrict this Endpoint to internal traffic]' \
'--no-internal[Make this Endpoint public]' \
'--ports=[one two three, A list of ports to expose on this Endpoint]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]'
;;
endpoints:tcp:modify)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--ports=[one two three, A list of ports to expose on this Endpoint]' \
'--no-ip-whitelist[Disable IP Whitelist]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]'
;;
endpoints:tls:create)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--default-domain[Enable Default Domain on this Endpoint]' \
'--no-default-domain[Disable Default Domain on this Endpoint]' \
'--internal[Restrict this Endpoint to internal traffic]' \
'--no-internal[Make this Endpoint public]' \
'--ports=[one two three, A list of ports to expose on this Endpoint]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]' \
'--certificate-file=[CERTIFICATE_FILE, A file containing a certificate to use on this Endpoint]: :_files' \
'--private-key-file=[PRIVATE_KEY_FILE, A file containing a private key to use on this Endpoint]: :_files' \
'--managed-tls[Enable Managed TLS on this Endpoint]' \
'--no-managed-tls[Disable Managed TLS on this Endpoint]' \
'--managed-tls-domain=[MANAGED_TLS_DOMAIN, A domain to use for Managed TLS]' \
'--certificate-fingerprint=[CERTIFICATE_FINGERPRINT, The fingerprint of an existing Certificate to use on this Endpoint]'
;;
endpoints:tls:modify)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--ports=[one two three, A list of ports to expose on this Endpoint]' \
'--ip-whitelist=[one two three, A list of IPv4 sources (addresses or CIDRs) to which to restrict traffic to this Endpoint]' \
'--no-ip-whitelist[Disable IP Whitelist]' \
'--certificate-file=[CERTIFICATE_FILE, A file containing a certificate to use on this Endpoint]: :_files' \
'--private-key-file=[PRIVATE_KEY_FILE, A file containing a private key to use on this Endpoint]: :_files' \
'--managed-tls[Enable Managed TLS on this Endpoint]' \
'--no-managed-tls[Disable Managed TLS on this Endpoint]' \
'--managed-tls-domain=[MANAGED_TLS_DOMAIN, A domain to use for Managed TLS]' \
'--certificate-fingerprint=[CERTIFICATE_FINGERPRINT, The fingerprint of an existing Certificate to use on this Endpoint]'
;;
login)
_arguments \
'--email=[EMAIL]' \
'--password=[PASSWORD]' \
'--lifetime=[LIFETIME, e.g. 24h, 1d, 600s, etc]' \
'--otp-token=[OTP_TOKEN, A token generated by your second-factor app]'
;;
logs)
_arguments \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'--app=[APP]: :_aptible_apps' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--database=[DATABASE]: :_aptible_dbs'
;;
restart)
_arguments \
"--simulate-oom=[Add this flag to simulate an OOM restart and test your app's response (not recommended on production apps)]" \
"--force[Add this flag to use --simulate-oom in a production environment, which is not allowed by default]" \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]'
;;
ssh)
_arguments \
'--app=[APP]: :_aptible_apps' \
'--environment=[ENVIRONMENT]: :_aptible_envs' \
'(-r, --remote)'{-r,--remote}'[REMOTE]' \
'--force-tty' \
'--force-no-tty'
;;
esac
;;
esac
}
_aptible_dbs() {
if [ -f "/tmp/aptible_dbs_zsh_cache" ]; then
local cache_time=$(stat -c %Y "/tmp/aptible_dbs_zsh_cache")
local expiration=$(date -d "now - 1 day" +%s)
if [ $cache_time -gt $expiration ]; then
local dbs; dbs=(
$(cat "/tmp/aptible_dbs_zsh_cache")
);
_describe 'db' dbs
else
_fetch_aptible_dbs
fi
else
_fetch_aptible_dbs
fi
}
_fetch_aptible_dbs() {
aptible db:list | egrep -v "^=" > /tmp/aptible_dbs_zsh_cache
_aptible_dbs
}
_aptible_apps() {
if [ -f "/tmp/aptible_apps_zsh_cache" ]; then
local cache_time=$(stat -c %Y "/tmp/aptible_apps_zsh_cache")
local expiration=$(date -d "now - 1 day" +%s)
if [ $cache_time -gt $expiration ]; then
local apps; apps=(
$(cat "/tmp/aptible_apps_zsh_cache")
);
_describe 'app' apps
else
_fetch_aptible _aptible_apps
fi
else
_fetch_aptible _aptible_apps
fi
}
_fetch_aptible() {
local list=$(aptible apps)
echo $list | egrep -v "^=" > /tmp/aptible_apps_zsh_cache
echo $list | egrep "^=" | tr -d '=' > /tmp/aptible_envs_zsh_cache
$1
}
_aptible_envs() {
if [ -f "/tmp/aptible_envs_zsh_cache" ]; then
local cache_time=$(stat -c %Y "/tmp/aptible_envs_zsh_cache")
local expiration=$(date -d "now - 1 day" +%s)
if [ $cache_time -gt $expiration ]; then
local apps; apps=(
$(cat "/tmp/aptible_envs_zsh_cache")
);
_describe 'app' apps
else
_fetch_aptible _aptible_envs
fi
else
_fetch_aptible _aptible_envs
fi
}
_aptible_cmds() {
local -a commands; commands=(
"apps:List all applications"
"apps\:create:Create a new application"
"apps\:deprovision:Deprovision an app"
"apps\:scale:Scale app to NUMBER of instances"
"backup\:list:List backups for a database"
"backup\:restore:Restore a backup"
"config:Print an app's current configuration"
"config\:add:Add an ENV variable to an app"
"config\:rm:Remove an ENV variable from an app"
"config\:set:Alias for config:add"
"config\:unset:Alias for config:rm"
"db\:backup:Backup a database"
"db\:clone:Clone a database to create a new one"
"db\:create:Create a new database"
"db\:deprovision:Deprovision a database"
"db\:dump:Dump a remote database to file"
"db\:execute:Executes sql against a database"
"db\:list:List all databases"
"db\:reload:Reload a database"
"db\:restart:Restart a database"
"db\:tunnel:Create a local tunnel to a database"
"db\:url:Display a database URL"
"db\:versions:List available database versions"
"deploy:Deploy an app"
"domains:Print an app's current virtual domains"
"endpoints\:database\:create:Create a Database Endpoint"
"endpoints\:deprovision:Deprovision an App or Database Endpoint"
"endpoints\:https\:create:Create an App HTTPS Endpoint"
"endpoints\:https\:modify:Modify an App HTTPS Endpoint"
"endpoints\:list:List Endpoints for an App or Database"
"endpoints\:renew:Renew an App Managed TLS Endpoint"
"endpoints\:tcp\:create:Create an App TCP Endpoint"
"endpoints\:tcp\:modify:Modify an App TCP Endpoint"
"endpoints\:tls\:create:Create an App TLS Endpoint"
"endpoints\:tls\:modify:Modify an App TLS Endpoint"
"help:Describe available commands or one specific command"
"login:Log in to Aptible"
"logs:Follows logs from a running app or database"
"operation\:cancel:Cancel a running operation"
"ps:Display running processes for an app - DEPRECATED"
"rebuild:Rebuild an app, and restart its services"
"restart:Restart all services associated with an app"
"services:List Services for an App"
"ssh:Run a command against an app"
"version:Print Aptible CLI version"
);
_describe 'command' commands
}
_aptible