Compare commits

..

16 Commits

Author SHA1 Message Date
3da90aa1a4 Fixing typo. 2025-04-14 00:06:02 +00:00
aa9afba282 Trying to fix existing tunnel. 2025-04-13 23:44:58 +00:00
0fe46e635d Trying to fix issue if data authentication already exist.
Some checks failed
Build and Push Docker Image ARM64 / docker (push) Failing after 1m52s
2025-04-13 04:27:21 +00:00
d84caeb8cf Trying to fix issue when restart. 2025-04-13 03:57:47 +00:00
68e7aa99d8 Trying to fix issue when restart. 2025-04-13 03:30:11 +00:00
8d5deeeef0 Updating version of vscode and adding feature to restart.
Some checks failed
Build and Push Docker Image ARM64 / docker (push) Failing after 1m27s
2025-04-13 00:51:32 +00:00
0c8c0d1068 Updating vscode version.
Some checks failed
Build and Push Docker Image ARM64 / docker (push) Failing after 14m39s
2025-03-07 00:02:34 +00:00
fc0c473ce4 Updating vscode version
Some checks failed
Build and Push Docker Image ARM64 / docker (push) Failing after 2m53s
2025-02-19 20:04:53 +00:00
521c51314a Updating version of vscode. Updating to version 3.1.17 2024-12-17 15:47:33 +00:00
23b4140fc5 Updating version of vscode. 2024-11-19 15:08:35 +00:00
a4e9a02d87 Updating version of vscode. 2024-11-01 10:47:10 -06:00
6fb7085164 Updating version to version 3.1.14 2024-10-03 20:08:51 +00:00
5754ef90a2 Merge branch 'master' of github.com:aleleba/aleleba-vscode-dockerfile-configuration 2024-10-03 20:06:17 +00:00
3b99e2546f Fixing github actions workflow. Updating to version 3.1.13 2024-09-10 14:59:04 -06:00
8ee5f0376f Trying to fix issue, updating to version 3.1.12 2024-09-10 14:46:28 -06:00
819e72324c Updating to new version of vscode. Updating to version 3.1.3. 2024-06-11 16:21:24 +00:00
5 changed files with 66 additions and 21 deletions

View File

@ -1,4 +1,4 @@
name: Build and Push Docker Images
name: Build and Push Docker Image ARM64
on:
push:
@ -7,26 +7,24 @@ on:
jobs:
docker:
runs-on: ubuntu-latest
strategy:
matrix:
platform: [amd64, arm64]
steps:
- name: Checkout
-
name: Checkout
uses: actions/checkout@v2
- name: Set up Docker Buildx
-
name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
- name: Login to DockerHub
-
name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
-
name: Build and push
uses: docker/build-push-action@v2
with:
context: .
push: true
tags: aleleba/vscode:latest
platforms: linux/${{ matrix.platform }}
platforms: linux/amd64,linux/arm64

View File

@ -1,9 +1,5 @@
FROM ubuntu:22.04
# Configurar debconf para que use una interfaz no interactiva
ENV DEBIAN_FRONTEND=noninteractive
ENV DEBCONF_NONINTERACTIVE_SEEN=true
# Update the package list, install sudo, create a non-root user, and grant password-less sudo permissions
RUN apt update && apt install -y sudo
@ -39,7 +35,7 @@ RUN ARCH="$(dpkg --print-architecture)" \
&& sudo wget -q https://packages.microsoft.com/keys/microsoft.asc -O- | sudo apt-key add - \
&& sudo add-apt-repository "deb [arch=${ARCH}] https://packages.microsoft.com/repos/vscode stable main" \
&& sudo apt-get update \
&& sudo apt-get install -y code
&& sudo DEBIAN_FRONTEND=noninteractive apt-get install -y code
#Making home writable
RUN sudo chmod -R a+rwX /home

View File

@ -157,8 +157,47 @@ else
echo "File extensions.json not found"
fi
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}"
# 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, extract token and tunnel information
# Extract token from token.json if it exists
TOKEN_FILE="/home/${HOME_USER}/.vscode/cli/token.json"
if [ -f "$TOKEN_FILE" ]; then
TOKEN=$(cat "$TOKEN_FILE" | tr -d '\n')
else
TOKEN=""
fi
# Extract id and cluster from code_tunnel.json if it exists
TUNNEL_FILE="/home/${HOME_USER}/.vscode/cli/code_tunnel.json"
if [ -f "$TUNNEL_FILE" ]; then
if command -v jq &> /dev/null; then
# Use jq if available
ID=$(jq -r '.id' "$TUNNEL_FILE")
CLUSTER=$(jq -r '.cluster' "$TUNNEL_FILE")
else
# Fallback to grep and cut if jq is not available
ID=$(grep -o '"id"[^,}]*' "$TUNNEL_FILE" | cut -d'"' -f4)
CLUSTER=$(grep -o '"cluster"[^,}]*' "$TUNNEL_FILE" | cut -d'"' -f4)
fi
TUNNEL_ID="${ID}.${CLUSTER}"
else
TUNNEL_ID=""
fi
# Create tunnel with extracted values if available
if [ -n "$TOKEN" ] && [ -n "$TUNNEL_ID" ]; then
sudo su ${HOME_USER} -c "code tunnel --name ${VSCODE_TUNNEL_NAME} --tunnel-id ${TUNNEL_ID} --host-token ${TOKEN}"
else
# Fallback to simpler command if values couldn't be extracted
sudo su ${HOME_USER} -c "code tunnel --name ${VSCODE_TUNNEL_NAME}"
fi
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
fi

View File

@ -39,6 +39,15 @@ 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:
@ -170,6 +179,9 @@ RUN echo 'source ~/.nvm/nvm.sh' >> ~/.bashrc
# Finishing installing node.js and NVM
```
> **Note:** If you are using this image as a base image in a Dockerfile, ensure that the value of `HOME_USER` is the same as the one you will use when creating the container. This is necessary to ensure that all configurations and packages are installed in the correct user directory.
> **Note:** To grant access to the server, please log into https://github.com/login/device and use the code XXXX-XXXX. You can view the container logs to get the code.

View File

@ -1 +1 @@
3.1.11
3.2.5