cfg/bin/vault-sshadd

63 lines
1.5 KiB
Text
Raw Permalink Normal View History

2016-07-21 13:48:49 +00:00
#!/bin/bash
set -euo pipefail
source "${HOME}/bin/script_framework.sh"
2016-07-21 13:48:49 +00:00
if ! (which vault >/dev/null); then
2016-07-21 13:48:49 +00:00
error "vault is required."
exit 2
fi
# Require something to be passed to this command
if [ $# -eq 0 ]; then
error "You need to specify a key name."
exit 2
fi
# Create a helper script to send STDIN data to ssh-add
HELPER=$(mktemp)
chmod 0700 ${HELPER}
trap "rm ${HELPER}" EXIT
2016-07-21 13:48:49 +00:00
cat -s <<EOF >${HELPER}
#!/bin/bash -eu
export -n DISPLAY
vault read -field=private "secret/ssh-key/\$1" | exec ssh-add -t 3600 -
EOF
2016-07-21 13:48:49 +00:00
for KEY_NAME in $@; do
fingerprint=$(vault read -field=public "/secret/ssh-key/$1" | ssh-keygen -l -f -)
2016-07-21 13:48:49 +00:00
# If this key is already in the agent we don't need to do anything
if (ssh-add -l | grep -q "${fingerprint}"); then
info "[${KEY_NAME}] Key already present."
2016-07-21 13:48:49 +00:00
continue
fi
# Retrieve key from LastPass
PWD=$(vault read -field=passphrase "secret/ssh-key/${KEY_NAME}")
2016-07-21 13:48:49 +00:00
# In case LastPass exitted non-zero we have no password
if ! [ $? -eq 0 ]; then
error "[${KEY_NAME}] Unable to get password. Not trying to unlock."
2016-07-21 13:48:49 +00:00
continue
fi
# Fill password to ssh-add utility
expect <<EOF >/dev/null
spawn ${HELPER} ${KEY_NAME}
2016-07-21 13:48:49 +00:00
expect "Enter passphrase"
send "$PWD\n"
expect "added:" {exit 0} timeout {exit 1}
2016-07-21 13:48:49 +00:00
EOF
if [ $? -eq 0 ]; then
info "[${KEY_NAME}] Should be loaded by now."
vault-patch --log-level=warn secret/ssh-key/${KEY_NAME} last_used=$(date +%Y-%m-%dT%H:%M:%S%z)
2016-07-21 13:48:49 +00:00
else
error "[${KEY_NAME}] Was not added successfully."
2016-07-21 13:48:49 +00:00
fi
done