forked from CCCHH/ansible-infra
		
	
		
			
				
	
	
		
			83 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Django/Jinja
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Django/Jinja
		
	
	
	
	
	
---
 | 
						|
version: "3.6"
 | 
						|
 | 
						|
services:
 | 
						|
  nextcloud:
 | 
						|
    build:
 | 
						|
      context: .
 | 
						|
      # Use the following example for adding cron:
 | 
						|
      # https://github.com/nextcloud/docker/tree/master/.examples/dockerfiles/cron/apache
 | 
						|
      dockerfile_inline: |
 | 
						|
        FROM nextcloud:{{ nextcloud__version }}
 | 
						|
 | 
						|
        RUN apt-get update && apt-get install -y \
 | 
						|
            supervisor \
 | 
						|
          && rm -rf /var/lib/apt/lists/* \
 | 
						|
          && mkdir /var/log/supervisord /var/run/supervisord
 | 
						|
 | 
						|
        RUN cat <<EOF > /supervisord.conf
 | 
						|
{% filter indent(width=8) %}
 | 
						|
        {{ lookup('ansible.builtin.file', 'supervisord.conf') }}
 | 
						|
{% endfilter %}
 | 
						|
        EOF
 | 
						|
 | 
						|
        ENV NEXTCLOUD_UPDATE=1
 | 
						|
 | 
						|
        CMD ["/usr/bin/supervisord", "-c", "/supervisord.conf"]
 | 
						|
    restart: unless-stopped
 | 
						|
    ports:
 | 
						|
      - "8080:80"
 | 
						|
    # This is a hotfix until we have a new mail setup and this also really
 | 
						|
    # doesn't belong into this role, but whatever, it works for now and it's not
 | 
						|
    # like anyone else really uses this role (or would be bothered by this
 | 
						|
    # really).
 | 
						|
    extra_hosts:
 | 
						|
      - "send-only-mailserver.ccchh.net:185.161.129.132"
 | 
						|
    depends_on:
 | 
						|
      - db
 | 
						|
      - redis
 | 
						|
    networks:
 | 
						|
      - nextcloud
 | 
						|
    volumes:
 | 
						|
{% if nextcloud__use_custom_new_user_skeleton %}
 | 
						|
      - "./custom_new_user_skeleton:/custom_new_user_skeleton"
 | 
						|
{% endif %}
 | 
						|
      - "./nextcloud_var_www_html:/var/www/html"
 | 
						|
      - "{{ nextcloud__data_dir }}:/var/www/html/data"
 | 
						|
    environment:
 | 
						|
      POSTGRES_HOST: db
 | 
						|
      POSTGRES_DB: nextcloud
 | 
						|
      POSTGRES_USER: nextcloud
 | 
						|
      POSTGRES_PASSWORD: "{{ nextcloud__postgres_password }}"
 | 
						|
      NEXTCLOUD_ADMIN_USER: admin
 | 
						|
      NEXTCLOUD_ADMIN_PASSWORD: "{{ nextcloud__admin_password }}"
 | 
						|
      REDIS_HOST: redis
 | 
						|
      NEXTCLOUD_TRUSTED_DOMAINS: "{{ nextcloud__fqdn }}"
 | 
						|
      # See here: https://github.com/nextcloud/docker#using-the-apache-image-behind-a-reverse-proxy-and-auto-configure-server-host-and-protocol
 | 
						|
      APACHE_DISABLE_REWRITE_IP: 1
 | 
						|
      TRUSTED_PROXIES: 127.0.0.1
 | 
						|
      OVERWRITECLIURL: "https://{{ nextcloud__fqdn }}/"
 | 
						|
      OVERWRITEHOST: "{{ nextcloud__fqdn }}"
 | 
						|
      OVERWRITEPROTOCOL: "https"
 | 
						|
    
 | 
						|
  db:
 | 
						|
    image: postgres:{{ nextcloud__postgres_version }}
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - nextcloud
 | 
						|
    volumes:
 | 
						|
      - "./database:/var/lib/postgresql/data"
 | 
						|
    environment:
 | 
						|
      POSTGRES_DB: nextcloud
 | 
						|
      POSTGRES_USER: nextcloud
 | 
						|
      POSTGRES_PASSWORD: "{{ nextcloud__postgres_password }}"
 | 
						|
 | 
						|
  redis:
 | 
						|
    image: redis:alpine
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - nextcloud
 | 
						|
 | 
						|
networks:
 | 
						|
  nextcloud:
 | 
						|
    external: false
 |