nix-unstable-static: add run_as_user.sh script

Allow to run nix as a user.
This commit is contained in:
zimbatm 2022-06-29 16:36:48 +02:00
parent d884d77087
commit bb3cbda9f3
No known key found for this signature in database
GPG key ID: 71BAF6D40C1D63D7
2 changed files with 35 additions and 0 deletions

View file

@ -61,6 +61,9 @@ let
# Make sure /tmp has the right permissions
chmod 1777 tmp
# Add user home folder
mkdir home
# Add SSL CA certs
cp -a "${cacert}/etc/ssl/certs/ca-bundle.crt" etc/ssl/certs/ca-bundle.crt
@ -80,6 +83,9 @@ let
done
mkdir -p libexec/nix
ln -s /bin/nix libexec/nix/build-remote
# Add run-as-user script
cp -a ${./run_as_user.sh} run_as_user.sh
'';
# To debug

View file

@ -0,0 +1,29 @@
#!/bin/sh -eu
#
# This script can be used as an entrypoint. It's used to synchronize and run
# the container with the same user and group as the host user.
#
# Usage:
# user_id=$(id -u) user_name=$(id -un) \
# group_id=$(id -g) group_name=$(id -gn) \
# ./run_as_user.sh [<command> ...<args>]
#
# shellcheck disable=SC2154
# Install the host user and group into the container
delgroup "${group_name}" 2>/dev/null || true
deluser "${user_name}" 2>/dev/null || true
addgroup -g "${group_id}" "${group_name}"
adduser -D -G "${group_name}" -u "${user_id}" "${user_name}"
# Don't propagate those env vars
user=${user_name}
unset user_id user_name group_id group_name
# Change into the user
if [ $# = 0 ]; then
exec su "${user}"
else
exec su "${user}" -c /bin/sh /bin/sh -c "exec \"\$@\"" "$@"
fi