Patch by Benjamin Drung

If the sysadmin changes the gitlab user in
/etc/gitlab/gitlab-debian.conf, the package installation or upgrade will
fail, because grantpriv.sh will always grant privileges to the gitlab
user. Thus adapt grantpriv.sh to honor the gitlab_user setting.
This commit is contained in:
Praveen Arimbrathodiyil 2017-02-15 11:06:52 +05:30
parent 1359e5823c
commit e7430db19d

18
debian/grantpriv.sh vendored
View file

@ -1,26 +1,28 @@
#!/bin/sh #!/bin/sh
user=gitlab
dbname=gitlab_production dbname=gitlab_production
# Take gitlab_user from envornment variable or use gitlab
test -n "${gitlab_user:-}" || gitlab_user="gitlab"
# If gitlab user cannot access gitlab_production, # If gitlab user cannot access gitlab_production,
# then it means the gitlab role does not exist # then it means the gitlab role does not exist
if ! su gitlab -c 'psql gitlab_production -c ""' if ! su ${gitlab_user} -c 'psql gitlab_production -c ""'
then then
echo "Create $user user with create database privillege..." echo "Create ${gitlab_user} user with create database privillege..."
su postgres -c "psql -c \"CREATE USER $user CREATEDB;\"" || { su postgres -c "psql -c \"CREATE USER ${gitlab_user} CREATEDB;\"" || {
exit 1 exit 1
} }
fi fi
# By default the gitlab_prodcution is not owned by gitlab user # By default the gitlab_prodcution is not owned by gitlab user
echo "Make $user user owner of $dbname database..." echo "Make ${gitlab_user} user owner of $dbname database..."
su postgres -c "psql -c \"ALTER DATABASE $dbname OWNER to $user;\"" || { su postgres -c "psql -c \"ALTER DATABASE $dbname OWNER to ${gitlab_user};\"" || {
exit 1 exit 1
} }
echo "Grant all privileges to $user user..." echo "Grant all privileges to ${gitlab_user} user..."
su postgres -c "psql -c \"GRANT ALL PRIVILEGES ON DATABASE template1 to $user;\"" || { su postgres -c "psql -c \"GRANT ALL PRIVILEGES ON DATABASE template1 to ${gitlab_user};\"" || {
exit 1 exit 1
} }