X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=buster%2Fsetup_scripts%2Fsetup_home_eeepc.sh;h=1b54a5682a9dd1fe39d113732db5911ddb8c5daa;hb=9cf85bce08b00c254652cfa929ed55ccafa6f8e5;hp=7dd2f8f690ee80019a65e7716d6b98458ca68349;hpb=722d0def8e15b2f96ef5190e09135f6cb2c1b09d;p=config diff --git a/buster/setup_scripts/setup_home_eeepc.sh b/buster/setup_scripts/setup_home_eeepc.sh index 7dd2f8f..1b54a56 100755 --- a/buster/setup_scripts/setup_home_eeepc.sh +++ b/buster/setup_scripts/setup_home_eeepc.sh @@ -2,12 +2,17 @@ set -e public_repos_dir="${HOME}/public_repos" -config_tree_prefix="${public_repos_dir}/config/buster" -setup_scripts_dir="${config_tree_prefix}/setup_scripts" +config_tree_prefix="${public_repos_dir}/config" +path_borgscript="${config_tree_prefix}/all_new_2018/borg.sh" +config_tree_buster="${config_tree_prefix}/buster" +setup_scripts_dir="${config_tree_buster}/setup_scripts" repos_list_file="${public_repos_dir}/repos" dir_secrets="${HOME}/tmp_secrets" borgkeys_dir=~/.config/borg/keys +borgrepos_file=~/.borgrepos ssh_dir=~/.ssh +authinfo_file=.authinfo +maildir=~/mail/maildir ensure_repo() { repo_name="${1}" @@ -17,12 +22,17 @@ ensure_repo() { fi } +# Clone config to copy dotfiles etc. from it. cd mkdir -p "${public_repos_dir}" ensure_repo config cd "${setup_scripts_dir}" -./copy_dirtree.sh "${config_tree_prefix}/home_files" "${HOME}" minimal user_eeepc +./copy_dirtree.sh "${config_tree_buster}/home_files" "${HOME}" minimal user_eeepc + +# Set up native messenger for tridactyl. curl -fsSl https://raw.githubusercontent.com/tridactyl/tridactyl/78e662efefd1f4af2bdb2a53edecf03b535b997b/native/install.sh | bash + +# Set up non-public parts of infrastructure. cd "${dir_secrets}" mkdir -p "${ssh_dir}" echo "Setting up .ssh" @@ -30,12 +40,46 @@ cp id_rsa ~/.ssh stty -echo ssh-keygen -y -f ~/.ssh/id_rsa > ~/.ssh/id_rsa.pub stty echo +gpg --import secret_keys.asc tar xf borg_keyfiles.tar mkdir -p "${borgkeys_dir}" mv borg_keyfiles/* "${borgkeys_dir}" +# .authinfo may not be present on every secrets drive yet +if [ -f "${authinfo_file}" ]; then + cp "${authinfo_file}" ~ +fi cd rm -rf "${dir_secrets}" + +# Sync org dir via borgbackup. For this we need the borgbackup servers +# in our .ssh/known_hosts file. +cat "${borgrepos_file}" | while read line; do + first_char=$(echo "${line}" | cut -c1) + if [ "${first_char}" = "#" ]; then + continue + fi + server=$(echo "${line}" | sed 's/.*@//') + ssh-keyscan "${server}" >> "${ssh_dir}"/known_hosts +done +BORG_PASSPHRASE="${SECRETS_PASS}" "${path_borgscript}" orgpull + +# Fill ~/public_repos. cat "${repos_list_file}" | while read line; do + first_char=$(echo "${line}" | cut -c1) + if [ "${first_char}" = "#" ]; then + continue + fi ensure_repo "${line}" done + +# Set up e-mail system. Note that we only do mbsync if the imap pass file +# is found. It may not be present on every secrets drive yet, so we have to +# deal with the possibility of it being absent at this point. +mkdir -p "${maildir}" # expected by mbsync/isync +if [ -f "${HOME}/${authinfo_file}" ]; then + mbsync -a + notmuch new +fi + +# Final note on how to integrate tridactyl. echo "TODO: As tridactyl user, don't forget to do :source on the first Firefox run and then re-start."