rekey 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. USER="${USER:-$(whoami)}"
  4. HOST="${HOST:-$(hostname -s 2>/dev/null || hostname)}"
  5. DATE="$(date +%F)"
  6. SSH_DIR="$HOME/.ssh"
  7. mkdir -p "$SSH_DIR"
  8. PASS_PATH="personal/ssh/$USER@$HOST/$DATE"
  9. # --- Temporary directory for private key (macOS compatible) ---
  10. # Tries /dev/shm if present (Linux), otherwise falls back to standard temp.
  11. if [[ -d /dev/shm && -w /dev/shm ]]; then
  12. TMPDIR_BASE="/dev/shm"
  13. else
  14. TMPDIR_BASE="${TMPDIR:-/tmp}"
  15. fi
  16. TMP_WORKDIR="$(mktemp -d "$TMPDIR_BASE/sshkey.${USER}.${HOST}.${DATE}.XXXXXX")"
  17. TMP_PRIV="$TMP_WORKDIR/id_ed25519"
  18. cleanup() {
  19. # best-effort secure cleanup: delete key material and remove temp dir
  20. rm -f "$TMP_PRIV" "$TMP_PRIV.pub" 2>/dev/null || true
  21. rmdir "$TMP_WORKDIR" 2>/dev/null || true
  22. }
  23. trap cleanup EXIT INT TERM
  24. # Generate Ed25519 key pair into temp dir
  25. ssh-keygen -t ed25519 -f "$TMP_PRIV" -N "" -q
  26. # Insert private key into pass
  27. pass insert --multiline --force "$PASS_PATH" < "$TMP_PRIV"
  28. echo "Private key stored in pass at $PASS_PATH"
  29. # Extract public key from the same temp file
  30. ssh-keygen -y -f "$TMP_PRIV" > "$SSH_DIR/$USER@$HOST.pub"
  31. chmod 600 "$SSH_DIR/$USER@$HOST.pub" 2>/dev/null || true
  32. echo "Public key written to $SSH_DIR/$USER@$HOST.pub"
  33. # Temp key removed automatically by trap