mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-06-18 11:58:12 -06:00
Compare commits
37 Commits
Author | SHA1 | Date | |
---|---|---|---|
fba2d768e9
|
|||
40c5f1c963
|
|||
e34b39c827
|
|||
f3797b5660
|
|||
a1e53a6624
|
|||
3da90aa1a4
|
|||
aa9afba282
|
|||
0fe46e635d
|
|||
d84caeb8cf
|
|||
68e7aa99d8
|
|||
8d5deeeef0
|
|||
0c8c0d1068
|
|||
fc0c473ce4
|
|||
521c51314a
|
|||
23b4140fc5
|
|||
a4e9a02d87 | |||
6fb7085164
|
|||
5754ef90a2
|
|||
3b99e2546f | |||
8ee5f0376f | |||
b676e5245c | |||
aa71cb3be5 | |||
40a58d6a85 | |||
54c7bd3365 | |||
862baf44b7 | |||
1b4baca42c | |||
3e130f4bf0 | |||
4c16938db3 | |||
cd7181d6ec | |||
819e72324c
|
|||
183e04cde2
|
|||
b33c4cbbe6 | |||
974914126f | |||
ae16a7be7f | |||
998701be6c | |||
b30b350fe4 | |||
1b278e0eea |
30
.github/workflows/main-workflow.yml
vendored
Normal file
30
.github/workflows/main-workflow.yml
vendored
Normal file
@ -0,0 +1,30 @@
|
||||
name: Build and Push Docker Image ARM64
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: [ master ]
|
||||
|
||||
jobs:
|
||||
docker:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
-
|
||||
name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
-
|
||||
name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v1
|
||||
-
|
||||
name: Login to DockerHub
|
||||
uses: docker/login-action@v1
|
||||
with:
|
||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||
-
|
||||
name: Build and push
|
||||
uses: docker/build-push-action@v2
|
||||
with:
|
||||
context: .
|
||||
push: true
|
||||
tags: aleleba/vscode:latest
|
||||
platforms: linux/amd64,linux/arm64
|
23
Dockerfile
23
Dockerfile
@ -1,8 +1,7 @@
|
||||
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 apt update && apt install -y sudo
|
||||
|
||||
RUN sudo apt-get update
|
||||
#Instalando Curl
|
||||
@ -13,10 +12,10 @@ RUN sudo apt-get install -y wget
|
||||
RUN sudo apt-get install -y jq
|
||||
|
||||
RUN sudo apt-get update
|
||||
RUN sudo apt-get install dumb-init
|
||||
RUN sudo apt-get install -y dumb-init
|
||||
|
||||
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 - \
|
||||
&& 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 \
|
||||
@ -29,14 +28,16 @@ RUN ARCH="$(dpkg --print-architecture)" \
|
||||
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
|
||||
RUN ARCH="$(dpkg --print-architecture)" \
|
||||
&& sudo apt-get update \
|
||||
&& sudo apt-get install -y gnupg2 \
|
||||
&& sudo apt-get install -y software-properties-common \
|
||||
&& 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 DEBIAN_FRONTEND=noninteractive apt-get install -y code
|
||||
|
||||
#Making home writteable
|
||||
#Making home writable
|
||||
RUN sudo chmod -R a+rwX /home
|
||||
|
||||
RUN sudo sysctl -w fs.inotify.max_user_watches=524288
|
||||
|
@ -77,7 +77,20 @@ if [ "$HOME_USER" != "$(whoami)" ]; then
|
||||
exec sudo -u $HOME_USER bash -c "source /etc/environment; /usr/bin/entrypoint.sh"
|
||||
else
|
||||
sudo chown -R ${HOME_USER} /home/${HOME_USER}
|
||||
sudo chmod -R 600 /home/${HOME_USER}/.ssh
|
||||
if [ -d "/home/${HOME_USER}/.ssh" ]; then
|
||||
sudo chmod 755 /home/${HOME_USER}/.ssh
|
||||
sudo chmod -R 600 /home/${HOME_USER}/.ssh/*
|
||||
# Check if any .pub files exist in the .ssh directory
|
||||
for file in /home/${HOME_USER}/.ssh/*.pub; do
|
||||
if [ -f "$file" ]; then
|
||||
sudo chmod 644 "$file"
|
||||
fi
|
||||
done
|
||||
# Check if the known_hosts file exists in the .ssh directory
|
||||
if [ -f "/home/${HOME_USER}/.ssh/known_hosts" ]; then
|
||||
sudo chmod 644 /home/${HOME_USER}/.ssh/known_hosts
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# Move the .bashrc file to the user's home directory if it doesn't exist
|
||||
@ -98,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
|
||||
@ -106,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
|
||||
|
@ -170,8 +170,13 @@ 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.
|
||||
|
||||
## Contributing
|
||||
|
||||
If you'd like to contribute to this project, please fork the repository and create a pull request.
|
||||
|
@ -1 +1 @@
|
||||
3.0.36
|
||||
3.2.10
|
||||
|
Reference in New Issue
Block a user