completions/zfs: Add encryption-related completions

This commit is contained in:
Mahmoud Al-Qudsi 2025-01-11 10:40:09 -06:00
parent 4a6d8d0b3a
commit f8b245eb31
2 changed files with 38 additions and 1 deletions

View file

@ -46,7 +46,7 @@ function __fish_zfs_needs_command
set bookmark bookmark set bookmark bookmark
end end
not __fish_seen_subcommand_from \? create destroy snap{,shot} rollback clone promote rename list set get inherit upgrade {user,group}space {u,un,}mount {un,}share $bookmark send receive recv {un,}allow hold{s,} release diff program not __fish_seen_subcommand_from \? create destroy snap{,shot} rollback clone promote rename list set get inherit upgrade {user,group}space {u,un,}mount {un,}share $bookmark send receive recv {un,}allow hold{s,} release diff program load-key unload-key change-key
end end
function __fish_zfs_using_command # ZFS command whose completions are looked for function __fish_zfs_using_command # ZFS command whose completions are looked for
@ -161,6 +161,9 @@ function __fish_zfs_complete_property_values -a name
casesensitivity=sensitive|insensitive|mixed casesensitivity=sensitive|insensitive|mixed
normalization=none|formC|formD|formKC|formKD normalization=none|formC|formD|formKC|formKD
utf8only=on|off utf8only=on|off
keyformat=raw|passphrase|hex
keylocation=stdin|file:///
encryption=off|on|aes-128-ccm|aes-192-ccm|aes-256-ccm|aes-128-gcm|aes-192-gcm|aes-256-gcm
" "
# Convert the list above into an array of strings # Convert the list above into an array of strings
set all_options (string split \n -- $all_options | string trim) set all_options (string split \n -- $all_options | string trim)
@ -355,6 +358,11 @@ complete -c zfs -f -n __fish_zfs_needs_command -a diff -d 'List changed files be
if test $OS = SunOS # This is currently only supported under Illumos, but that will probably change if test $OS = SunOS # This is currently only supported under Illumos, but that will probably change
complete -c zfs -f -n __fish_zfs_needs_command -a program -d 'Execute a ZFS Channel Program' complete -c zfs -f -n __fish_zfs_needs_command -a program -d 'Execute a ZFS Channel Program'
end end
if __fish_is_openzfs
complete -c zfs -f -n __fish_zfs_needs_command -a load-key -d "Load encryption key for dataset"
complete -c zfs -f -n __fish_zfs_needs_command -a unload-key -d "Unload encryption key for dataset"
complete -c zfs -f -n __fish_zfs_needs_command -a change-key -d "Change wrapper encryption key for dataset"
end
# Completions hereafter try to follow the man pages commands order, for maintainability, at the cost # Completions hereafter try to follow the man pages commands order, for maintainability, at the cost
# of multiple if statements. # of multiple if statements.
@ -603,3 +611,26 @@ if test $OS = SunOS # This is currently only supported under Illumos, but that w
complete -c zfs -x -n '__fish_zfs_using_command program' -s t -d 'Execution memory limit' complete -c zfs -x -n '__fish_zfs_using_command program' -s t -d 'Execution memory limit'
complete -c zfs -x -n '__fish_zfs_using_command program' -d 'Pool program will be executed on' -a '(__fish_complete_zfs_pools)' complete -c zfs -x -n '__fish_zfs_using_command program' -d 'Pool program will be executed on' -a '(__fish_complete_zfs_pools)'
end end
# encryption-related completions
complete -c zfs -f -n '__fish_zfs_using_command load-key' -s n -d 'Dry run; checks but doesn\'t load'
complete -c zfs -f -n '__fish_zfs_using_command load-key' -s r -d 'Recursively load key for child datasets'
complete -c zfs -f -n '__fish_zfs_using_command load-key' -s a -d 'Load keys for all imported pools'
complete -c zfs -n '__fish_zfs_using_command load-key' -s L -d 'Key location' -r
# todo: maybe query properties to list only encrypted datasets (that haven't had their keys loaded)
complete -c zfs -n '__fish_zfs_using_command load-key' -d 'Dataset to load key for' -xa '(__fish_print_zfs_filesystems; __fish_print_zfs_volumes)'
complete -c zfs -f -n '__fish_zfs_using_command unload-key' -s r -d 'Recursively unload key for child datasets'
complete -c zfs -f -n '__fish_zfs_using_command unload-key' -s a -d 'Unload keys for all imported pools'
# todo: maybe query properties to list only encrypted datasets (that have had their keys loaded)
complete -c zfs -n '__fish_zfs_using_command unload-key' -d 'Dataset to unload key for' -xa '(__fish_print_zfs_filesystems; __fish_print_zfs_volumes)'
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s l -d 'Ensure key is loaded before changing key'
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s i -d 'Inherit key from its parent'
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s o -xa "keylocation=file:///" -d "Absolute path to key"
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s o -xa "keylocation=prompt" -d "Obtain key from stdin"
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s o -xa "keyformat=hex keyformat=raw keyformat=passphrase"
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s o -xa "keyformat=hex keyformat=raw keyformat=passphrase"
complete -c zfs -f -n '__fish_zfs_using_command change-key' -s o -xa "pbkdf2iters=" -d "Specify PBKDF2 iteration count"
# todo: maybe query properties to list only encrypted datasets
complete -c zfs -f -n '__fish_zfs_using_command change-key' -d "Dataset to change wraper key for" -xa "(__fish_print_zfs_filesystems; __fish_print_zfs_volumes)"

View file

@ -27,4 +27,10 @@ function __fish_complete_zfs_write_once_properties -d "Completes with ZFS proper
else else
echo -e "casesensitivity\tCase sensitivity (sensitive, insensitive, mixed)" echo -e "casesensitivity\tCase sensitivity (sensitive, insensitive, mixed)"
end end
if __fish_is_openzfs
echo -e "keylocation\tSpecify key location/type"
echo -e "pbkdf2iters\tNumber of PBKDF2 iterations"
echo -e "keyformat\tSpecify key format"
echo -e "encryption\tEncryption of dataset"
end
end end