From ad9fc14faddb34f8b6002dd4c6cb6e23b21b883c Mon Sep 17 00:00:00 2001 From: Kat Morgan Date: Wed, 7 Feb 2024 06:25:05 +0000 Subject: [PATCH] make entrypoint helpers exit non-critical helper funcs quietly --- .github/docker/slim/bin/devcontainer-links | 46 ++++++++++++---------- .github/docker/slim/bin/entrypoint | 9 +++-- 2 files changed, 32 insertions(+), 23 deletions(-) diff --git a/.github/docker/slim/bin/devcontainer-links b/.github/docker/slim/bin/devcontainer-links index 82c19ac..32f51c0 100755 --- a/.github/docker/slim/bin/devcontainer-links +++ b/.github/docker/slim/bin/devcontainer-links @@ -2,29 +2,35 @@ # Change ownership of all items in /workspaces to the current user user="$(id -u)" -sudo chown "${user}" /workspaces/* 2>/dev/null # Iterate over directories in /workspaces -for dir in /workspaces/*; do - # Check if it's a directory - if [[ -d "${dir}" ]]; then - # Extract the directory name - dir_name=$(basename "${dir}") - - # Check if a symlink already exists in the home directory - if [[ -L "${HOME}/${dir_name}" ]]; then - # Remove the existing symlink if it exists - rm "${HOME}/${dir_name}" - elif [[ -e "${HOME}/${dir_name}" ]]; then - # Skip if it's not a symlink (to avoid destructive actions on actual directories or files) - echo "Skipping ${HOME}/${dir_name}, as it's not a symlink." - continue +run_links() { + + sudo chown "${user}" /workspaces/* 2>/dev/null + + for dir in /workspaces/*; do + # Check if it's a directory + if [[ -d "${dir}" ]]; then + # Extract the directory name + dir_name=$(basename "${dir}") + + # Check if a symlink already exists in the home directory + if [[ -L "${HOME}/${dir_name}" ]]; then + # Remove the existing symlink if it exists + rm "${HOME}/${dir_name}" + elif [[ -e "${HOME}/${dir_name}" ]]; then + # Skip if it's not a symlink (to avoid destructive actions on actual directories or files) + echo "Skipping ${HOME}/${dir_name}, as it's not a symlink." + continue + fi + + # Create a new symbolic link + ln -s "${dir}" "${HOME}/${dir_name}" fi + done +} - # Create a new symbolic link - ln -s "${dir}" "${HOME}/${dir_name}" - fi -done +run_links 2>/dev/null || true # Allow direnv to set environment variables -direnv allow 2>/dev/null +direnv allow 2>/dev/null || true diff --git a/.github/docker/slim/bin/entrypoint b/.github/docker/slim/bin/entrypoint index 2af16c0..e848eed 100755 --- a/.github/docker/slim/bin/entrypoint +++ b/.github/docker/slim/bin/entrypoint @@ -168,11 +168,11 @@ run_ttyd() { # Base Variables export dir_platform=".platform" -export ssh_host_identity_path="/home/${USER}/${dir_platform}/secrets/ssh/host" -export ssh_user_identity_path="/home/${USER}/${dir_platform}/secrets/ssh/user" +export ssh_host_identity_path="/home/$USER/$dir_platform/secrets/ssh/host" +export ssh_user_identity_path="/home/$USER/$dir_platform/secrets/ssh/user" # Validate environment variables -if [ -z "${USER}" ]; then +if [ -z "$USER" ]; then echo "Error: USER environment variable not set" exit 1 fi @@ -204,4 +204,7 @@ else fi run_tmux_keepalive "pulumi" > /dev/null 2>&1 & + +sleep 5 && devcontainer-links || true + sleep infinity