blob: fb193df9a00a9402bf5877b83e08e1a971230252 [file] [log] [blame]
#!/bin/bash
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
################################
#
# Prep
#
################################
if [ "$1" == "-h" ]; then
echo "$0 [-h] <username> <uid> <gid>"
echo " this script is used internally by other scripts in the same directory to create a user with the running host user's same uid and gid"
exit 1
fi
# arguments
username=$1
uid=$2
gid=$3
BUILD_HOME=$4
################################
#
# Main
#
################################
# disable git directory ownership checks
su ${username} -c "git config --global safe.directory '*'"
if grep "^ID=" /etc/os-release | grep -q 'debian\|ubuntu' ; then
deluser docker
adduser --quiet --disabled-login --no-create-home --uid $uid --gecos ${username} ${username}
groupmod --non-unique -g $gid $username
gpasswd -a ${username} sudo >/dev/null
else
adduser --no-create-home --uid $uid ${username}
fi
# sudo priviledges
echo "${username} ALL=(root) NOPASSWD:ALL" > /etc/sudoers.d/${username}
chmod 0440 /etc/sudoers.d/${username}
# proper permissions
chown -R ${username}:${username} /home/docker
chmod og+wx ${BUILD_HOME}