2016-05-27 22:24:50 +00:00
|
|
|
#!/bin/sh
|
|
|
|
set -e -u
|
|
|
|
|
2020-06-10 12:38:41 +00:00
|
|
|
CONTAINER_HOME_DIR=/home/builder
|
2018-09-11 20:32:43 +00:00
|
|
|
UNAME=$(uname)
|
|
|
|
if [ "$UNAME" = Darwin ]; then
|
2017-07-15 09:37:17 +00:00
|
|
|
# Workaround for mac readlink not supporting -f.
|
|
|
|
REPOROOT=$PWD
|
2022-04-25 01:36:10 +00:00
|
|
|
SEC_OPT=""
|
2017-07-15 09:37:17 +00:00
|
|
|
else
|
|
|
|
REPOROOT="$(dirname $(readlink -f $0))/../"
|
2022-04-25 01:36:10 +00:00
|
|
|
SEC_OPT=" --security-opt seccomp=$REPOROOT/scripts/profile.json"
|
2017-07-15 09:37:17 +00:00
|
|
|
fi
|
2017-07-13 22:27:46 +00:00
|
|
|
|
2022-07-14 14:38:30 +00:00
|
|
|
# Required for Linux with SELinux and btrfs to avoid permission issues, eg: Fedora
|
|
|
|
# To reset, use "restorecon -Fr ."
|
|
|
|
# To check, use "ls -Z ."
|
|
|
|
if [ -n "$(command -v getenforce)" ] && [ "$(getenforce)" = Enforcing ]; then
|
|
|
|
VOLUME=$REPOROOT:$CONTAINER_HOME_DIR/termux-packages:z
|
|
|
|
else
|
|
|
|
VOLUME=$REPOROOT:$CONTAINER_HOME_DIR/termux-packages
|
|
|
|
fi
|
|
|
|
|
2019-08-02 14:39:27 +00:00
|
|
|
: ${TERMUX_BUILDER_IMAGE_NAME:=termux/package-builder}
|
2018-07-22 23:34:06 +00:00
|
|
|
: ${CONTAINER_NAME:=termux-package-builder}
|
2016-05-27 22:24:50 +00:00
|
|
|
|
2017-07-21 13:34:38 +00:00
|
|
|
USER=builder
|
2017-03-02 11:15:27 +00:00
|
|
|
|
2020-09-27 21:36:23 +00:00
|
|
|
if [ -n "${TERMUX_DOCKER_USE_SUDO-}" ]; then
|
|
|
|
SUDO="sudo"
|
|
|
|
else
|
|
|
|
SUDO=""
|
|
|
|
fi
|
|
|
|
|
2019-08-02 14:39:27 +00:00
|
|
|
echo "Running container '$CONTAINER_NAME' from image '$TERMUX_BUILDER_IMAGE_NAME'..."
|
2016-06-03 22:41:30 +00:00
|
|
|
|
2021-07-27 16:15:35 +00:00
|
|
|
# Check whether attached to tty and adjust docker flags accordingly.
|
|
|
|
if [ -t 1 ]; then
|
2020-01-23 19:27:06 +00:00
|
|
|
DOCKER_TTY=" --tty"
|
2021-07-27 16:15:35 +00:00
|
|
|
else
|
|
|
|
DOCKER_TTY=""
|
2020-01-23 19:27:06 +00:00
|
|
|
fi
|
|
|
|
|
2020-09-27 21:36:23 +00:00
|
|
|
$SUDO docker start $CONTAINER_NAME >/dev/null 2>&1 || {
|
2016-06-03 22:41:30 +00:00
|
|
|
echo "Creating new container..."
|
2020-09-27 21:36:23 +00:00
|
|
|
$SUDO docker run \
|
2019-02-21 01:35:57 +00:00
|
|
|
--detach \
|
|
|
|
--name $CONTAINER_NAME \
|
2022-07-14 14:38:30 +00:00
|
|
|
--volume $VOLUME \
|
2022-04-25 01:36:10 +00:00
|
|
|
$SEC_OPT \
|
2019-02-21 01:35:57 +00:00
|
|
|
--tty \
|
2019-08-02 14:39:27 +00:00
|
|
|
$TERMUX_BUILDER_IMAGE_NAME
|
2020-01-23 19:27:06 +00:00
|
|
|
if [ "$UNAME" != Darwin ]; then
|
|
|
|
if [ $(id -u) -ne 1000 -a $(id -u) -ne 0 ]; then
|
|
|
|
echo "Changed builder uid/gid... (this may take a while)"
|
2020-09-27 21:36:23 +00:00
|
|
|
$SUDO docker exec $DOCKER_TTY $CONTAINER_NAME sudo chown -R $(id -u) $CONTAINER_HOME_DIR
|
|
|
|
$SUDO docker exec $DOCKER_TTY $CONTAINER_NAME sudo chown -R $(id -u) /data
|
|
|
|
$SUDO docker exec $DOCKER_TTY $CONTAINER_NAME sudo usermod -u $(id -u) builder
|
|
|
|
$SUDO docker exec $DOCKER_TTY $CONTAINER_NAME sudo groupmod -g $(id -g) builder
|
2020-01-23 19:27:06 +00:00
|
|
|
fi
|
2019-02-12 08:23:21 +00:00
|
|
|
fi
|
2016-06-03 22:41:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if [ "$#" -eq "0" ]; then
|
2020-09-27 21:36:23 +00:00
|
|
|
$SUDO docker exec --interactive $DOCKER_TTY $CONTAINER_NAME bash
|
2016-06-03 22:41:30 +00:00
|
|
|
else
|
2020-09-27 21:36:23 +00:00
|
|
|
$SUDO docker exec --interactive $DOCKER_TTY $CONTAINER_NAME "$@"
|
2016-06-03 22:41:30 +00:00
|
|
|
fi
|