|
|
|
@ -134,6 +134,7 @@ function main(){
|
|
|
|
groups_def_dir="${repo_root}/groups"
|
|
|
|
groups_def_dir="${repo_root}/groups"
|
|
|
|
opt_list_groups=0
|
|
|
|
opt_list_groups=0
|
|
|
|
groups_list=()
|
|
|
|
groups_list=()
|
|
|
|
|
|
|
|
opt_find_secrets=0
|
|
|
|
secrets_file_list=()
|
|
|
|
secrets_file_list=()
|
|
|
|
|
|
|
|
|
|
|
|
while (( $# >= 1 ));do
|
|
|
|
while (( $# >= 1 ));do
|
|
|
|
@ -149,6 +150,8 @@ function main(){
|
|
|
|
-lg|--list_groups) opt_list_groups=1 ;;
|
|
|
|
-lg|--list_groups) opt_list_groups=1 ;;
|
|
|
|
# ARGS: [optional] [list] specify "groups" which correspond to e.g. job groups, projects, etc
|
|
|
|
# ARGS: [optional] [list] specify "groups" which correspond to e.g. job groups, projects, etc
|
|
|
|
-g|--group) groups_list+=( "${2}" ); shift ;;
|
|
|
|
-g|--group) groups_list+=( "${2}" ); shift ;;
|
|
|
|
|
|
|
|
# ARGS: [optional] update all "secrets.yaml" files found below .sops.yaml location
|
|
|
|
|
|
|
|
-f|--find_secrets) opt_find_secrets=1;;
|
|
|
|
# ARGS: [optional] [list] specify files containing sops-encrypted secrets
|
|
|
|
# ARGS: [optional] [list] specify files containing sops-encrypted secrets
|
|
|
|
-s|--secrets_file|-f|--file) secrets_file_list+=( "${2}" ); shift ;;
|
|
|
|
-s|--secrets_file|-f|--file) secrets_file_list+=( "${2}" ); shift ;;
|
|
|
|
# ARGS: [optional] [list] specify files containing sops-encrypted secrets
|
|
|
|
# ARGS: [optional] [list] specify files containing sops-encrypted secrets
|
|
|
|
@ -182,12 +185,19 @@ function main(){
|
|
|
|
# locate appropriate sops config if default assumption not found
|
|
|
|
# locate appropriate sops config if default assumption not found
|
|
|
|
# dev note: '2> /dev/null' to disable debug output
|
|
|
|
# dev note: '2> /dev/null' to disable debug output
|
|
|
|
sops_config="$(fn_sops_locate_config_in_git_repo 2> /dev/null)"
|
|
|
|
sops_config="$(fn_sops_locate_config_in_git_repo 2> /dev/null)"
|
|
|
|
|
|
|
|
sops_config_dir="$(basename "${sops_config}")"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Paths to Secrets Files
|
|
|
|
if [[ "${#secrets_file_list[@]}" != "0" ]]; then
|
|
|
|
if [[ "${#secrets_file_list[@]}" != "0" ]]; then
|
|
|
|
for secrets_file in "${secrets_file_list[@]}"; do
|
|
|
|
for secrets_file in "${secrets_file_list[@]}"; do
|
|
|
|
test -e "${secrets_file}" || (echo "E: could not locate file with secrets, tried: ${secrets_file}" && exit 1)
|
|
|
|
test -e "${secrets_file}" || (echo "E: could not locate file with secrets, tried: ${secrets_file}" && exit 1)
|
|
|
|
done
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ "${opt_find_secrets}" -eq 1 ]]; then
|
|
|
|
|
|
|
|
found_secrets_file_list="$(find "${sops_config_dir}" -name secrets.yaml)"
|
|
|
|
|
|
|
|
secrets_file_list+=("$(find "${sops_config_dir}" -name secrets.yaml)")
|
|
|
|
|
|
|
|
fi
|
|
|
|
# /VALIDATE INPUTS
|
|
|
|
# /VALIDATE INPUTS
|
|
|
|
# /OPTIONS: ARGPARSING and VALIDATION
|
|
|
|
# /OPTIONS: ARGPARSING and VALIDATION
|
|
|
|
|
|
|
|
|
|
|
|
|