mirror of
https://github.com/coder/code-server.git
synced 2024-12-05 07:13:06 +08:00
5276e41606
* Allow user Entrypoint scripts
* Variable encapsulation
Co-authored-by: Asher <ash@coder.com>
* Check if Entrypoint Dir exists & run all executable
* Don't create entrypoint.d by default
* yarn fmt
* yarn fmt
* Fix for SC2044
* Revert "yarn fmt"
This reverts commit 5ca347f361
.
Co-authored-by: Asher <ash@coder.com>
28 lines
967 B
Bash
Executable File
28 lines
967 B
Bash
Executable File
#!/bin/sh
|
|
set -eu
|
|
|
|
# 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 [ "${DOCKER_USER-}" ]; then
|
|
USER="$DOCKER_USER"
|
|
if [ "$DOCKER_USER" != "$(whoami)" ]; then
|
|
echo "$DOCKER_USER ALL=(ALL) NOPASSWD:ALL" | sudo tee -a /etc/sudoers.d/nopasswd > /dev/null
|
|
# 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 "$DOCKER_USER" coder
|
|
sudo groupmod -n "$DOCKER_USER" coder
|
|
|
|
sudo sed -i "/coder/d" /etc/sudoers.d/nopasswd
|
|
fi
|
|
fi
|
|
|
|
# Allow users to have scripts run on container startup to prepare workspace.
|
|
# https://github.com/coder/code-server/issues/5177
|
|
if [ -d "${ENTRYPOINTD}" ]; then
|
|
find "${ENTRYPOINTD}" -type f -executable -print -exec {} \;
|
|
fi
|
|
|
|
exec dumb-init /usr/bin/code-server "$@"
|