2014-03-01 03:27:49 +01:00
# systemd-nspawn(1) completion -*- shell-script -*-
2017-11-18 18:21:19 +01:00
# SPDX-License-Identifier: LGPL-2.1+
2014-03-01 03:27:49 +01:00
#
# This file is part of systemd.
#
# Copyright 2014 Thomas H.P. Andersen
#
# systemd is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
#
# systemd is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with systemd; If not, see <http://www.gnu.org/licenses/>.
__contains_word() {
local w word=$1; shift
for w in "$@"; do
[[ $w = "$word" ]] && return
done
}
__get_users() {
local a b
loginctl list-users --no-legend --no-pager | { while read a b; do echo " $b"; done; };
}
__get_slices() {
local a b
systemctl list-units -t slice --no-legend --no-pager | { while read a b; do echo " $a"; done; };
}
2015-01-08 21:51:49 +01:00
__get_machines() {
local a b
machinectl list --no-legend --no-pager | { while read a b; do echo " $a"; done; };
}
__get_env() {
local a
env | { while read a; do echo " ${a%%=*}"; done; };
}
__get_interfaces(){
2016-02-16 18:17:01 -05:00
{ cd /sys/class/net && echo *; } | \
while read -d' ' -r name; do
[[ "$name" != "lo" ]] && echo "$name"
done
2015-01-08 21:51:49 +01:00
}
2014-03-01 03:27:49 +01:00
_systemd_nspawn() {
local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]}
local i verb comps
local -A OPTS=(
2018-01-10 23:20:45 +09:00
[STANDALONE]='-h --help --version --private-network -b --boot --read-only -q --quiet --share-system --keep-unit -n --network-veth
-j -x --ephemeral -a --as-pid2 --private-users-chown -U'
[ARG]='-D --directory -u --user --uuid --capability --drop-capability --link-journal --bind --bind-ro -M --machine
-S --slice -E --setenv -Z --selinux-context -L --selinux-apifs-context --register --network-interface --network-bridge
--personality -i --image --tmpfs --volatile --network-macvlan --kill-signal --template --notify-ready --root-hash
--chdir --pivot-root --property --private-users --network-namespace-path --network-ipvlan --network-veth-extra
--network-zone -p --port --system-call-filter --overlay --overlay-ro --settings'
2014-03-01 03:27:49 +01:00
)
_init_completion || return
if __contains_word "$prev" ${OPTS[ARG]}; then
case $prev in
2016-03-20 17:55:58 +00:00
--directory|-D|--template)
2015-01-08 21:51:49 +01:00
compopt -o nospace
comps=$(compgen -S/ -A directory -- "$cur" )
2014-03-01 03:27:49 +01:00
;;
--user|-u)
comps=$( __get_users )
;;
2018-01-10 23:20:45 +09:00
--uuid|--root-hash)
2014-03-01 03:27:49 +01:00
comps=''
;;
--capability)
comps='CAP_BLOCK_SUSPEND CAP_IPC_LOCK CAP_MAC_ADMIN CAP_MAC_OVERRIDE CAP_SYS_MODULE CAP_SYS_PACCT CAP_SYS_RAWIO
CAP_SYS_TIME CAP_SYSLOG CAP_WAKE_ALARM CAP_NET_ADMIN'
;;
--drop-capability)
comps='CAP_AUDIT_CONTROL CAP_AUDIT_WRITE CAP_CHOWN CAP_DAC_OVERRIDE CAP_DAC_READ_SEARCH CAP_FOWNER CAP_FSETID
CAP_IPC_OWNER CAP_KILL CAP_LEASE CAP_LINUX_IMMUTABLE CAP_MKNOD CAP_NET_ADMIN CAP_NET_BIND_SERVICE
CAP_NET_BROADCAST CAP_NET_RAW CAP_SETFCAP CAP_SETGID CAP_SETPCAP CAP_SETUID CAP_SYS_ADMIN CAP_SYS_BOOT
CAP_SYS_CHROOT CAP_SYS_NICE CAP_SYS_PTRACE CAP_SYS_RESOURCE CAP_SYS_TTY_CONFIG'
;;
--link-journal)
2015-09-26 03:59:56 +03:00
comps='no auto guest try-guest host try-host'
2014-03-01 03:27:49 +01:00
;;
--bind|--bind-ro)
2015-01-08 21:51:49 +01:00
compopt -o nospace
comps=$(compgen -S/ -A directory -- "$cur" )
;;
--tmpfs)
compopt -o nospace
comps=$(compgen -S/ -A directory -- "$cur" )
2014-03-01 03:27:49 +01:00
;;
--machine|-M)
2015-01-08 21:51:49 +01:00
comps=$( __get_machines )
2014-03-01 03:27:49 +01:00
;;
--slice|-S)
comps=$( __get_slices )
;;
2018-01-10 23:20:45 +09:00
--setenv|-E)
2015-01-08 21:51:49 +01:00
comps=$( __get_env )
2014-03-01 03:27:49 +01:00
;;
--selinux-context|-Z)
comps=''
;;
--selinux-apifs-context|-L)
comps=''
;;
--register)
comps='yes no'
;;
--network-interface)
2015-01-08 21:51:49 +01:00
comps=$(__get_interfaces)
2014-03-01 03:27:49 +01:00
;;
--network-bridge)
comps=''
;;
2015-01-08 21:51:49 +01:00
--network-macvlan)
comps=''
;;
2014-03-01 03:27:49 +01:00
--personality)
comps='x86 x86-64'
;;
2015-01-08 21:51:49 +01:00
--volatile)
comps='yes state no'
;;
2014-04-11 00:48:19 +02:00
--image|-i)
2015-01-08 21:51:49 +01:00
compopt -o nospace
2014-04-11 00:48:19 +02:00
comps=$( compgen -A file -- "$cur" )
;;
2015-11-23 14:58:22 +00:00
--kill-signal)
2015-11-24 09:39:27 -05:00
_signals
return
2015-11-23 14:58:22 +00:00
;;
2016-07-08 17:44:20 +02:00
--notify-ready)
comps='yes no'
2018-01-10 23:20:45 +09:00
;;
--private-users)
comps='yes no pick'
;;
--network-namespace-path)
comps=$( compgen -A file -- "$cur" )
;;
--settings)
comps='yes no override trusted'
2016-07-08 17:44:20 +02:00
;;
2014-03-01 03:27:49 +01:00
esac
COMPREPLY=( $(compgen -W '$comps' -- "$cur") )
return 0
fi
COMPREPLY=( $(compgen -W '${OPTS[*]}' -- "$cur") )
}
complete -F _systemd_nspawn systemd-nspawn