mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-06-18 20:08:13 -06:00
Compare commits
32 Commits
Author | SHA1 | Date | |
---|---|---|---|
6519cc3ef9
|
|||
c27e148488
|
|||
cd8b5c19e1
|
|||
a6e4296f25
|
|||
08cf40624d
|
|||
a3b5fe1d6d
|
|||
99812ff71c
|
|||
d8a8162ffd
|
|||
32d405aa80
|
|||
2a98fcce78
|
|||
3ab91f9f5f
|
|||
840fdfaf1e
|
|||
f7a5094cc3
|
|||
22f0003c53
|
|||
b08429c9ae
|
|||
7f81f891ab
|
|||
66c96f1fe7
|
|||
1e5523c1f7
|
|||
390f9cdc15
|
|||
f9503fe827
|
|||
c50b9e969f
|
|||
f9b4e4644a
|
|||
01410a3ccd
|
|||
cb4bf58db9
|
|||
ed98e9a48c
|
|||
2ab5fcffc7
|
|||
c1acddcc6e
|
|||
a9b021cebe
|
|||
fd7e35cf34
|
|||
f929aaac63
|
|||
c1affb8781
|
|||
dfeddf9688
|
@ -1,13 +1,15 @@
|
||||
#!/bin/bash
|
||||
set -eu
|
||||
|
||||
if [[ -z "${HOME_USER}" ]]; then
|
||||
HOME_USER="vscode"
|
||||
# Check if we are root
|
||||
if [ "$(id -u)" != "0" ]; then
|
||||
echo "This script must be run as root" 1>&2
|
||||
exec sudo /usr/bin/entrypoint.sh
|
||||
fi
|
||||
|
||||
#addgroup nonroot
|
||||
#adduser --disabled-password --gecos "" ${HOME_USER}
|
||||
#echo "${HOME_USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
|
||||
if [[ -z "${HOME_USER-}" ]]; then
|
||||
HOME_USER="vscode"
|
||||
fi
|
||||
|
||||
# We do this first to ensure sudo works below when renaming the user.
|
||||
# Otherwise the current container UID may not exist in the passwd database.
|
||||
@ -15,40 +17,65 @@ eval "$(fixuid -q)"
|
||||
|
||||
if [ "${HOME_USER-}" ]; then
|
||||
USER="$HOME_USER"
|
||||
if [ "$HOME_USER" != "$(whoami)" ]; then
|
||||
# if ! id -u $HOME_USER > /dev/null 2>&1; then
|
||||
# Create a user with the same UID as the host user.
|
||||
# sudo adduser --disabled-password --gecos "" ${HOME_USER}
|
||||
# sudo echo "$HOME_USER ALL=(ALL) NOPASSWD:ALL" | sudo tee -a /etc/sudoers.d/nopasswd > /dev/null
|
||||
if [[ "${HOME_USER-}" == "vscode" ]]; then
|
||||
if ! id -u $HOME_USER > /dev/null 2>&1; then
|
||||
sudo adduser --disabled-password --gecos "" ${HOME_USER}
|
||||
sudo echo "$HOME_USER ALL=(ALL) NOPASSWD:ALL" | sudo tee -a /etc/sudoers.d/nopasswd > /dev/null
|
||||
fi
|
||||
|
||||
# Set the default shell to bash for VS Code Remote - Containers
|
||||
# sudo usermod --login "$HOME_USER" vscode
|
||||
# sudo groupmod -n "$HOME_USER" vscode
|
||||
# sudo sed -i "/vscode/d" /etc/sudoers.d/nopasswd
|
||||
sudo cp -R /home/vscode/. /home/${HOME_USER}/
|
||||
|
||||
# Crear el nuevo directorio home si no existe
|
||||
# if [ -d "/home/${HOME_USER}" ]; then
|
||||
# Si existe, hacer una copia de seguridad de los archivos existentes
|
||||
# sudo mv /home/${HOME_USER} /home/${HOME_USER}_backup
|
||||
# fi
|
||||
# Check if .bashrc file exists
|
||||
if [ ! -f "/home/${HOME_USER}/.bashrc" ]; then
|
||||
# If not, create it
|
||||
sudo touch /home/${HOME_USER}/.bashrc
|
||||
fi
|
||||
|
||||
# Cambiar el directorio home del usuario vscode a /home/${HOME_USER}
|
||||
# sudo usermod -d /home/${HOME_USER} -m vscode
|
||||
# sudo usermod -d /home/${HOME_USER} vscode
|
||||
# Change the owner of the .bashrc file to HOME_USER
|
||||
sudo chown ${HOME_USER} /home/${HOME_USER}/.bashrc
|
||||
|
||||
# su - ${HOME_USER}
|
||||
# fi
|
||||
# Copy environment variables from vscode user to HOME_USER
|
||||
# env | grep -v 'HOME_USER' | while read -r line; do
|
||||
# sudo su - ${HOME_USER} -c "echo 'export $line' >> ~/.bashrc"
|
||||
# done
|
||||
# sudo -u $HOME_USER -i
|
||||
env | grep -v 'HOME_USER' | while read -r line; do
|
||||
sudo su - ${HOME_USER} -c "echo 'export $line' >> ~/.bashrc"
|
||||
done
|
||||
|
||||
# sudo cd /home/${HOME_USER}
|
||||
sudo chown -R ${HOME_USER}:${HOME_USER} /home/${HOME_USER}
|
||||
# Copy the .bashrc file from vscode user to HOME_USER
|
||||
sudo su - ${HOME_USER} -c "cat /home/vscode/.bashrc >> ~/.bashrc"
|
||||
|
||||
# Creating .vscode folder if it doesn't exist
|
||||
if [ ! -d "/home/${HOME_USER}/.vscode" ]; then
|
||||
sudo mkdir -p /home/${HOME_USER}/.vscode
|
||||
fi
|
||||
|
||||
# Changing the property of the directory /home/${HOME_USER}/.vscode
|
||||
sudo chown -R ${HOME_USER}: /home/${HOME_USER}/.vscode
|
||||
|
||||
# Changing the HOME_USER in the .bashrc file
|
||||
sudo su - ${HOME_USER} -c "sudo sed -i \"s|/home/vscode|/home/${HOME_USER}|g\" ~/.bashrc"
|
||||
|
||||
# Switch to the user specified by $HOME_USER and start an interactive shell session.
|
||||
sudo su -l ${HOME_USER}
|
||||
|
||||
# Copy the HOME variable from vscode user to HOME_USER
|
||||
sudo su -l ${HOME_USER} -c "echo \"export HOME=/home/${HOME_USER}\" >> ~/.bashrc"
|
||||
|
||||
# Source the .bashrc file to apply the changes immediately
|
||||
sudo su -l ${HOME_USER} -c "source ~/.bashrc"
|
||||
|
||||
# Delete the vscode user
|
||||
if id "vscode" &>/dev/null; then
|
||||
sudo chown -R vscode:vscode /home/vscode
|
||||
sudo userdel -r vscode
|
||||
fi
|
||||
else
|
||||
# Switch to the user specified by $HOME_USER and start an interactive shell session.
|
||||
sudo su -l ${HOME_USER}
|
||||
fi
|
||||
fi
|
||||
|
||||
# Add LS_COLORS variable to .bashrc
|
||||
LS_COLORS_VALUE="rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=00:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.zst=01;31:*.tzst=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=01;31:*.wim=01;31:*.swm=01;31:*.dwm=01;31:*.esd=01;31:*.jpg=01;35:*.jpeg=01;35:*.mjpg=01;35:*.mjpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.m4a=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.oga=00;36:*.opus=00;36:*.spx=00;36:*.xspf=00;36:"
|
||||
sudo su - ${HOME_USER} -c "echo 'export LS_COLORS=\"$LS_COLORS_VALUE\"' >> ~/.bashrc"
|
||||
|
||||
#Creating extensions folder
|
||||
if [ ! -d "/home/${HOME_USER}/.config/Code" ]; then
|
||||
@ -88,14 +115,8 @@ else
|
||||
echo "File extensions.json not found"
|
||||
fi
|
||||
|
||||
# Allow users to have scripts run on container startup to prepare workspace.
|
||||
# https://github.com/coder/code-server/issues/5177
|
||||
#if [ -d "${ENTRYPOINTD}" ]; then
|
||||
#find "${ENTRYPOINTD}" -type f -executable -print -exec {} \;
|
||||
#fi
|
||||
|
||||
if [[ -z "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||
exec dumb-init sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms $@"
|
||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
||||
else
|
||||
exec dumb-init sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME} $@"
|
||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
||||
fi
|
||||
|
@ -1 +1 @@
|
||||
2.0.23
|
||||
2.0.56
|
Reference in New Issue
Block a user