docker-code-server/root/etc/cont-init.d/30-config

38 lines
1.3 KiB
Plaintext
Raw Normal View History

2019-06-24 18:03:06 +00:00
#!/usr/bin/with-contenv bash
2019-06-24 19:15:27 +00:00
mkdir -p /config/{extensions,data,workspace,.ssh}
2019-06-24 18:03:06 +00:00
2020-12-24 01:03:43 +00:00
if [ -n "${SUDO_PASSWORD}" ] || [ -n "${SUDO_PASSWORD_HASH}" ]; then
2021-05-08 14:50:21 +00:00
echo "setting up sudo access"
if ! grep -q 'abc' /etc/sudoers; then
echo "adding abc to sudoers"
echo "abc ALL=(ALL:ALL) ALL" >> /etc/sudoers
fi
if [ -n "${SUDO_PASSWORD_HASH}" ]; then
echo "setting sudo password using sudo password hash"
sed -i "s|^abc:\!:|abc:${SUDO_PASSWORD_HASH}:|" /etc/shadow
else
echo "setting sudo password using SUDO_PASSWORD env var"
echo -e "${SUDO_PASSWORD}\n${SUDO_PASSWORD}" | passwd abc
fi
fi
2019-06-24 18:03:06 +00:00
# permissions
if [ -f "/usr/bin/find" ] && [ -f "/usr/bin/xargs" ]; then
# Split workload between config and workspace
echo "setting permissions::configuration"
CORES=$(nproc --all)
find /config -maxdepth 4 -mindepth 1 -path /config/workspace -prune -false -o -type d | \
xargs --max-args=1 --max-procs=$(($CORES*2*8)) \
chown -R abc:abc
echo "setting permissions::workspace"
chown abc:abc /config/workspace
find /config/workspace -maxdepth 4 -mindepth 1 -type d | \
xargs --max-args=1 --max-procs=$(($CORES*2*16)) \
chown -R abc:abc
else
chown -R abc:abc \
/config
fi