--- version: "3.8" services: app: image: michaelmcandrew/civicrm:5.59.4-wordpress-php8.1 hostname: civicrm environment: - PROJECT_NAME - BASE_URL=https://${DOMAIN} - CIVICRM_DB_NAME=civicrm - CIVICRM_DB_USER=civicrm - CIVICRM_DB_PASS_FILE=/run/secrets/db_password - CIVICRM_DB_HOST=civicrm-db - CIVICRM_DB_PORT=3306 - CIVICRM_COMPONENTS - CIVICRM_EXTENSIONS - WORDPRESS_DB_NAME=wordpress - WORDPRESS_DB_USER=wordpress - WORDPRESS_DB_PASS_FILE=/run/secrets/db_password - WORDPRESS_DB_HOST=db - WORDPRESS_DB_PORT=3306 - SMTP_HOST - SMTP_PORT - SMTP_USER - SMTP_PASSWORD_FILE=/run/secrets/smtp_password secrets: - db_password - civicrm_site_key - civicrm_cred_key - civicrm_sign_key - smtp_password volumes: - data:/var/www/html/wp-content/uploads networks: - default - proxy configs: - source: apache-sites-available-conf target: /etc/apache2/sites-available/000-default.conf - source: entrypoint target: /usr/local/bin/entrypoint.sh mode: 555 - source: civicrm-settings-php target: /usr/local/etc/civicrm/civicrm.settings.php entrypoint: /usr/local/bin/entrypoint.sh deploy: restart_policy: condition: on-failure labels: - "traefik.enable=true" - "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=80" - "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`${EXTRA_DOMAINS})" - "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure" - "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}" ## Redirect from EXTRA_DOMAINS to DOMAIN #- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true" #- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}" - "coop-cloud.${STACK_NAME}.version=0.1.1+5.59.4-wordpress-php8.1" - "backupbot.backup=true" - "backupbot.backup.path=/var/www/html/wp-content/uploads" healthcheck: test: [ "CMD", "cv", "api", "system.get" ] interval: 30s timeout: 10s retries: 10 start_period: 10s db: &db image: "mariadb:10.11" volumes: - "mariadb:/var/lib/mysql" environment: - MYSQL_DATABASE=wordpress - MYSQL_USER=wordpress - MYSQL_PASSWORD_FILE=/run/secrets/db_password - MYSQL_ROOT_PASSWORD_FILE=/run/secrets/db_root_password secrets: - db_password - db_root_password healthcheck: test: [ "CMD-SHELL", 'mysqladmin -p"$$(cat /run/secrets/db_root_password)" ping' ] interval: 30s timeout: 10s retries: 10 start_period: 1m deploy: restart_policy: condition: on-failure labels: backupbot.backup: "true" backupbot.backup.path: "/tmp/dump.sql" backupbot.backup.pre-hook: "sh -c 'mysqldump --single-transaction -u root -p\"$$(cat /run/secrets/db_root_password)\" $${MYSQL_DATABASE} > /tmp/dump.sql'" backupbot.backup.post-hook: "rm -f /tmp/dump.sql" backupbot.restore: "true" backupbot.restore.post-hook: "sh -c 'mysql -u root -p\"$$(cat /run/secrets/db_root_password)\" $${MYSQL_DATABASE} < /tmp/dump.sql && rm -f /tmp/dump.sql'" civicrm-db: <<: *db volumes: - "civicrm-db:/var/lib/mysql" environment: - MYSQL_DATABASE=civicrm - MYSQL_USER=civicrm - MYSQL_PASSWORD_FILE=/run/secrets/db_password - MYSQL_ROOT_PASSWORD_FILE=/run/secrets/db_root_password networks: proxy: external: true volumes: mariadb: civicrm-db: data: configs: apache-sites-available-conf: name: ${STACK_NAME}_apache_sites_available_conf_${APACHE_SITES_AVAILABLE_CONF_VERSION} file: apache-sites-available-default.conf.tmpl template_driver: golang civicrm-settings-php: name: ${STACK_NAME}_civicrm_settings_php_${CIVICRM_SETTINGS_PHP_VERSION} file: civicrm.settings.php template_driver: golang entrypoint: name: ${STACK_NAME}_entrypoint_${ENTRYPOINT_VERSION} file: entrypoint.sh template_driver: golang secrets: db_root_password: external: true name: ${STACK_NAME}_db_root_password_${SECRET_DB_ROOT_PASSWORD_VERSION} smtp_password: external: true name: ${STACK_NAME}_smtp_password_${SECRET_SMTP_PASSWORD_VERSION} db_password: external: true name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION} civicrm_site_key: external: true name: ${STACK_NAME}_civicrm_site_key_${SECRET_CIVICRM_SITE_KEY_VERSION} civicrm_cred_key: external: true name: ${STACK_NAME}_civicrm_cred_key_${SECRET_CIVICRM_CRED_KEY_VERSION} civicrm_sign_key: external: true name: ${STACK_NAME}_civicrm_sign_key_${SECRET_CIVICRM_SIGN_KEY_VERSION}