All checks were successful
Test / Create distribution (push) Successful in 30s
Test / Sandbox (push) Successful in 1m58s
Test / Sandbox (race detector) (push) Successful in 3m11s
Test / Fpkg (push) Successful in 4m24s
Test / Fortify (race detector) (push) Successful in 4m58s
Test / Fortify (push) Successful in 3m44s
Test / Flake checks (push) Successful in 1m34s
Signed-off-by: Ophestra <cat@gensokyo.uk>
82 lines
2.3 KiB
Plaintext
82 lines
2.3 KiB
Plaintext
#compdef fortify
|
|
|
|
_fortify_app() {
|
|
__fortify_files
|
|
return $?
|
|
}
|
|
|
|
_fortify_run() {
|
|
_arguments \
|
|
'--id[Reverse-DNS style Application identifier, leave empty to inherit instance identifier]:id' \
|
|
'-a[Application identity]: :_numbers' \
|
|
'-g[Groups inherited by all container processes]: :_groups' \
|
|
'-d[Container home directory]: :_files -/' \
|
|
'-u[Passwd user name within sandbox]: :_users' \
|
|
'--wayland[Enable connection to Wayland via security-context-v1]' \
|
|
'-X[Enable direct connection to X11]' \
|
|
'--dbus[Enable proxied connection to D-Bus]' \
|
|
'--pulse[Enable direct connection to PulseAudio]' \
|
|
'--dbus-config[Path to session bus proxy config file]: :_files -g "*.json"' \
|
|
'--dbus-system[Path to system bus proxy config file]: :_files -g "*.json"' \
|
|
'--mpris[Allow owning MPRIS D-Bus path]' \
|
|
'--dbus-log[Force buffered logging in the D-Bus proxy]'
|
|
}
|
|
|
|
_fortify_ps() {
|
|
_arguments \
|
|
'--short[List instances only]'
|
|
}
|
|
|
|
_fortify_show() {
|
|
_alternative \
|
|
'instances:domains:__fortify_instances' \
|
|
'files:files:__fortify_files'
|
|
}
|
|
|
|
__fortify_files() {
|
|
_files -g "*.(json|ftfy)"
|
|
return $?
|
|
}
|
|
|
|
__fortify_instances() {
|
|
local -a out
|
|
shift -p
|
|
out=( ${(f)"$(_call_program commands fortify ps --short 2>&1)"} )
|
|
if (( $#out == 0 )); then
|
|
_message "No active instances"
|
|
else
|
|
_describe "active instances" out
|
|
fi
|
|
return $?
|
|
}
|
|
|
|
(( $+functions[_fortify_commands] )) || _fortify_commands()
|
|
{
|
|
local -a _fortify_cmds
|
|
_fortify_cmds=(
|
|
"app:Launch app defined by the specified config file"
|
|
"run:Configure and start a permissive default sandbox"
|
|
"show:Show the contents of an app configuration"
|
|
"ps:List active apps and their state"
|
|
"version:Show fortify version"
|
|
"license:Show full license text"
|
|
"template:Produce a config template"
|
|
"help:Show help message"
|
|
)
|
|
if (( CURRENT == 1 )); then
|
|
_describe -t commands 'action' _fortify_cmds || compadd "$@"
|
|
else
|
|
local curcontext="$curcontext"
|
|
cmd="${${_fortify_cmds[(r)$words[1]:*]%%:*}}"
|
|
if (( $+functions[_fortify_$cmd] )); then
|
|
_fortify_$cmd
|
|
else
|
|
_message "no more options"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
_arguments -C \
|
|
'-v[Verbose output]' \
|
|
'--json[Serialise output in JSON when applicable]' \
|
|
'*::fortify command:_fortify_commands' |