setup.sh 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #!/usr/bin/env bash
  2. set -e
  3. if [ "$1" = 'builder' ]; then
  4. PACKAGES="build-essential curl git libimlib2-dev libpq-dev shared-mime-info postgresql"
  5. elif [ "$1" = 'runner' ]; then
  6. PACKAGES="curl libimlib2 libpq5 nginx gnupg postgresql-client"
  7. fi
  8. apt-get update
  9. apt-get upgrade -y
  10. # shellcheck disable=SC2086
  11. apt-get install -y --no-install-recommends ${PACKAGES}
  12. rm -rf /var/lib/apt/lists/*
  13. if [ "$1" = 'builder' ]; then
  14. # Create an empty DB just so that the Rails stack can run.
  15. /etc/init.d/postgresql start
  16. su - postgres bash -c "createuser zammad -R -S"
  17. su - postgres bash -c "createdb --encoding=utf8 --owner=zammad zammad"
  18. cd "${ZAMMAD_DIR}"
  19. bundle config set without 'test development mysql'
  20. bundle install
  21. touch db/schema.rb
  22. ZAMMAD_SAFE_MODE=1 DATABASE_URL=postgresql://zammad:/zammad bundle exec rake assets:precompile # Don't require Redis.
  23. rm -r tmp/*
  24. script/build/cleanup.sh
  25. fi
  26. if [ "$1" = 'runner' ]; then
  27. groupadd -g 1000 "${ZAMMAD_USER}"
  28. useradd -M -d "${ZAMMAD_DIR}" -s /bin/bash -u 1000 -g 1000 "${ZAMMAD_USER}"
  29. sed -i -e "s#user www-data;##g" -e 's#/var/log/nginx/\(access\|error\).log#/dev/stdout#g' -e 's#pid /run/nginx.pid;#pid /tmp/nginx.pid;#g' /etc/nginx/nginx.conf
  30. mkdir -p "${ZAMMAD_DIR}" /var/log/nginx
  31. chown -R "${ZAMMAD_USER}":"${ZAMMAD_USER}" /etc/nginx /var/lib/nginx /var/log/nginx "${ZAMMAD_DIR}"
  32. fi