95 lines
3.2 KiB
Bash
95 lines
3.2 KiB
Bash
#compdef ansible-vault
|
|
# ------------------------------------------------------------------------------
|
|
# Copyright (c) 2016 Github zsh-users - http://github.com/zsh-users
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# * Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# * Neither the name of the zsh-users nor the
|
|
# names of its contributors may be used to endorse or promote products
|
|
# derived from this software without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
# DISCLAIMED. IN NO EVENT SHALL ZSH-USERS BE LIABLE FOR ANY
|
|
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
# ------------------------------------------------------------------------------
|
|
# Description
|
|
# -----------
|
|
#
|
|
# Completion script for ansible v1.9.2 (http://ansible.org)
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
# Authors
|
|
# -------
|
|
#
|
|
# * Rick van Hattem (https://github.com/wolph)
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
#
|
|
|
|
_ansible-vault-commands() {
|
|
local -a commands
|
|
|
|
commands=(
|
|
'create:Create new encrypted file'
|
|
'decrypt:Decrypt encrypted file'
|
|
'edit:Edit encrypted file'
|
|
'encrypt:Encrypt unencrypted file'
|
|
'rekey:Change password for encrypted file'
|
|
'view:View encrypted file'
|
|
)
|
|
|
|
_arguments -s : $nul_args && ret=0
|
|
_describe -t commands 'ansible-vault command' commands && ret=0
|
|
}
|
|
|
|
_ansible-vault-command(){
|
|
args=(
|
|
'--debug[enable debugging]' \
|
|
'--vault-password-file[vault password file]:password_file:_files'
|
|
$nul_args
|
|
"1::file_name:_files"
|
|
)
|
|
_arguments -s : $args && ret=0
|
|
}
|
|
|
|
_ansible-vault() {
|
|
local -a nul_args
|
|
nul_args=(
|
|
'(-h --help)'{-h,--help}'[show help message and exit.]'
|
|
)
|
|
|
|
local curcontext=$curcontext ret=1
|
|
|
|
if ((CURRENT == 2)); then
|
|
_ansible-vault-commands
|
|
else
|
|
shift words
|
|
(( CURRENT -- ))
|
|
curcontext="${curcontext%:*:*}:ansible-vault-$words[1]:"
|
|
_call_function ret _ansible-vault-command
|
|
fi
|
|
}
|
|
|
|
_ansible-vault "$@"
|
|
|
|
# Local Variables:
|
|
# mode: Shell-Script
|
|
# sh-indentation: 2
|
|
# indent-tabs-mode: nil
|
|
# sh-basic-offset: 2
|
|
# End:
|
|
# vim: ft=zsh sw=2 ts=2 et
|