2020-03-14 01:49:34 +08:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2020-03-14 08:12:03 +08:00
|
|
|
# we first check whether the user is in the group docker
|
2020-03-14 01:49:34 +08:00
|
|
|
user=$(id -un)
|
2020-03-14 08:12:03 +08:00
|
|
|
DIR_UUID=$(cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1)
|
2020-03-14 01:49:34 +08:00
|
|
|
group=$(id -gn)
|
|
|
|
uid=$(id -u)
|
|
|
|
gid=$(id -g)
|
2020-03-14 07:38:16 +08:00
|
|
|
gids=( $(id -G) )
|
|
|
|
groups=( $(id -Gn) )
|
2020-03-14 01:49:34 +08:00
|
|
|
tmpdir="/tmp/fdb-docker-${DIR_UUID}"
|
|
|
|
image=fdb-dev
|
|
|
|
|
|
|
|
pushd .
|
|
|
|
mkdir ${tmpdir}
|
|
|
|
cd ${tmpdir}
|
|
|
|
|
2020-03-14 07:38:16 +08:00
|
|
|
echo
|
|
|
|
|
2020-03-14 01:49:34 +08:00
|
|
|
cat <<EOF >> Dockerfile
|
|
|
|
FROM foundationdb/foundationdb-build:latest
|
2020-03-16 01:56:44 +08:00
|
|
|
RUN yum install -y sudo
|
|
|
|
RUN echo '%sudo ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
|
|
|
|
RUN groupadd -g 1100 sudo
|
2020-03-14 07:38:16 +08:00
|
|
|
EOF
|
|
|
|
|
|
|
|
num_groups=${#gids[@]}
|
2020-03-16 01:56:44 +08:00
|
|
|
additional_groups="-G sudo"
|
2020-03-14 07:38:16 +08:00
|
|
|
for ((i=0;i<num_groups;i++))
|
|
|
|
do
|
|
|
|
echo "RUN groupadd -g ${gids[$i]} ${groups[$i]}" >> Dockerfile
|
|
|
|
if [ ${gids[i]} -ne ${gid} ]
|
|
|
|
then
|
2020-03-16 01:56:44 +08:00
|
|
|
additional_groups="${additional_groups},${gids[$i]}"
|
2020-03-14 07:38:16 +08:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
cat <<EOF >> Dockerfile
|
|
|
|
RUN useradd -u ${uid} -g ${gid} ${additional_groups} -m ${user}
|
2020-03-14 01:49:34 +08:00
|
|
|
|
|
|
|
USER ${user}
|
|
|
|
CMD scl enable devtoolset-8 rh-python36 rh-ruby24 -- bash
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
echo "Created ${tmpdir}"
|
|
|
|
echo "Buidling Docker container ${image}"
|
2020-03-16 01:45:18 +08:00
|
|
|
sudo docker build -t ${image} .
|
2020-03-14 01:49:34 +08:00
|
|
|
|
|
|
|
popd
|
|
|
|
|
|
|
|
echo "Writing startup script"
|
|
|
|
mkdir -p $HOME/bin
|
|
|
|
cat <<EOF > $HOME/bin/fdb-dev
|
|
|
|
#!/usr/bin/bash
|
|
|
|
|
2020-03-14 07:38:16 +08:00
|
|
|
if [ -d "\${CCACHE_DIR}" ]
|
|
|
|
then
|
|
|
|
args="-v \${CCACHE_DIR}:\${CCACHE_DIR}"
|
|
|
|
args="\${args} -e CCACHE_DIR=\${CCACHE_DIR}"
|
|
|
|
args="\${args} -e CCACHE_UMASK=\${CCACHE_UMASK}"
|
|
|
|
ccache_args=\$args
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2020-03-16 01:45:18 +08:00
|
|
|
sudo docker run --rm `# delete (temporary) image after return` \\
|
2020-03-14 01:49:34 +08:00
|
|
|
-it `# Run in interactive mode and simulate a TTY` \\
|
|
|
|
--privileged=true `# Run in privileged mode ` \\
|
|
|
|
--cap-add=SYS_PTRACE \\
|
|
|
|
--security-opt seccomp=unconfined \\
|
2020-03-14 03:34:39 +08:00
|
|
|
-v "${HOME}:${HOME}" `# Mount home directory` \\
|
2020-03-14 07:38:16 +08:00
|
|
|
\${ccache_args} \\
|
2020-03-14 01:49:34 +08:00
|
|
|
${image}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
chmod +x $HOME/bin/fdb-dev
|
|
|
|
echo "To start the dev docker image run $HOME/bin/fdb-dev"
|
|
|
|
echo "You can edit this file but be aware that this script will overwrite your changes if you rerun it"
|