nix-unstable-static: add run_as_user.sh script
Allow to run nix as a user.
This commit is contained in:
parent
d884d77087
commit
bb3cbda9f3
2 changed files with 35 additions and 0 deletions
|
@ -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
|
||||
|
|
29
images/nix-unstable-static/run_as_user.sh
Executable file
29
images/nix-unstable-static/run_as_user.sh
Executable 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
|
Loading…
Add table
Add a link
Reference in a new issue