entrypoint.sh 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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. # * PULL
  16. #
  17. # Default values
  18. # TODO: Voir avec Damien si c'est le comportement souhaité
  19. PULL=${PULL:=1}
  20. # Check environment variables
  21. /tracim/check_env_vars.sh
  22. # If PULL is set, change repository HEAD
  23. if [ "$PULL" = 1 ]; then
  24. echo "Upgrade Tracim code"
  25. cd /tracim && git pull origin master
  26. fi
  27. # Create config.ini file if no exist
  28. if [ ! -f /etc/tracim/config.ini ]; then
  29. cp /tracim/tracim/development.ini.base /etc/tracim/config.ini
  30. fi
  31. ln -s /etc/tracim/config.ini /tracim/tracim/config.ini
  32. # Create wsgidav.conf file if no exist
  33. if [ ! -f /etc/tracim/wsgidav.conf ]; then
  34. cp /tracim/tracim/wsgidav.conf.sample /etc/tracim/wsgidav.conf
  35. fi
  36. ln -s /etc/tracim/wsgidav.conf /tracim/tracim/wsgidav.conf
  37. # Create uwsgi file if no exist
  38. if [ ! -f /etc/tracim/uwsgi.ini ]; then
  39. cp /tracim/tracim/uwsgi.ini.template /etc/tracim/uwsgi.ini
  40. fi
  41. # MySQL case
  42. if [ "$DATABASE_TYPE" = mysql ] ; then
  43. # Ensure DATABASE_PORT is set
  44. if ! [ -n "$DATABASE_PORT" ]; then
  45. DATABASE_PORT=3306
  46. fi
  47. # engine is mysql+oursql
  48. DATABASE_TYPE=mysql+oursql
  49. # Check if database must be init
  50. 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';")
  51. if [ ${TEST_TABLE} = 0 ] ; then
  52. INIT_DATABASE=true
  53. fi
  54. fi
  55. # PostgreSQL case
  56. if [ "$DATABASE_TYPE" = postgresql ] ; then
  57. # Ensure DATABASE_PORT is set
  58. if ! [ -n "$DATABASE_PORT" ]; then
  59. DATABASE_PORT=5432
  60. fi
  61. DATABASE_SUFFIX="?client_encoding=utf8"
  62. # Check if database must be init
  63. 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' );")
  64. if [ ${TEST_TABLE} = f ] ; then
  65. INIT_DATABASE=true
  66. fi
  67. fi
  68. # SQLite case
  69. if [ "$DATABASE_TYPE" = sqlite ] ; then
  70. if [ ! -f /var/tracim/tracim.db ]; then
  71. INIT_DATABASE=true
  72. fi
  73. fi
  74. # Update radicale file system folder config
  75. sed -i "s/\(# radicale.server.filesystem.folder *= *\).*/radicale.server.filesystem.folder = \/var\/tracim\/radicale/" /etc/tracim/config.ini
  76. # Update sqlalchemy.url config
  77. if ! [ "$DATABASE_TYPE" = sqlite ] ; then
  78. 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
  79. else
  80. sed -i "s/\(sqlalchemy.url *= *\).*/\\sqlalchemy.url = sqlite:\/\/\/\/var\/tracim\/tracim.db/" /etc/tracim/config.ini
  81. fi
  82. # Initialize database if needed
  83. if [ "$INIT_DATABASE" = true ] ; then
  84. cd /tracim/tracim/ && gearbox setup-app -c config.ini
  85. fi
  86. # Upgrade database
  87. if [ "$PULL" = 1 ]; then
  88. echo "Upgrade Tracim database id required"
  89. cd /tracim/tracim/ && gearbox migrate upgrade
  90. fi
  91. # Start with uwsgi
  92. uwsgi --http-socket 0.0.0.0:80 /etc/tracim/uwsgi.ini