mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-06-18 20:08:13 -06:00
Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
fba2d768e9
|
|||
40c5f1c963
|
|||
e34b39c827
|
|||
f3797b5660
|
|||
a1e53a6624
|
|||
3da90aa1a4
|
|||
aa9afba282
|
|||
0fe46e635d
|
|||
d84caeb8cf
|
|||
68e7aa99d8
|
@ -111,7 +111,12 @@ fi
|
||||
|
||||
# Find .sh files in /usr/bin/custom-scripts and execute them in order
|
||||
for script in $(find /usr/bin/custom-scripts -name "*.sh" | sort); do
|
||||
chmod +x $script
|
||||
# Ensure the script is executable
|
||||
if [ ! -x $script ]; then
|
||||
sudo chmod +x $script
|
||||
fi
|
||||
|
||||
# Execute the script as the configured user
|
||||
if [[ $script == *"sudo"* ]]; then
|
||||
sudo -u $HOME_USER bash -c "source /etc/environment; sudo $script"
|
||||
else
|
||||
@ -119,6 +124,7 @@ for script in $(find /usr/bin/custom-scripts -name "*.sh" | sort); do
|
||||
fi
|
||||
done
|
||||
|
||||
|
||||
#Creating extensions folder
|
||||
if [ ! -d "/home/${HOME_USER}/.config/Code" ]; then
|
||||
sudo mkdir -p /home/${HOME_USER}/.config/Code
|
||||
@ -157,15 +163,8 @@ else
|
||||
echo "File extensions.json not found"
|
||||
fi
|
||||
|
||||
# Check if CLI directory exists and has content
|
||||
if [ -d "/home/${HOME_USER}/.vscode/cli" ] && [ "$(ls -A /home/${HOME_USER}/.vscode/cli 2>/dev/null)" ]; then
|
||||
# CLI directory exists and has content, use restart
|
||||
sudo su ${HOME_USER} -c "code tunnel restart"
|
||||
if [[ -v VSCODE_TUNNEL_NAME && -n "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
||||
else
|
||||
# No CLI directory or empty, use normal startup
|
||||
if [[ -v VSCODE_TUNNEL_NAME && -n "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
||||
else
|
||||
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
||||
fi
|
||||
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
||||
fi
|
||||
|
@ -39,15 +39,6 @@ docker run -it -e HOME_USER=custom-home-user -e GLOBAL_ENV_MY_GLOBAL_VARIABLE=my
|
||||
```
|
||||
In this example, MY_GLOBAL_VARIABLE will be set to my_global_value in the /etc/environment file.
|
||||
|
||||
### Persistent VS Code Tunnel
|
||||
|
||||
You can maintain the VS Code tunnel configuration between container restarts by adding a volume mount to `/home/${HOME_USER}/.vscode/cli`. When this volume is mounted and the container restarts, it will use `code tunnel restart` to reconnect using the existing tunnel configuration instead of creating a new one.
|
||||
|
||||
Example:
|
||||
```bash
|
||||
docker run -it -e HOME_USER=custom-home-user -e VSCODE_TUNNEL_NAME=vscode-ssh-remote-server -v /path/to/vscode-cli:/home/custom-home-user/.vscode/cli -v /path/to/extensions.json:/home/extensions.json aleleba/vscode
|
||||
```
|
||||
|
||||
### 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:
|
||||
|
@ -1 +1 @@
|
||||
3.2.0
|
||||
3.2.10
|
||||
|
Reference in New Issue
Block a user