Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

134 lines
4.4KB

  1. #!/bin/bash
  2. source /etc/profile.d/gogs.sh
  3. # set DB root password from secret
  4. if [ ! -z $MYSQL_ROOT_PWD_FILE -a -f $MYSQL_ROOT_PWD_FILE ]; then
  5. MYSQL_ROOT_PWD=`cat $MYSQL_ROOT_PWD_FILE`;
  6. fi
  7. GOGS_DB_PWD=`openssl rand -base64 20`
  8. # set LDAP password from secret
  9. if [ ! -z $LDAP_BIND_PWD_FILE -a -f $LDAP_BIND_PWD_FILE ]; then
  10. LDAP_BIND_PWD=`cat $LDAP_BIND_PWD_FILE`;
  11. fi
  12. # set Admin password from secret
  13. if [ ! -z $GOGS_ADMIN_PWD_FILE -a -f $GOGS_ADMIN_PWD_FILE ]; then
  14. GOGS_ADMIN_PWD=`cat $GOGS_ADMIN_PWD_FILE`;
  15. fi
  16. # check needed variables
  17. if [[ -z ${DB_HOST} || -z ${GOGS_DB_NAME} \
  18. || -z ${GOGS_DB_USER} || -z ${GOGS_DB_PWD} \
  19. || -z ${GOGS_ADMIN_PWD} || -z ${ADMIN_EMAIL} \
  20. || -z ${LDAP_SERVER_HOST} || -z ${LDAP_BIND_DN} \
  21. || -z ${LDAP_BIND_PWD} || -z ${LDAP_SEARCH_BASE} \
  22. ]];
  23. then
  24. echo "Missing variable! You must provide: DB_HOST, GOGS_DB_NAME, \
  25. GOGS_DB_USER, GOGS_DB_PWD, GOGS_ADMIN_PWD, ADMIN_EMAIL and LDAP stuff";
  26. echo $DB_HOST, $GOGS_DB_NAME, $GOGS_DB_USER, ${#GOGS_DB_PWD}
  27. echo ${#GOGS_ADMIN_PWD}, ${ADMIN_EMAIL},
  28. echo ${LDAP_SERVER_HOST}, ${LDAP_BIND_DN}, ${#LDAP_BIND_PWD}, ${LDAP_SEARCH_BASE}
  29. #env;
  30. exit 1;
  31. fi
  32. function check_result {
  33. if [ $1 != 0 ]; then
  34. echo "Error: $2";
  35. exit 1;
  36. fi
  37. }
  38. # ### DB setup ###
  39. # wait for DB to be ready
  40. R=111
  41. while [ $R -eq 111 ]; do
  42. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "SHOW DATABASES" 2> /dev/null;
  43. R=$?;
  44. done
  45. # check if DB exists
  46. DB_EXISTS=$(mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "SHOW DATABASES" 2> /dev/null | grep ${GOGS_DB_NAME})
  47. echo DB exists: ${DB_EXISTS}
  48. if [ -z "${DB_EXISTS}" ]; then
  49. echo Creating Database
  50. #mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "DROP DATABASE IF EXISTS ${GOGS_DB_NAME};"
  51. #check_result $? "Dropping DB"
  52. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "CREATE DATABASE ${GOGS_DB_NAME};"
  53. check_result $? "Creating DB"
  54. fi
  55. echo Creating User
  56. # 'IF EXISTS' for DROP USER is available from MariaDB 10.1.3 only
  57. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "DROP USER ${GOGS_DB_USER};" || echo "It seems it didn't exist"
  58. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "CREATE USER ${GOGS_DB_USER} IDENTIFIED BY '${GOGS_DB_PWD}';"
  59. check_result $? "Creating User"
  60. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "GRANT ALL ON ${GOGS_DB_NAME}.* TO ${GOGS_DB_USER};"
  61. check_result $? "Granting permissions"
  62. mysql -u root -p${MYSQL_ROOT_PWD} -h ${DB_HOST} -e "FLUSH PRIVILEGES;"
  63. check_result $? "Flushing privileges"
  64. unset MYSQL_ROOT_PWD
  65. # ### Start ssh server ###
  66. echo "Starting ssh server"
  67. # https://bugs.launchpad.net/ubuntu/+source/openssh/+bug/45234
  68. mkdir -p /var/run/sshd
  69. #/usr/sbin/sshd
  70. service ssh start
  71. # SSH certs
  72. if [[ ! -e ${GOGS_CUSTOM}/https/cert.pem || ! -e ${GOGS_CUSTOM}/https/key.pem ]]; then
  73. su git -c "mkdir -p ${GOGS_CUSTOM}/https"
  74. su git -c "cd ${GOGS_CUSTOM}/https && ${GOPATH}/src/github.com/gogits/gogs/gogs cert --ca=true --duration=8760h0m0s --host=${GOGS_DOMAIN} && cd -"
  75. fi
  76. # ### Conf file ###
  77. echo Tweaking config files
  78. CONF_FILE=${GOGS_CUSTOM}/conf/app.ini
  79. # We need to re-generate conf file because we are changing DB pwd
  80. #if [[ ! -e ${CONF_FILE} ]]; then
  81. su git -c "mkdir -p ${GOGS_CUSTOM}/conf"
  82. mv ${GOPATH}/src/github.com/gogits/gogs/custom/conf/app.ini ${CONF_FILE}
  83. echo Setting domain
  84. sed -i "s/GOGS_DOMAIN/${GOGS_DOMAIN}/g" ${CONF_FILE}
  85. # DB conf
  86. echo Setting DB conf
  87. sed -i "s/DB_HOST/${DB_HOST}/g" ${CONF_FILE}
  88. sed -i "s/GOGS_DB_NAME/${GOGS_DB_NAME}/g" ${CONF_FILE}
  89. sed -i "s/GOGS_DB_USER/${GOGS_DB_USER}/g" ${CONF_FILE}
  90. sed -i "s/GOGS_DB_PWD/${GOGS_DB_PWD//\//\\/}/g" ${CONF_FILE}
  91. #fi
  92. # LDAP config
  93. LDAP_FILE=${GOGS_CUSTOM}/conf/auth.d/ldap.conf
  94. #if [[ ! -e ${CONF_FILE} ]]; then
  95. su git -c "mkdir -p ${GOGS_CUSTOM}/conf/auth.d"
  96. mv ${GOPATH}/src/github.com/gogits/gogs/custom/conf/auth.d/ldap.conf ${LDAP_FILE}
  97. echo Setting LDAP conf
  98. sed -i "s/LDAP_SERVER_HOST/${LDAP_SERVER_HOST}/g" ${LDAP_FILE}
  99. sed -i "s/LDAP_BIND_DN/${LDAP_BIND_DN}/g" ${LDAP_FILE}
  100. sed -i "s/LDAP_BIND_PWD/${LDAP_BIND_PWD}/g" ${LDAP_FILE}
  101. sed -i "s/LDAP_SEARCH_BASE/${LDAP_SEARCH_BASE}/g" ${LDAP_FILE}
  102. #fi
  103. # Create admin user if DB was new
  104. if [ -z "${DB_EXISTS}" ]; then
  105. su -c git "${GOPATH}/src/github.com/gogits/gogs/gogs admin create-user --name admin --password ${GOGS_ADMIN_PWD} --admin --email ${ADMIN_EMAIL}"
  106. fi
  107. #exec "$@"
  108. #exec gosu git ${GOPATH}/src/github.com/gogits/gogs/gogs web
  109. exec su git -c "${GOPATH}/src/github.com/gogits/gogs/gogs web"