mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-06-19 12:28:15 -06:00
Compare commits
31 Commits
Author | SHA1 | Date | |
---|---|---|---|
fe2a226190
|
|||
a983adf4ad
|
|||
374d13fe6c
|
|||
d4391139b2
|
|||
13571867ca
|
|||
52b9e7a411
|
|||
04e26f2afc
|
|||
dddaf129f4
|
|||
6525dc4c7e
|
|||
b3609b3d0b
|
|||
dd283a2c5f
|
|||
18fe10675c
|
|||
aabc21eac2
|
|||
50708112ac
|
|||
f29f99181e | |||
8e9ef7bfa9 | |||
762ff44dc8 | |||
ac7a82f0ca | |||
9bac2433a6 | |||
d8a291c82d | |||
3cee54d519 | |||
f68ef82de3 | |||
47d6a61a28 | |||
b5cbdca7ef | |||
68bdbd4c61 | |||
a164ccadff | |||
d755728ed8 | |||
c17566fd5f | |||
f9351861bd | |||
1634a2a507 | |||
8bda7b330b |
17
Dockerfile
17
Dockerfile
@ -12,6 +12,19 @@ RUN sudo apt-get install -y wget
|
||||
#Instalando jq
|
||||
RUN sudo apt-get install -y jq
|
||||
|
||||
RUN sudo apt-get update
|
||||
RUN sudo apt-get install dumb-init
|
||||
|
||||
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 +47,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"]
|
77
entrypoint.sh
Normal file → Executable file
77
entrypoint.sh
Normal file → Executable file
@ -1,18 +1,69 @@
|
||||
#!/bin/bash
|
||||
set -eu
|
||||
|
||||
if [[ -z "${HOME_USER}" ]]; then
|
||||
HOME_USER="vscode"
|
||||
fi
|
||||
|
||||
addgroup nonroot
|
||||
adduser --disabled-password --gecos "" ${HOME_USER}
|
||||
echo "${HOME_USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
|
||||
#addgroup nonroot
|
||||
#adduser --disabled-password --gecos "" ${HOME_USER}
|
||||
#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
|
||||
# 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
|
||||
|
||||
# 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
|
||||
|
||||
# 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
|
||||
|
||||
# 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
|
||||
|
||||
# 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
|
||||
|
||||
# sudo cd /home/${HOME_USER}
|
||||
sudo chown -R ${HOME_USER}:${HOME_USER} /home/${HOME_USER}
|
||||
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
|
||||
@ -20,8 +71,8 @@ if [ -f "/home/extensions.json" ]; then
|
||||
# Read the JSON file into a variable
|
||||
jsonExtensions=$(cat /home/extensions.json)
|
||||
|
||||
# Use jq to extract the array elements
|
||||
extensions=$(echo $jsonExtensions | jq -r '.[]')
|
||||
# Use jq to extract the extension parameter from the JSON array
|
||||
extensions=$(echo $jsonExtensions | jq -r '.[].extensionsGroup.extensions[].uniqueIdentifier')
|
||||
|
||||
# Loop through the extensions and process each element
|
||||
for extension in $extensions; do
|
||||
@ -37,8 +88,14 @@ 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
|
||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
||||
exec dumb-init sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms $@"
|
||||
else
|
||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
||||
exec dumb-init sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME} $@"
|
||||
fi
|
||||
|
36
readme.md
36
readme.md
@ -19,12 +19,38 @@ The following environment variables can be set when running the Docker container
|
||||
|
||||
### Adding VSCode Extensions
|
||||
|
||||
To add VSCode extensions to the container, create a JSON file with an array of strings containing the extension identifier of each extension you want to install. For example:
|
||||
To add VSCode extensions to the container, create a JSON file with an array of objects containing the extension details you want to install, the only Mandatory field is uniqueIdentifier and follow this structure. For example:
|
||||
```
|
||||
[
|
||||
"ms-python.python",
|
||||
"ms-vscode.cpptools",
|
||||
"ms-azuretools.vscode-docker"
|
||||
[
|
||||
{
|
||||
"extensionsGroup": {
|
||||
"description": "Extensions of Spanish Language Pack",
|
||||
"extensions": [
|
||||
{
|
||||
"name": "Spanish Language Pack for Visual Studio Code",
|
||||
"notes": "Extension of Spanish Language Pack for Visual Studio Code",
|
||||
"uniqueIdentifier": "ms-ceintl.vscode-language-pack-es"
|
||||
}
|
||||
]
|
||||
}
|
||||
},
|
||||
{
|
||||
"extensionsGroup": {
|
||||
"description": "Extensions of Github Copilot",
|
||||
"extensions": [
|
||||
{
|
||||
"name": "GitHub Copilot",
|
||||
"notes": "Extension of GitHub Copilot",
|
||||
"uniqueIdentifier": "github.copilot"
|
||||
},
|
||||
{
|
||||
"name": "GitHub Copilot Chat",
|
||||
"notes": "Extension of GitHub Copilot Chat",
|
||||
"uniqueIdentifier": "github.copilot-chat"
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
]
|
||||
```
|
||||
|
||||
|
2
version.txt
Normal file → Executable file
2
version.txt
Normal file → Executable file
@ -1 +1 @@
|
||||
1.0.25
|
||||
2.0.23
|
Reference in New Issue
Block a user