entrypoint.sh 3.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. #!/usr/bin/env bash
  2. # TODO: generate cookie secrent (if not yet done)
  3. # TODO: run uwsgi as other user
  4. # TODO: Gestion des migrations
  5. # TODO: Verbosite des logs ?
  6. #
  7. # ENVIRONMENT VARIABLES ARE:
  8. #
  9. # * DATABASE_TYPE (values: postgresql, mysql, sqlite)
  10. # * DATABASE_USER
  11. # * DATABASE_PASSWORD
  12. # * DATABASE_HOST
  13. # * DATABASE_PORT
  14. # * DATABASE_NAME
  15. #
  16. # Check environment variables
  17. /tracim/check_env_vars.sh
  18. # Create config.ini file if no exist
  19. if [ ! -f /etc/tracim/config.ini ]; then
  20. cp /tracim/tracim/development.ini.base /etc/tracim/config.ini
  21. fi
  22. ln -s /etc/tracim/config.ini /tracim/tracim/config.ini
  23. # Create wsgidav.conf file if no exist
  24. if [ ! -f /etc/tracim/wsgidav.conf ]; then
  25. cp /tracim/tracim/wsgidav.conf.sample /etc/tracim/wsgidav.conf
  26. fi
  27. ln -s /etc/tracim/wsgidav.conf /tracim/tracim/wsgidav.conf
  28. # Create uwsgi file if no exist
  29. if [ ! -f /etc/tracim/uwsgi.ini ]; then
  30. cp /tracim/tracim/uwsgi.ini.template /etc/tracim/uwsgi.ini
  31. fi
  32. # MySQL case
  33. if [ "$DATABASE_TYPE" = mysql ] ; then
  34. # Ensure DATABASE_PORT is set
  35. if ! [ -n "$DATABASE_PORT" ]; then
  36. DATABASE_PORT=3306
  37. fi
  38. # engine is mysql+oursql
  39. DATABASE_TYPE=mysql+oursql
  40. # Check if database must be init
  41. TEST_TABLE=$(mysql --host="$DATABASE_HOST" --user="$DATABASE_USER" --password="$DATABASE_USER" --database="$DATABASE_NAME" -s -N --execute="SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = '$DATABASE_NAME' AND table_name = 'content';")
  42. if [ ${TEST_TABLE} = 0 ] ; then
  43. INIT_DATABASE=true
  44. fi
  45. fi
  46. # PostgreSQL case
  47. if [ "$DATABASE_TYPE" = postgresql ] ; then
  48. # Ensure DATABASE_PORT is set
  49. if ! [ -n "$DATABASE_PORT" ]; then
  50. DATABASE_PORT=5432
  51. fi
  52. DATABASE_SUFFIX="?client_encoding=utf8"
  53. # Check if database must be init
  54. TEST_TABLE=$(PGPASSWORD="$DATABASE_PASSWORD" psql -U ${DATABASE_USER} -h ${TEST_TABLE} -d ${DATABASE_NAME} -t -c "SELECT EXISTS (SELECT 1 FROM information_schema.tables WHERE table_schema = 'public' AND table_name = 'content' );")
  55. if [ ${TEST_TABLE} = f ] ; then
  56. INIT_DATABASE=true
  57. fi
  58. fi
  59. # SQLite case
  60. if [ "$DATABASE_TYPE" = sqlite ] ; then
  61. if [ ! -f /var/tracim/tracim.db ]; then
  62. INIT_DATABASE=true
  63. fi
  64. fi
  65. # Update radicale file system folder config
  66. sed -i "s/\(# radicale.server.filesystem.folder *= *\).*/radicale.server.filesystem.folder = \/var\/tracim\/radicale/" /etc/tracim/config.ini
  67. # Update sqlalchemy.url config
  68. if ! [ "$DATABASE_TYPE" = sqlite ] ; then
  69. sed -i "s/\(sqlalchemy.url *= *\).*/\\sqlalchemy.url = $DATABASE_TYPE:\/\/$DATABASE_USER:$DATABASE_PASSWORD@$DATABASE_HOST:$DATABASE_PORT\/$DATABASE_NAME$DATABASE_SUFFIX/" /etc/tracim/config.ini
  70. else
  71. sed -i "s/\(sqlalchemy.url *= *\).*/\\sqlalchemy.url = sqlite:\/\/\/\/var\/tracim\/tracim.db/" /etc/tracim/config.ini
  72. fi
  73. # Initialize database if needed
  74. if [ "$INIT_DATABASE" = true ] ; then
  75. cd /tracim/tracim/ && gearbox setup-app -c config.ini
  76. fi
  77. # Start with uwsgi
  78. uwsgi --http-socket 0.0.0.0:80 /etc/tracim/uwsgi.ini