Compare commits

...

17 Commits

Author SHA1 Message Date
dd283a2c5f Adding the environment variables of vscode to home user. Updating to version 2.0.13 2024-03-19 19:50:04 +00:00
18fe10675c Updating version to version 2.0.12 and trying to fix isuue. 2024-03-05 22:23:30 +00:00
aabc21eac2 Trying to fix the issue. Updating to version 2.0.11 2024-03-05 20:47:59 +00:00
50708112ac Trying to fix again the issue. Updating to version 2.0.10 2024-03-05 20:02:48 +00:00
f29f99181e Trying to fix. Updatin to version 2.0.9 2024-02-15 23:27:33 +00:00
8e9ef7bfa9 Trying to fix issue. updating to version 2.0.8 2024-02-15 20:18:50 +00:00
762ff44dc8 Fixing sudo issue. 2024-02-15 18:56:28 +00:00
ac7a82f0ca Trying to fix issue. Updating to version 2.0.6 2024-02-15 18:41:29 +00:00
9bac2433a6 Trying to fix. Updating to version 2.0.5 2024-02-15 06:23:40 +00:00
d8a291c82d Trying to fix. Version 2.0.4 2024-02-15 04:07:06 +00:00
3cee54d519 Trying to fix it. 2.0.3 2024-02-15 03:50:50 +00:00
f68ef82de3 Trying to make fix, updating to version 2.0.2 2024-02-15 03:21:00 +00:00
47d6a61a28 Trying to fix user error. Updating to version 2.0.1 2024-02-15 01:44:59 +00:00
b5cbdca7ef Trying to fix user configuration. Updating to version 2.0.0 2024-02-15 01:05:41 +00:00
68bdbd4c61 Trying to fix issue. Updating to version 1.1.6 2024-02-14 21:32:17 +00:00
a164ccadff trying to make user dynamic. 2024-02-14 21:15:23 +00:00
d755728ed8 Returning to the working configuration. Updating to version 1.1.4 2024-02-14 18:48:08 +00:00
3 changed files with 59 additions and 43 deletions

View File

@ -12,6 +12,16 @@ RUN sudo apt-get install -y wget
#Instalando jq
RUN sudo apt-get install -y jq
RUN adduser --gecos '' --disabled-password vscode \
&& echo "vscode ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers.d/nopasswd
RUN ARCH="$(dpkg --print-architecture)" \
&& curl -fsSL "https://github.com/boxboat/fixuid/releases/download/v0.6.0/fixuid-0.6.0-linux-$ARCH.tar.gz" | tar -C /usr/local/bin -xzf - \
&& chown root:root /usr/local/bin/fixuid \
&& chmod 4755 /usr/local/bin/fixuid \
&& mkdir -p /etc/fixuid \
&& printf "user: vscode\ngroup: vscode\n" > /etc/fixuid/config.yml
#Instalando devtunnel
#Comandos que no se deben olvidar correr al crear el devtunnel
#devtunnel user login -g -d
@ -34,4 +44,8 @@ RUN sudo sysctl -w fs.inotify.max_user_watches=524288
ADD ./entrypoint.sh /usr/bin/entrypoint.sh
RUN sudo chmod +x /usr/bin/entrypoint.sh
USER 1000
ENV USER=vscode
WORKDIR /home/vscode
ENTRYPOINT ["/usr/bin/entrypoint.sh"]

86
entrypoint.sh Normal file → Executable file
View File

@ -1,54 +1,56 @@
#!/bin/bash
#if [[ -z "${HOME_USER}" ]]; then
#HOME_USER="vscode"
#fi
set -eu
set -e
# use specified user name or use `vscode` if not specified
HOME_USER="${HOME_USER:-vscode}"
# use specified group name or use the same user name also as the group name
MY_GROUP="${MY_GROUP:-${HOME_USER}}"
# use the specified UID for the user
MY_UID="${MY_UID:-1000}"
# use the specified GID for the user
MY_GID="${MY_GID:-${MY_UID}}"
# check to see if group exists; if not, create it
if grep -q -E "^${MY_GROUP}:" /etc/group > /dev/null 2>&1
then
echo "INFO: Group exists; skipping creation"
else
echo "INFO: Group doesn't exist; creating..."
# create the group
sudo addgroup -g "${MY_GID}" "${MY_GROUP}" || (echo "INFO: Group exists but with a different name; renaming..."; sudo groupmod -g "${MY_GID}" -n "${MY_GROUP}" "$(awk -F ':' '{print $1":"$3}' < /etc/group | grep ":${MY_GID}$" | awk -F ":" '{print $1}')")
if [[ -z "${HOME_USER}" ]]; then
HOME_USER="vscode"
fi
# check to see if user exists; if not, create it
if id -u "${HOME_USER}" > /dev/null 2>&1
then
echo "INFO: User exists; skipping creation"
else
echo "INFO: User doesn't exist; creating..."
# create the user
sudo adduser -u "${MY_UID}" -G "${MY_GROUP}" -h "/home/${HOME_USER}" -s /bin/sh -D "${HOME_USER}"
fi
# addgroup nonroot
#addgroup nonroot
#adduser --disabled-password --gecos "" ${HOME_USER}
# echo "${HOME_USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
#echo "${HOME_USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
# 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.
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
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
sudo -u $HOME_USER -i
# Unfortunately we cannot change $HOME as we cannot move any bind mounts
# nor can we bind mount $HOME into a new home as that requires a privileged container.
# sudo usermod --login "$HOME_USER" vscode
# sudo groupmod -n "$HOME_USER" vscode
# sudo sed -i "/vscode/d" /etc/sudoers.d/nopasswd
# sudo cd /home/${HOME_USER}
sudo chown -R ${HOME_USER}:${HOME_USER} /home/${HOME_USER}
# 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
fi
fi
#Creating extensions folder
sudo mkdir /home/${HOME_USER}/.config/Code
if [ ! -d "/home/${HOME_USER}/.config/Code" ]; then
sudo mkdir -p /home/${HOME_USER}/.config/Code
fi
sudo chmod -R a+rwX /home/${HOME_USER}/.config/Code
sudo mkdir /home/${HOME_USER}/.vscode-server
if [ ! -d "/home/${HOME_USER}/.vscode-server" ]; then
sudo mkdir -p /home/${HOME_USER}/.vscode-server
fi
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode-server
sudo mkdir /home/${HOME_USER}/.vscode-server-insiders
if [ ! -d "/home/${HOME_USER}/.vscode-server-insiders" ]; then
sudo mkdir -p /home/${HOME_USER}/.vscode-server-insiders
fi
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode-server-insiders
# Check if the data.json file exists

View File

@ -1 +1 @@
1.1.3
2.0.13