| 1234567891011121314151617181920212223242526272829303132333435363738394041 |
- #!/usr/bin/env bash
- set -euo pipefail
- PASS_BASE="personal/ssh"
- STORE_ROOT="${PASSWORD_STORE_DIR:-$HOME/.password-store}"
- ABS_BASE_PATH="${STORE_ROOT}/${PASS_BASE}"
- # Ensure ssh-agent is running
- if [[ -z "${SSH_AUTH_SOCK:-}" ]]; then
- eval "$(ssh-agent -s)"
- fi
- # Verify the base path exists
- if [[ ! -d "$ABS_BASE_PATH" ]]; then
- echo "ERROR: Base path not found in pass: $PASS_BASE" >&2
- exit 1
- fi
- # Loop through each identity subdirectory
- while IFS= read -r dir; do
- IDENTITY=$(basename "$dir")
-
- # Find the latest .gpg file by name (ISO sort)
- LATEST_FILE=$(find "$dir" -maxdepth 1 -name "*.gpg" -printf "%f\n" \
- | sed 's/\.gpg$//' \
- | sort -r \
- | head -n 1)
- if [[ -z "$LATEST_FILE" ]]; then
- continue
- fi
- echo "Injecting $IDENTITY ($LATEST_FILE) into ssh-agent..."
-
- # Decrypt and pipe directly to ssh-add
- # The '-' tells ssh-add to read the key from standard input (stdin)
- pass show "${PASS_BASE}/${IDENTITY}/${LATEST_FILE}" | ssh-add - >/dev/null 2>&1
- done < <(find "$ABS_BASE_PATH" -mindepth 1 -maxdepth 1 -type d)
- echo "Done. All latest keys injected into agent."
|