mirror of
https://github.com/aleleba/aleleba-vscode-dockerfile-configuration.git
synced 2025-04-20 14:47:48 -06:00
Compare commits
101 Commits
Author | SHA1 | Date | |
---|---|---|---|
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 | |||
e88ab12701 | |||
694039fb29 | |||
8ffbd5d818 | |||
c2f5311948 | |||
f91d1c56a1 | |||
42b7bd30e7 | |||
0f51996adc | |||
8dea73ec95 | |||
8b71265807 | |||
d9df63f836 | |||
c9799b9a77 | |||
de3fda3c09 | |||
559cd39a66 | |||
4bbe7f51cb | |||
b0b9497107 | |||
1631237881 | |||
6a6947d855 | |||
65644a8b14 | |||
03b01cbae3 | |||
b5c8652d94 | |||
9f101b45cc | |||
89fd905384 | |||
ac320909ab | |||
ab2bdc80a6 | |||
6f1beacbd0 | |||
b7d52df70b | |||
5dbb07fd80 | |||
3f6a9f6626 | |||
13e642be86 | |||
ba267c2494 | |||
67cc921484 | |||
15de59c6e7 | |||
7bf78c1935 | |||
e2ba0edd34 | |||
e74fb7d054 | |||
b027cd07a0 | |||
66ed2b4950 | |||
d596af8a2f | |||
680e3810b6 | |||
6519cc3ef9 | |||
c27e148488 | |||
cd8b5c19e1 | |||
a6e4296f25 | |||
08cf40624d | |||
a3b5fe1d6d | |||
99812ff71c | |||
d8a8162ffd | |||
32d405aa80 | |||
2a98fcce78 | |||
3ab91f9f5f | |||
840fdfaf1e | |||
f7a5094cc3 | |||
22f0003c53 | |||
b08429c9ae | |||
7f81f891ab | |||
66c96f1fe7 | |||
1e5523c1f7 | |||
390f9cdc15 | |||
f9503fe827 | |||
c50b9e969f | |||
f9b4e4644a | |||
01410a3ccd | |||
cb4bf58db9 | |||
ed98e9a48c | |||
2ab5fcffc7 | |||
c1acddcc6e | |||
a9b021cebe |
118
.bashrc
Normal file
118
.bashrc
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
# ~/.bashrc: executed by bash(1) for non-login shells.
|
||||||
|
# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
|
||||||
|
# for examples
|
||||||
|
|
||||||
|
# If not running interactively, don't do anything
|
||||||
|
case $- in
|
||||||
|
*i*) ;;
|
||||||
|
*) return;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# don't put duplicate lines or lines starting with space in the history.
|
||||||
|
# See bash(1) for more options
|
||||||
|
HISTCONTROL=ignoreboth
|
||||||
|
|
||||||
|
# append to the history file, don't overwrite it
|
||||||
|
shopt -s histappend
|
||||||
|
|
||||||
|
# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
|
||||||
|
HISTSIZE=1000
|
||||||
|
HISTFILESIZE=2000
|
||||||
|
|
||||||
|
# check the window size after each command and, if necessary,
|
||||||
|
# update the values of LINES and COLUMNS.
|
||||||
|
shopt -s checkwinsize
|
||||||
|
|
||||||
|
# If set, the pattern "**" used in a pathname expansion context will
|
||||||
|
# match all files and zero or more directories and subdirectories.
|
||||||
|
#shopt -s globstar
|
||||||
|
|
||||||
|
# make less more friendly for non-text input files, see lesspipe(1)
|
||||||
|
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
|
||||||
|
|
||||||
|
# set variable identifying the chroot you work in (used in the prompt below)
|
||||||
|
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
|
||||||
|
debian_chroot=$(cat /etc/debian_chroot)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set a fancy prompt (non-color, unless we know we "want" color)
|
||||||
|
case "$TERM" in
|
||||||
|
xterm-color|*-256color) color_prompt=yes;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# uncomment for a colored prompt, if the terminal has the capability; turned
|
||||||
|
# off by default to not distract the user: the focus in a terminal window
|
||||||
|
# should be on the output of commands, not on the prompt
|
||||||
|
#force_color_prompt=yes
|
||||||
|
|
||||||
|
if [ -n "$force_color_prompt" ]; then
|
||||||
|
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
|
||||||
|
# We have color support; assume it's compliant with Ecma-48
|
||||||
|
# (ISO/IEC-6429). (Lack of such support is extremely rare, and such
|
||||||
|
# a case would tend to support setf rather than setaf.)
|
||||||
|
color_prompt=yes
|
||||||
|
else
|
||||||
|
color_prompt=
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$color_prompt" = yes ]; then
|
||||||
|
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
|
||||||
|
else
|
||||||
|
PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
|
||||||
|
fi
|
||||||
|
unset color_prompt force_color_prompt
|
||||||
|
|
||||||
|
# If this is an xterm set the title to user@host:dir
|
||||||
|
case "$TERM" in
|
||||||
|
xterm*|rxvt*)
|
||||||
|
PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# enable color support of ls and also add handy aliases
|
||||||
|
if [ -x /usr/bin/dircolors ]; then
|
||||||
|
test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
|
||||||
|
alias ls='ls --color=auto'
|
||||||
|
#alias dir='dir --color=auto'
|
||||||
|
#alias vdir='vdir --color=auto'
|
||||||
|
|
||||||
|
alias grep='grep --color=auto'
|
||||||
|
alias fgrep='fgrep --color=auto'
|
||||||
|
alias egrep='egrep --color=auto'
|
||||||
|
fi
|
||||||
|
|
||||||
|
# colored GCC warnings and errors
|
||||||
|
#export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'
|
||||||
|
|
||||||
|
# some more ls aliases
|
||||||
|
alias ll='ls -alF'
|
||||||
|
alias la='ls -A'
|
||||||
|
alias l='ls -CF'
|
||||||
|
|
||||||
|
# Add an "alert" alias for long running commands. Use like so:
|
||||||
|
# sleep 10; alert
|
||||||
|
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'
|
||||||
|
|
||||||
|
# Alias definitions.
|
||||||
|
# You may want to put all your additions into a separate file like
|
||||||
|
# ~/.bash_aliases, instead of adding them here directly.
|
||||||
|
# See /usr/share/doc/bash-doc/examples in the bash-doc package.
|
||||||
|
|
||||||
|
if [ -f ~/.bash_aliases ]; then
|
||||||
|
. ~/.bash_aliases
|
||||||
|
fi
|
||||||
|
|
||||||
|
# enable programmable completion features (you don't need to enable
|
||||||
|
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
|
||||||
|
# sources /etc/bash.bashrc).
|
||||||
|
if ! shopt -oq posix; then
|
||||||
|
if [ -f /usr/share/bash-completion/bash_completion ]; then
|
||||||
|
. /usr/share/bash-completion/bash_completion
|
||||||
|
elif [ -f /etc/bash_completion ]; then
|
||||||
|
. /etc/bash_completion
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
export LS_COLORS="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:"
|
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
|
27
.profile
Normal file
27
.profile
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# ~/.profile: executed by the command interpreter for login shells.
|
||||||
|
# This file is not read by bash(1), if ~/.bash_profile or ~/.bash_login
|
||||||
|
# exists.
|
||||||
|
# see /usr/share/doc/bash/examples/startup-files for examples.
|
||||||
|
# the files are located in the bash-doc package.
|
||||||
|
|
||||||
|
# the default umask is set in /etc/profile; for setting the umask
|
||||||
|
# for ssh logins, install and configure the libpam-umask package.
|
||||||
|
#umask 022
|
||||||
|
|
||||||
|
# if running bash
|
||||||
|
if [ -n "$BASH_VERSION" ]; then
|
||||||
|
# include .bashrc if it exists
|
||||||
|
if [ -f "$HOME/.bashrc" ]; then
|
||||||
|
. "$HOME/.bashrc"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set PATH so it includes user's private bin if it exists
|
||||||
|
if [ -d "$HOME/bin" ] ; then
|
||||||
|
PATH="$HOME/bin:$PATH"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set PATH so it includes user's private bin if it exists
|
||||||
|
if [ -d "$HOME/.local/bin" ] ; then
|
||||||
|
PATH="$HOME/.local/bin:$PATH"
|
||||||
|
fi
|
34
Dockerfile
34
Dockerfile
@ -1,8 +1,7 @@
|
|||||||
FROM ubuntu:22.04
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
# Update the package list, install sudo, create a non-root user, and grant password-less sudo permissions
|
# Update the package list, install sudo, create a non-root user, and grant password-less sudo permissions
|
||||||
RUN apt update
|
RUN apt update && apt install -y sudo
|
||||||
RUN apt install -y sudo
|
|
||||||
|
|
||||||
RUN sudo apt-get update
|
RUN sudo apt-get update
|
||||||
#Instalando Curl
|
#Instalando Curl
|
||||||
@ -13,13 +12,10 @@ RUN sudo apt-get install -y wget
|
|||||||
RUN sudo apt-get install -y jq
|
RUN sudo apt-get install -y jq
|
||||||
|
|
||||||
RUN sudo apt-get update
|
RUN sudo apt-get update
|
||||||
RUN sudo apt-get install dumb-init
|
RUN sudo apt-get install -y dumb-init
|
||||||
|
|
||||||
RUN adduser --gecos '' --disabled-password vscode \
|
|
||||||
&& echo "vscode ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers.d/nopasswd
|
|
||||||
|
|
||||||
RUN ARCH="$(dpkg --print-architecture)" \
|
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 \
|
&& chown root:root /usr/local/bin/fixuid \
|
||||||
&& chmod 4755 /usr/local/bin/fixuid \
|
&& chmod 4755 /usr/local/bin/fixuid \
|
||||||
&& mkdir -p /etc/fixuid \
|
&& mkdir -p /etc/fixuid \
|
||||||
@ -32,23 +28,25 @@ RUN ARCH="$(dpkg --print-architecture)" \
|
|||||||
RUN curl -sL https://aka.ms/DevTunnelCliInstall | bash
|
RUN curl -sL https://aka.ms/DevTunnelCliInstall | bash
|
||||||
|
|
||||||
#Instalando VSCode
|
#Instalando VSCode
|
||||||
RUN sudo apt-get update && sudo apt-get install -y gnupg2
|
RUN ARCH="$(dpkg --print-architecture)" \
|
||||||
RUN sudo apt-get install -y software-properties-common
|
&& sudo apt-get update \
|
||||||
RUN sudo wget -q https://packages.microsoft.com/keys/microsoft.asc -O- | sudo apt-key add -
|
&& sudo apt-get install -y gnupg2 \
|
||||||
RUN sudo add-apt-repository "deb [arch=amd64] https://packages.microsoft.com/repos/vscode stable main"
|
&& sudo apt-get install -y software-properties-common \
|
||||||
RUN sudo apt update
|
&& sudo wget -q https://packages.microsoft.com/keys/microsoft.asc -O- | sudo apt-key add - \
|
||||||
RUN sudo apt install code -y
|
&& 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 chmod -R a+rwX /home
|
||||||
|
|
||||||
RUN sudo sysctl -w fs.inotify.max_user_watches=524288
|
RUN sudo sysctl -w fs.inotify.max_user_watches=524288
|
||||||
|
|
||||||
|
ADD ./.bashrc /usr/bin/.bashrc
|
||||||
|
RUN sudo chmod +x /usr/bin/.bashrc
|
||||||
|
ADD ./.profile /usr/bin/.profile
|
||||||
|
RUN sudo chmod +x /usr/bin/.profile
|
||||||
ADD ./entrypoint.sh /usr/bin/entrypoint.sh
|
ADD ./entrypoint.sh /usr/bin/entrypoint.sh
|
||||||
RUN sudo chmod +x /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"]
|
ENTRYPOINT ["/usr/bin/entrypoint.sh"]
|
160
entrypoint.sh
160
entrypoint.sh
@ -1,48 +1,138 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
if [[ -z "${HOME_USER}" ]]; then
|
if [[ -z "${HOME_USER-}" ]]; then
|
||||||
HOME_USER="vscode"
|
HOME_USER="vscode"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#addgroup nonroot
|
if ! grep -q "HOME_USER=" /etc/environment; then
|
||||||
#adduser --disabled-password --gecos "" ${HOME_USER}
|
sudo bash -c "echo HOME_USER=$HOME_USER >> /etc/environment"
|
||||||
#echo "${HOME_USER} ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
|
fi
|
||||||
|
|
||||||
# We do this first to ensure sudo works below when renaming the user.
|
if [[ -v VSCODE_TUNNEL_NAME && -n "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||||
# Otherwise the current container UID may not exist in the passwd database.
|
if ! grep -q "VSCODE_TUNNEL_NAME=" /etc/environment; then
|
||||||
eval "$(fixuid -q)"
|
sudo bash -c "echo VSCODE_TUNNEL_NAME=$VSCODE_TUNNEL_NAME >> /etc/environment"
|
||||||
|
|
||||||
if [ "${HOME_USER-}" ]; then
|
|
||||||
USER="$HOME_USER"
|
|
||||||
if [ "$HOME_USER" != "$(whoami)" ]; 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
|
|
||||||
|
|
||||||
# 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
|
|
||||||
# Unfortunately we cannot change $HOME as we cannot move any bind mounts
|
|
||||||
# nor can we bind mount $HOME into a new home as that requires a privileged container.
|
|
||||||
# sudo usermod --login "$HOME_USER" vscode
|
|
||||||
# sudo groupmod -n "$HOME_USER" vscode
|
|
||||||
|
|
||||||
## Agregar binarios
|
|
||||||
sudo sed -i "/vscode/d" /etc/sudoers.d/nopasswd
|
|
||||||
sudo cd /home/${HOME_USER}
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# List all environment variables
|
||||||
|
printenv |
|
||||||
|
|
||||||
|
# Filter variables that start with GLOBAL_ENV_
|
||||||
|
grep -E '^GLOBAL_ENV_' |
|
||||||
|
|
||||||
|
# Exclude GLOBAL_ENV_HOME_USER and GLOBAL_ENV_VSCODE_TUNNEL_NAME
|
||||||
|
grep -vE '^(GLOBAL_ENV_HOME_USER|GLOBAL_ENV_VSCODE_TUNNEL_NAME)=' |
|
||||||
|
|
||||||
|
# Remove the GLOBAL_ENV_ prefix
|
||||||
|
sed 's/^GLOBAL_ENV_//' |
|
||||||
|
|
||||||
|
# Append the result to /etc/environment if not already present
|
||||||
|
while IFS= read -r line
|
||||||
|
do
|
||||||
|
if ! grep -q "^${line%=*}=" /etc/environment; then
|
||||||
|
echo "" >> /etc/environment
|
||||||
|
echo "export $line" >> /etc/environment
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# List all environment variables
|
||||||
|
printenv |
|
||||||
|
|
||||||
|
# Filter variables that start with USER_ENV_
|
||||||
|
grep -E '^USER_ENV_' |
|
||||||
|
|
||||||
|
# Remove the USER_ENV_ prefix
|
||||||
|
sed 's/^USER_ENV_//' |
|
||||||
|
|
||||||
|
# Append the result to /usr/bin/.bashrc
|
||||||
|
while IFS= read -r line
|
||||||
|
do
|
||||||
|
# Check if the current user is root
|
||||||
|
if [ "$(id -u)" = "0" ]; then
|
||||||
|
echo "" >> /usr/bin/.bashrc
|
||||||
|
echo "export $line" >> /usr/bin/.bashrc
|
||||||
|
else
|
||||||
|
echo "" >> /home/${HOME_USER}/.bashrc
|
||||||
|
echo "export $line" >> /home/${HOME_USER}/.bashrc
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
USER="$HOME_USER"
|
||||||
|
if ! id -u $HOME_USER > /dev/null 2>&1; then
|
||||||
|
sudo adduser --disabled-password --gecos "" --uid 1000 ${HOME_USER}
|
||||||
|
sudo echo "$HOME_USER ALL=(ALL) NOPASSWD:ALL" | sudo tee -a /etc/sudoers.d/nopasswd > /dev/null
|
||||||
|
|
||||||
|
# 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
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Then execute entrypoint.sh
|
||||||
|
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}
|
||||||
|
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
|
||||||
|
if [ ! -f "/home/${HOME_USER}/.bashrc" ]; then
|
||||||
|
sudo mv /usr/bin/.bashrc /home/${HOME_USER}/.bashrc
|
||||||
|
sudo chown ${HOME_USER} /home/${HOME_USER}/.bashrc
|
||||||
|
else
|
||||||
|
sudo rm -f /usr/bin/.bashrc
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Move the .profile file to the user's home directory if it doesn't exist
|
||||||
|
if [ ! -f "/home/${HOME_USER}/.profile" ]; then
|
||||||
|
sudo mv /usr/bin/.profile /home/${HOME_USER}/.profile
|
||||||
|
sudo chown ${HOME_USER} /home/${HOME_USER}/.profile
|
||||||
|
else
|
||||||
|
sudo rm -f /usr/bin/.profile
|
||||||
|
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
|
||||||
|
if [[ $script == *"sudo"* ]]; then
|
||||||
|
sudo -u $HOME_USER bash -c "source /etc/environment; sudo $script"
|
||||||
|
else
|
||||||
|
sudo -u $HOME_USER bash -c "source /etc/environment; $script"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
#Creating extensions folder
|
#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 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 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
|
sudo chmod -R a+rwX /home/${HOME_USER}/.vscode-server-insiders
|
||||||
|
|
||||||
# Check if the data.json file exists
|
# Check if the data.json file exists
|
||||||
@ -56,7 +146,7 @@ if [ -f "/home/extensions.json" ]; then
|
|||||||
# Loop through the extensions and process each element
|
# Loop through the extensions and process each element
|
||||||
for extension in $extensions; do
|
for extension in $extensions; do
|
||||||
echo "Installing extension: $extension"
|
echo "Installing extension: $extension"
|
||||||
sudo su - ${HOME_USER} -c "code --install-extension $extension"
|
sudo su ${HOME_USER} -c "code --install-extension $extension"
|
||||||
done
|
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
|
||||||
sudo cp -R /home/${HOME_USER}/.vscode/* /home/${HOME_USER}/.vscode-server-insiders
|
sudo cp -R /home/${HOME_USER}/.vscode/* /home/${HOME_USER}/.vscode-server-insiders
|
||||||
@ -67,8 +157,8 @@ else
|
|||||||
echo "File extensions.json not found"
|
echo "File extensions.json not found"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "${VSCODE_TUNNEL_NAME}" ]]; then
|
if [[ -v VSCODE_TUNNEL_NAME && -n "${VSCODE_TUNNEL_NAME}" ]]; then
|
||||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
||||||
else
|
else
|
||||||
sudo su - ${HOME_USER} -c "code tunnel --accept-server-license-terms --name ${VSCODE_TUNNEL_NAME}"
|
sudo su ${HOME_USER} -c "code tunnel --accept-server-license-terms"
|
||||||
fi
|
fi
|
||||||
|
78
readme.md
78
readme.md
@ -17,6 +17,28 @@ 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.
|
- `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.
|
- `VSCODE_TUNNEL_NAME`: The name of the SSH tunnel used by Visual Studio Code to connect to the container.
|
||||||
|
|
||||||
|
### Custom Environment Variables
|
||||||
|
|
||||||
|
You can set custom environment variables for the `HOME_USER` by using the `USER_ENV_` prefix when running the Docker container. These environment variables will be created in the `/home/${HOME_USER}/.bashrc` file without the `USER_ENV_` prefix.
|
||||||
|
|
||||||
|
For example, if you want to set a custom environment variable named `MY_VARIABLE` for the `HOME_USER`, you can do so by setting the `USER_ENV_MY_VARIABLE` environment variable when running the Docker container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker run -it -e HOME_USER=custom-home-user -e USER_ENV_MY_VARIABLE=my_value -e VSCODE_TUNNEL_NAME=vscode-ssh-remote-server -v /path/to/extensions.json:/home/extensions.json aleleba/vscode
|
||||||
|
```
|
||||||
|
In this example, MY_VARIABLE will be set to my_value in the /home/${HOME_USER}/.bashrc file.
|
||||||
|
|
||||||
|
### Global Environment Variables
|
||||||
|
|
||||||
|
You can set global environment variables by using the `GLOBAL_ENV_` prefix when running the Docker container. These environment variables will be created in the `/etc/environment` file without the `GLOBAL_ENV_` prefix.
|
||||||
|
|
||||||
|
For example, if you want to set a global environment variable named `MY_GLOBAL_VARIABLE`, you can do so by setting the `GLOBAL_ENV_MY_GLOBAL_VARIABLE` environment variable when running the Docker container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker run -it -e HOME_USER=custom-home-user -e GLOBAL_ENV_MY_GLOBAL_VARIABLE=my_global_value -e VSCODE_TUNNEL_NAME=vscode-ssh-remote-server -v /path/to/extensions.json:/home/extensions.json aleleba/vscode
|
||||||
|
```
|
||||||
|
In this example, MY_GLOBAL_VARIABLE will be set to my_global_value in the /etc/environment file.
|
||||||
|
|
||||||
### Adding VSCode Extensions
|
### 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:
|
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:
|
||||||
@ -81,6 +103,48 @@ You can run this `docker-compose.yml` file by navigating to the directory where
|
|||||||
|
|
||||||
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.
|
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.
|
||||||
|
|
||||||
|
## Adding Custom Scripts
|
||||||
|
|
||||||
|
In this project, you can add custom scripts that will be automatically executed when the application starts. The `/usr/bin/custom-scripts` directory in the Docker container is a volume that maps to a directory on your host machine. Here's how you can add a custom script:
|
||||||
|
|
||||||
|
### 1. Create a new script file
|
||||||
|
|
||||||
|
Create a new file with a `.sh` extension in the directory on your host machine that maps to the `/usr/bin/custom-scripts` volume in the Docker container. For example, if the `/usr/bin/custom-scripts` volume maps to the `./custom-scripts` directory on your host machine, you can create a file named `install_node.sh` in the `./custom-scripts` directory.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
touch ./custom-scripts/install_node.sh
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2. Write your script
|
||||||
|
|
||||||
|
Open the file in a text editor and write your script. Here's an example that installs Node.js using NVM:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
#!/bin/bash
|
||||||
|
# Installing Node.js with NVM
|
||||||
|
sudo curl -O https://raw.githubusercontent.com/creationix/nvm/master/install.sh
|
||||||
|
bash install.sh
|
||||||
|
source ~/.nvm/nvm.sh
|
||||||
|
nvm install --lts
|
||||||
|
nvm alias default lts/*
|
||||||
|
nvm use default && npm install -g yo generator-code
|
||||||
|
nvm use default && npm install -g @vscode/vsce
|
||||||
|
```
|
||||||
|
The #!/bin/bash line at the top of the script tells the system that this script should be run with the Bash shell.
|
||||||
|
|
||||||
|
#### Note on sudo privileges
|
||||||
|
|
||||||
|
If the script name includes the word "sudo", the script will be run with root privileges. This is useful if your script needs to perform operations that require superuser privileges.
|
||||||
|
|
||||||
|
For instance, if you have a script named `install_sudo_package.sh`, this script will be run with root privileges due to the inclusion of "sudo" in the file name.
|
||||||
|
|
||||||
|
Please be aware of the security implications when running scripts with root privileges. Ensure that your script does not perform any unsafe or destructive operations when run with these privileges.
|
||||||
|
|
||||||
|
### 3. Run your Docker container
|
||||||
|
When you start your Docker container, all .sh files in the /usr/bin/custom-scripts directory will be automatically executed in alphabetical order. The environment variables from the /etc/environment file will be loaded before each script is executed.
|
||||||
|
|
||||||
|
Remember to replace install_node.sh with the name of your script and ./custom-scripts with the actual path to the directory on your host machine that maps to the /usr/bin/custom-scripts volume in the Docker container.
|
||||||
|
|
||||||
## Using this image as a base image in a Dockerfile
|
## 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`:
|
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`:
|
||||||
@ -88,6 +152,14 @@ To use this image as a base image in a Dockerfile, you can add the following lin
|
|||||||
```
|
```
|
||||||
FROM aleleba/vscode:latest
|
FROM aleleba/vscode:latest
|
||||||
|
|
||||||
|
ENV HOME_USER=vscode
|
||||||
|
|
||||||
|
RUN sudo adduser --disabled-password --gecos "" --uid 1000 ${HOME_USER}
|
||||||
|
RUN sudo echo "$HOME_USER ALL=(ALL) NOPASSWD:ALL" | sudo tee -a /etc/sudoers.d/nopasswd > /dev/null
|
||||||
|
|
||||||
|
USER ${HOME_USER}
|
||||||
|
WORKDIR /home/${HOME_USER}
|
||||||
|
|
||||||
# Installing node.js and NVM
|
# Installing node.js and NVM
|
||||||
SHELL ["/bin/bash", "--login", "-i", "-c"]
|
SHELL ["/bin/bash", "--login", "-i", "-c"]
|
||||||
RUN curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash
|
RUN curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash
|
||||||
@ -99,6 +171,12 @@ RUN echo 'source ~/.nvm/nvm.sh' >> ~/.bashrc
|
|||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
> **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
|
## Contributing
|
||||||
|
|
||||||
If you'd like to contribute to this project, please fork the repository and create a pull request.
|
If you'd like to contribute to this project, please fork the repository and create a pull request.
|
||||||
|
@ -1 +1 @@
|
|||||||
2.0.27
|
3.2.7
|
||||||
|
Loading…
Reference in New Issue
Block a user