#compdef innernet autoload -U is-at-least _innernet() { typeset -A opt_args typeset -a _arguments_options local ret=1 if is-at-least 5.2; then _arguments_options=(-s -S -C) else _arguments_options=(-s -C) fi local context curcontext="$curcontext" state line _arguments "${_arguments_options[@]}" \ '-c+[]:CONFIG_DIR: ' \ '--config-dir=[]:CONFIG_DIR: ' \ '-d+[]:DATA_DIR: ' \ '--data-dir=[]:DATA_DIR: ' \ '--backend=[Specify a WireGuard backend to use. If not set, innernet will auto-select based on availability]:BACKEND:(kernel userspace)' \ '--mtu=[Specify the desired MTU for your interface (default: 1420 for IPv4 and 1400 for IPv6)]:MTU: ' \ '-h[Print help information]' \ '--help[Print help information]' \ '-V[Print version information]' \ '--version[Print version information]' \ '*-v[Verbose output, use -vv for even higher verbositude]' \ '*--verbose[Verbose output, use -vv for even higher verbositude]' \ '--no-routing[Whether the routing should be done by innernet or is done by an external tool like e.g. babeld]' \ ":: :_innernet_commands" \ "*::: :->innernet" \ && ret=0 case $state in (innernet) words=($line[1] "${words[@]}") (( CURRENT += 1 )) curcontext="${curcontext%:*:*}:innernet-command-$line[1]:" case $line[1] in (install) _arguments "${_arguments_options[@]}" \ '--hosts-path=[The path to write hosts to]:HOSTS_PATH: ' \ '(--default-name)--name=[Set a specific interface name]:NAME: ' \ '*--exclude-nat-candidates=[Exclude one or more CIDRs from NAT candidate reporting. ex. --exclude-nat-candidates '\''0.0.0.0/0'\'' would report no candidates]:EXCLUDE_NAT_CANDIDATES: ' \ '(--hosts-path)--no-write-hosts[Don'\''t write to any hosts files]' \ '--default-name[Use the network name inside the invitation as the interface name]' \ '-d[Delete the invitation after a successful install]' \ '--delete-invite[Delete the invitation after a successful install]' \ '--no-nat-traversal[Don'\''t attempt NAT traversal. Note that this still will report candidates unless you also specify to exclude all NAT candidates]' \ '(--exclude-nat-candidates)--no-nat-candidates[Don'\''t report any candidates to coordinating server. Shorthand for --exclude-nat-candidates '\''0.0.0.0/0'\'']' \ '-h[Print help information]' \ '--help[Print help information]' \ ':invite -- Path to the invitation file:' \ && ret=0 ;; (show) _arguments "${_arguments_options[@]}" \ '-s[One-line peer list]' \ '--short[One-line peer list]' \ '-t[Display peers in a tree based on the CIDRs]' \ '--tree[Display peers in a tree based on the CIDRs]' \ '-h[Print help information]' \ '--help[Print help information]' \ '::interface:' \ && ret=0 ;; (up) _arguments "${_arguments_options[@]}" \ '--interval=[Keep fetching the latest peer list at the specified interval in seconds. Valid only in daemon mode]:INTERVAL: ' \ '--hosts-path=[The path to write hosts to]:HOSTS_PATH: ' \ '*--exclude-nat-candidates=[Exclude one or more CIDRs from NAT candidate reporting. ex. --exclude-nat-candidates '\''0.0.0.0/0'\'' would report no candidates]:EXCLUDE_NAT_CANDIDATES: ' \ '-d[Enable daemon mode i.e. keep the process running, while fetching the latest peer list periodically]' \ '--daemon[Enable daemon mode i.e. keep the process running, while fetching the latest peer list periodically]' \ '(--hosts-path)--no-write-hosts[Don'\''t write to any hosts files]' \ '--no-nat-traversal[Don'\''t attempt NAT traversal. Note that this still will report candidates unless you also specify to exclude all NAT candidates]' \ '(--exclude-nat-candidates)--no-nat-candidates[Don'\''t report any candidates to coordinating server. Shorthand for --exclude-nat-candidates '\''0.0.0.0/0'\'']' \ '-h[Print help information]' \ '--help[Print help information]' \ '::interface:' \ && ret=0 ;; (fetch) _arguments "${_arguments_options[@]}" \ '--hosts-path=[The path to write hosts to]:HOSTS_PATH: ' \ '*--exclude-nat-candidates=[Exclude one or more CIDRs from NAT candidate reporting. ex. --exclude-nat-candidates '\''0.0.0.0/0'\'' would report no candidates]:EXCLUDE_NAT_CANDIDATES: ' \ '(--hosts-path)--no-write-hosts[Don'\''t write to any hosts files]' \ '--no-nat-traversal[Don'\''t attempt NAT traversal. Note that this still will report candidates unless you also specify to exclude all NAT candidates]' \ '(--exclude-nat-candidates)--no-nat-candidates[Don'\''t report any candidates to coordinating server. Shorthand for --exclude-nat-candidates '\''0.0.0.0/0'\'']' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (uninstall) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (down) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (add-peer) _arguments "${_arguments_options[@]}" \ '--name=[Name of new peer]:NAME: ' \ '(--auto-ip)--ip=[Specify desired IP of new peer (within parent CIDR)]:IP: ' \ '--cidr=[Name of CIDR to add new peer under]:CIDR: ' \ '--admin=[Make new peer an admin?]:ADMIN: ' \ '--save-config=[Save the config to the given location]:SAVE_CONFIG: ' \ '--invite-expires=[Invite expiration period (eg. '\''30d'\'', '\''7w'\'', '\''2h'\'', '\''60m'\'', '\''1000s'\'')]:INVITE_EXPIRES: ' \ '--auto-ip[Auto-assign the peer the first available IP within the CIDR]' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (rename-peer) _arguments "${_arguments_options[@]}" \ '--name=[Name of peer to rename]:NAME: ' \ '--new-name=[The new name of the peer]:NEW_NAME: ' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (add-cidr) _arguments "${_arguments_options[@]}" \ '--name=[The CIDR name (eg. '\''engineers'\'')]:NAME: ' \ '--cidr=[The CIDR network (eg. '\''10.42.5.0/24'\'')]:CIDR: ' \ '--parent=[The CIDR parent name]:PARENT: ' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (delete-cidr) _arguments "${_arguments_options[@]}" \ '--name=[The CIDR name (eg. '\''engineers'\'')]:NAME: ' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (list-cidrs) _arguments "${_arguments_options[@]}" \ '-t[Display CIDRs in tree format]' \ '--tree[Display CIDRs in tree format]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (disable-peer) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (enable-peer) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (add-association) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ '::cidr1 -- The first cidr to associate:' \ '::cidr2 -- The second cidr to associate:' \ && ret=0 ;; (delete-association) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (list-associations) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (set-listen-port) _arguments "${_arguments_options[@]}" \ '-l+[The listen port you'\''d like to set for the interface]:LISTEN_PORT: ' \ '--listen-port=[The listen port you'\''d like to set for the interface]:LISTEN_PORT: ' \ '(-l --listen-port)-u[Unset the local listen port to use a randomized port]' \ '(-l --listen-port)--unset[Unset the local listen port to use a randomized port]' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (override-endpoint) _arguments "${_arguments_options[@]}" \ '-e+[The listen port you'\''d like to set for the interface]:ENDPOINT: ' \ '--endpoint=[The listen port you'\''d like to set for the interface]:ENDPOINT: ' \ '(-e --endpoint)-u[Unset an existing override to use the automatic endpoint discovery]' \ '(-e --endpoint)--unset[Unset an existing override to use the automatic endpoint discovery]' \ '--yes[Bypass confirmation]' \ '-h[Print help information]' \ '--help[Print help information]' \ ':interface:' \ && ret=0 ;; (completions) _arguments "${_arguments_options[@]}" \ '-h[Print help information]' \ '--help[Print help information]' \ ':shell:(bash elvish fish powershell zsh)' \ && ret=0 ;; (help) _arguments "${_arguments_options[@]}" \ && ret=0 ;; esac ;; esac } (( $+functions[_innernet_commands] )) || _innernet_commands() { local commands; commands=( 'install:Install a new innernet config' \ 'show:Enumerate all innernet connections' \ 'up:Bring up your local interface, and update it with latest peer list' \ 'fetch:Fetch and update your local interface with the latest peer list' \ 'uninstall:Uninstall an innernet network' \ 'down:Bring down the interface (equivalent to '\''wg-quick down '\'')' \ 'add-peer:Add a new peer' \ 'rename-peer:Rename a peer' \ 'add-cidr:Add a new CIDR' \ 'delete-cidr:Delete a CIDR' \ 'list-cidrs:List CIDRs' \ 'disable-peer:Disable an enabled peer' \ 'enable-peer:Enable a disabled peer' \ 'add-association:Add an association between CIDRs' \ 'delete-association:Delete an association between CIDRs' \ 'list-associations:List existing assocations between CIDRs' \ 'set-listen-port:Set the local listen port' \ 'override-endpoint:Override your external endpoint that the server sends to other peers' \ 'completions:Generate shell completion scripts' \ 'help:Print this message or the help of the given subcommand(s)' \ ) _describe -t commands 'innernet commands' commands "$@" } (( $+functions[_innernet__add-association_commands] )) || _innernet__add-association_commands() { local commands; commands=() _describe -t commands 'innernet add-association commands' commands "$@" } (( $+functions[_innernet__add-cidr_commands] )) || _innernet__add-cidr_commands() { local commands; commands=() _describe -t commands 'innernet add-cidr commands' commands "$@" } (( $+functions[_innernet__add-peer_commands] )) || _innernet__add-peer_commands() { local commands; commands=() _describe -t commands 'innernet add-peer commands' commands "$@" } (( $+functions[_innernet__completions_commands] )) || _innernet__completions_commands() { local commands; commands=() _describe -t commands 'innernet completions commands' commands "$@" } (( $+functions[_innernet__delete-association_commands] )) || _innernet__delete-association_commands() { local commands; commands=() _describe -t commands 'innernet delete-association commands' commands "$@" } (( $+functions[_innernet__delete-cidr_commands] )) || _innernet__delete-cidr_commands() { local commands; commands=() _describe -t commands 'innernet delete-cidr commands' commands "$@" } (( $+functions[_innernet__disable-peer_commands] )) || _innernet__disable-peer_commands() { local commands; commands=() _describe -t commands 'innernet disable-peer commands' commands "$@" } (( $+functions[_innernet__down_commands] )) || _innernet__down_commands() { local commands; commands=() _describe -t commands 'innernet down commands' commands "$@" } (( $+functions[_innernet__enable-peer_commands] )) || _innernet__enable-peer_commands() { local commands; commands=() _describe -t commands 'innernet enable-peer commands' commands "$@" } (( $+functions[_innernet__fetch_commands] )) || _innernet__fetch_commands() { local commands; commands=() _describe -t commands 'innernet fetch commands' commands "$@" } (( $+functions[_innernet__help_commands] )) || _innernet__help_commands() { local commands; commands=() _describe -t commands 'innernet help commands' commands "$@" } (( $+functions[_innernet__install_commands] )) || _innernet__install_commands() { local commands; commands=() _describe -t commands 'innernet install commands' commands "$@" } (( $+functions[_innernet__list-associations_commands] )) || _innernet__list-associations_commands() { local commands; commands=() _describe -t commands 'innernet list-associations commands' commands "$@" } (( $+functions[_innernet__list-cidrs_commands] )) || _innernet__list-cidrs_commands() { local commands; commands=() _describe -t commands 'innernet list-cidrs commands' commands "$@" } (( $+functions[_innernet__override-endpoint_commands] )) || _innernet__override-endpoint_commands() { local commands; commands=() _describe -t commands 'innernet override-endpoint commands' commands "$@" } (( $+functions[_innernet__rename-peer_commands] )) || _innernet__rename-peer_commands() { local commands; commands=() _describe -t commands 'innernet rename-peer commands' commands "$@" } (( $+functions[_innernet__set-listen-port_commands] )) || _innernet__set-listen-port_commands() { local commands; commands=() _describe -t commands 'innernet set-listen-port commands' commands "$@" } (( $+functions[_innernet__show_commands] )) || _innernet__show_commands() { local commands; commands=() _describe -t commands 'innernet show commands' commands "$@" } (( $+functions[_innernet__uninstall_commands] )) || _innernet__uninstall_commands() { local commands; commands=() _describe -t commands 'innernet uninstall commands' commands "$@" } (( $+functions[_innernet__up_commands] )) || _innernet__up_commands() { local commands; commands=() _describe -t commands 'innernet up commands' commands "$@" } _innernet "$@"