mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-06-18 20:08:13 -06:00
Compare commits
80 Commits
Author | SHA1 | Date | |
---|---|---|---|
2a98fcce78
|
|||
3ab91f9f5f
|
|||
840fdfaf1e
|
|||
f7a5094cc3
|
|||
22f0003c53
|
|||
b08429c9ae
|
|||
7f81f891ab
|
|||
66c96f1fe7
|
|||
1e5523c1f7
|
|||
390f9cdc15
|
|||
f9503fe827
|
|||
c50b9e969f
|
|||
f9b4e4644a
|
|||
01410a3ccd
|
|||
cb4bf58db9
|
|||
ed98e9a48c
|
|||
2ab5fcffc7
|
|||
c1acddcc6e
|
|||
a9b021cebe
|
|||
fd7e35cf34
|
|||
f929aaac63
|
|||
c1affb8781
|
|||
dfeddf9688
|
|||
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 | |||
e1245da9de | |||
8d86fd2f5d | |||
f5a6331fd3 | |||
8676e1bcb3 | |||
52d6bc12f4 | |||
fdcea0d423 | |||
1a8869bb11 | |||
53afd74739 | |||
00defc98eb | |||
127a78f58d | |||
d5e345fb48 | |||
e0bb4bfa2f | |||
c90139bbcc | |||
3dc1c03a0f | |||
f7c889e3c9 | |||
115d25613c | |||
eaa8cc886d | |||
ff85878b7e | |||
c189c21474 | |||
49ffeccf7e | |||
72cc00272c | |||
1e044e4959 | |||
4bcf68cd67 | |||
711b77fa2c | |||
9c4f9247f8 | |||
071d112af7 |
54
Dockerfile
Normal file
54
Dockerfile
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
# Update the package list, install sudo, create a non-root user, and grant password-less sudo permissions
|
||||||
|
RUN apt update
|
||||||
|
RUN apt install -y sudo
|
||||||
|
|
||||||
|
RUN sudo apt-get update
|
||||||
|
#Instalando Curl
|
||||||
|
RUN sudo apt-get install -y curl
|
||||||
|
#Instalando wget
|
||||||
|
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
|
||||||
|
#devtunnel token TUNNELID --scope connect
|
||||||
|
RUN curl -sL https://aka.ms/DevTunnelCliInstall | bash
|
||||||
|
|
||||||
|
#Instalando VSCode
|
||||||
|
RUN sudo apt-get update && sudo apt-get install -y gnupg2
|
||||||
|
RUN sudo apt-get install -y software-properties-common
|
||||||
|
RUN sudo wget -q https://packages.microsoft.com/keys/microsoft.asc -O- | sudo apt-key add -
|
||||||
|
RUN sudo add-apt-repository "deb [arch=amd64] https://packages.microsoft.com/repos/vscode stable main"
|
||||||
|
RUN sudo apt update
|
||||||
|
RUN sudo apt install code -y
|
||||||
|
|
||||||
|
#Making home writteable
|
||||||
|
RUN sudo chmod -R a+rwX /home
|
||||||
|
|
||||||
|
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"]
|
107
entrypoint.sh
Executable file
107
entrypoint.sh
Executable file
@ -0,0 +1,107 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
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.
|
||||||
|
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 cp -R /home/vscode/. /home/${HOME_USER}/
|
||||||
|
|
||||||
|
# Check if .bashrc file exists
|
||||||
|
if [ ! -f "/home/${HOME_USER}/.bashrc" ]; then
|
||||||
|
# If not, create it
|
||||||
|
sudo touch /home/${HOME_USER}/.bashrc
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Change the owner of the .bashrc file to HOME_USER
|
||||||
|
sudo chown ${HOME_USER} /home/${HOME_USER}/.bashrc
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# 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"
|
||||||
|
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
|
||||||
|
sudo mkdir -p /home/${HOME_USER}/.config/Code
|
||||||
|
fi
|
||||||
|
sudo chmod -R a+rwX /home/${HOME_USER}/.config/Code
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
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
|
||||||
|
if [ -f "/home/extensions.json" ]; then
|
||||||
|
# Read the JSON file into a variable
|
||||||
|
jsonExtensions=$(cat /home/extensions.json)
|
||||||
|
|
||||||
|
# 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
|
||||||
|
echo "Installing extension: $extension"
|
||||||
|
sudo su - ${HOME_USER} -c "code --install-extension $extension"
|
||||||
|
done
|
||||||
|
sudo cp -R /home/${HOME_USER}/.vscode/* /home/${HOME_USER}/.vscode-server
|
||||||
|
sudo cp -R /home/${HOME_USER}/.vscode/* /home/${HOME_USER}/.vscode-server-insiders
|
||||||
|
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode
|
||||||
|
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode-server
|
||||||
|
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode-server-insiders
|
||||||
|
else
|
||||||
|
echo "File extensions.json not found"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||||
|
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}"
|
||||||
|
fi
|
110
readme.md
Normal file
110
readme.md
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
# Aleleba VSCode Dockerfile Configuration
|
||||||
|
|
||||||
|
This repository contains a Dockerfile configuration for use with Visual Studio Code with dev tunnel.
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
To run the Docker container, follow these steps:
|
||||||
|
|
||||||
|
1. Clone this repository to your local machine.
|
||||||
|
2. Open the integrated terminal in Visual Studio Code.
|
||||||
|
3. Run the Docker container by running the following command: `docker run -it -e HOME_USER=custom-home-user -e VSCODE_TUNNEL_NAME=vscode-ssh-remote-server -v /path/to/extensions.json:/home/extensions.json aleleba/vscode`
|
||||||
|
|
||||||
|
### Environment Variables
|
||||||
|
|
||||||
|
The following environment variables can be set when running the Docker container:
|
||||||
|
|
||||||
|
- `HOME_USER`: The username of the user running the container. This is used to set the correct permissions on files created in the container.
|
||||||
|
- `VSCODE_TUNNEL_NAME`: The name of the SSH tunnel used by Visual Studio Code to connect to the container.
|
||||||
|
|
||||||
|
### Adding VSCode Extensions
|
||||||
|
|
||||||
|
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:
|
||||||
|
```
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"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"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
Save this file as `extensions.json` and add it as a volume when running the Docker container on /home/extensions.json. For example:
|
||||||
|
`docker run -it -e HOME_USER=custom-home-user -e VSCODE_TUNNEL_NAME=vscode-ssh-remote-server -v /path/to/extensions.json:/home/extensions.json aleleba/vscode`
|
||||||
|
|
||||||
|
|
||||||
|
The extensions will be installed automatically after the container is created.
|
||||||
|
|
||||||
|
### Using Docker Compose
|
||||||
|
|
||||||
|
Alternatively, you can use Docker Compose to run the container with the `aleleba/vscode` image and the `HOME_USER` and `VSCODE_TUNNEL_NAME` environment variables set. Here's an example `docker-compose.yml` file:
|
||||||
|
|
||||||
|
```
|
||||||
|
version: '3'
|
||||||
|
|
||||||
|
services:
|
||||||
|
vscode:
|
||||||
|
image: aleleba/vscode
|
||||||
|
environment:
|
||||||
|
HOME_USER: custom-home-user
|
||||||
|
VSCODE_TUNNEL_NAME: vscode-ssh-remote-server
|
||||||
|
volumes:
|
||||||
|
- /path/to/extensions.json:/home/extensions.json
|
||||||
|
```
|
||||||
|
|
||||||
|
You can run this `docker-compose.yml` file by navigating to the directory where it is saved and running the following command: `docker-compose up -d`
|
||||||
|
|
||||||
|
This will start the container in the background and output the container ID. You can then use the `docker ps` command to view the running container.
|
||||||
|
|
||||||
|
## Using this image as a base image in a Dockerfile
|
||||||
|
|
||||||
|
To use this image as a base image in a Dockerfile, you can add the following line to the top of your Dockerfile and you can install any additional packages you need, here an example installing nvm and nodejs in a `Dockerfile`:
|
||||||
|
|
||||||
|
```
|
||||||
|
FROM aleleba/vscode:latest
|
||||||
|
|
||||||
|
# Installing node.js and NVM
|
||||||
|
SHELL ["/bin/bash", "--login", "-i", "-c"]
|
||||||
|
RUN curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash
|
||||||
|
RUN nvm install --lts
|
||||||
|
RUN nvm alias default lts/*
|
||||||
|
SHELL ["/bin/sh", "-c"]
|
||||||
|
RUN echo 'source ~/.nvm/nvm.sh' >> ~/.bashrc
|
||||||
|
# Finishing installing node.js and NVM
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
If you'd like to contribute to this project, please fork the repository and create a pull request.
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
|
||||||
|
|
||||||
|
I hope this helps! Let me know if you have any further questions.
|
1
version.txt
Executable file
1
version.txt
Executable file
@ -0,0 +1 @@
|
|||||||
|
2.0.47
|
Reference in New Issue
Block a user