install.fairie/home/.chezmoiscripts/universal/run_before_01-decrypt-age-key.tmpl
Brian Zalewski ab1f625265 Update 28 files
- /home/.chezmoiscripts/universal/run_onchange_after_99-bootstrap-zsh-plugins.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_100-cleanup.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_8-git-hooks.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_7-docker-plugins.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_6-bin-symlink.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_5-log-config.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_4-environment-profile.tmpl
- /home/.chezmoiscripts/universal/run_before_1-decrypt-age-key.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_after_set-wallpaper.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_before_10_install-darwin-dependencies.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_after_10_configure-macos.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_5-install-homebrew.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_8-install-zx.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_9-ensure-node-version.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_95-bootstrap-zsh-plugins.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_98-cleanup.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_08-git-hooks.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_06-bin-symlink.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_05-log-config.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_04-environment-profile.tmpl
- /home/.chezmoiscripts/universal/run_before_01-decrypt-age-key.tmpl
- /home/.chezmoiscripts/universal/run_onchange_after_07-docker-plugins.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_after_21-set-wallpaper.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_before_10-install-darwin-dependencies.tmpl
- /home/.chezmoiscripts/darwin/run_onchange_after_10-configure-macos.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_05-install-homebrew.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_08-install-zx.tmpl
- /home/.chezmoiscripts/_universal/run_onchange_before_09-ensure-node-version.tmpl
2023-01-24 10:18:42 +00:00

33 lines
1.6 KiB
Bash

#!/usr/bin/env bash
{{ includeTemplate "universal/logg" }}
XDG_CONFIG_HOME="$HOME/.config"
### Decrypt private key if it is not already present
if [ ! -f "${XDG_CONFIG_HOME}/age/chezmoi.txt" ]; then
mkdir -p "${XDG_CONFIG_HOME}/age"
logg star '`PRESS ENTER` if you have not set up your encryption token yet'
age --decrypt --output "${XDG_CONFIG_HOME}/age/chezmoi.txt" "{{ .chezmoi.sourceDir }}/key.txt.age" || EXIT_CODE=$?
if [ -n "$EXIT_CODE" ]; then
logg info 'Proceeding without decrypting age encryption key stored at `~/.local/share/chezmoi/home/key.txt.age`'
logg info 'To have Chezmoi handle your encryption (so you can store your private files publicly) take a look at https://shorturl.at/jkpzG'
logg info 'Removing all files that begin with encrypted_ because decryption failed'
find "$HOME/.local/share/chezmoi" -type f -name "encrypted_*" | while read ENCRYPTED_FILE; do
logg info "Removing $ENCRYPTED_FILE"
rm -f "$ENCRYPTED_FILE"
FALLBACK_FILENAME="$(echo "$ENCRYPTED_FILE" | sed 's/encrypted_/encrypted-fallback_/')"
if [ -f "$FALLBACK_FILENAME" ]; then
NEW_FALLBACK_FILENAME="$(echo "$ENCRYPTED_FILE" | sed 's/encrypted-fallback_//')"
cp "$FALLBACK_FILENAME" "$NEW_FALLBACK_FILENAME"
fi
done
fi
fi
### Ensure proper permissions on private key
if [ -f "${XDG_CONFIG_HOME}/age/chezmoi.txt" ]; then
logg info 'Ensuring proper permissions on Chezmoi / age decryption key'
logg info 'Chezmoi / age decryption key is stored in '"${XDG_CONFIG_HOME}/age/chezmoi.txt"
chmod 600 "${XDG_CONFIG_HOME}/age/chezmoi.txt"
fi