| 
									
										
										
										
											2023-04-26 17:49:16 +00:00
										 |  |  | version: '3.7'
 | 
					
						
							|  |  |  | services:
 | 
					
						
							| 
									
										
										
										
											2023-06-18 16:02:29 +00:00
										 |  |  |   paperless-ngx:
 | 
					
						
							|  |  |  |     container_name: paperless-ngx
 | 
					
						
							| 
									
										
										
										
											2024-01-07 09:16:44 +00:00
										 |  |  |     image: ghcr.io/paperless-ngx/paperless-ngx:2.3.1
 | 
					
						
							| 
									
										
										
										
											2023-06-18 16:02:29 +00:00
										 |  |  |     restart: unless-stopped
 | 
					
						
							|  |  |  |     depends_on:
 | 
					
						
							|  |  |  |       - db
 | 
					
						
							|  |  |  |       - broker
 | 
					
						
							|  |  |  |     ports:
 | 
					
						
							|  |  |  |       - ${APP_PORT}:8000
 | 
					
						
							|  |  |  |     volumes:
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/paperless_data:/usr/src/paperless/data
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/paperless_media:/usr/src/paperless/media
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/paperless_export:/usr/src/paperless/export
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/paperless_consume:/usr/src/paperless/consume
 | 
					
						
							|  |  |  |     environment:
 | 
					
						
							|  |  |  |       PAPERLESS_REDIS: redis://broker:6379
 | 
					
						
							|  |  |  |       PAPERLESS_DBHOST: db
 | 
					
						
							|  |  |  |       PAPERLESS_ADMIN_USER: ${PAPERLESS_ADMIN_USERNAME}
 | 
					
						
							|  |  |  |       PAPERLESS_ADMIN_PASSWORD: ${PAPERLESS_ADMIN_PASSWORD}
 | 
					
						
							|  |  |  |       PAPERLESS_TIKA_ENABLED: ${PAPERLESS_TIKA_ENABLED}
 | 
					
						
							|  |  |  |       PAPERLESS_TIKA_GOTENBERG_ENDPOINT: http://gotenberg:3000
 | 
					
						
							|  |  |  |       PAPERLESS_TIKA_ENDPOINT: http://tika:9998
 | 
					
						
							|  |  |  |       PAPERLESS_URL: ${APP_PROTOCOL:-http}://${APP_DOMAIN}
 | 
					
						
							|  |  |  |       COMPOSE_PROJECT_NAME: paperless-ngx
 | 
					
						
							|  |  |  |     networks:
 | 
					
						
							|  |  |  |         - tipi_main_network
 | 
					
						
							|  |  |  |     labels:
 | 
					
						
							|  |  |  |       # Main
 | 
					
						
							|  |  |  |       traefik.enable: true
 | 
					
						
							|  |  |  |       traefik.http.middlewares.paperless-ngx-web-redirect.redirectscheme.scheme: https
 | 
					
						
							|  |  |  |       traefik.http.services.paperless-ngx.loadbalancer.server.port: 8000
 | 
					
						
							|  |  |  |         # Web
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-insecure.rule: Host(`${APP_DOMAIN}`)
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-insecure.entrypoints: web
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-insecure.service: paperless-ngx
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-insecure.middlewares: paperless-ngx-web-redirect
 | 
					
						
							|  |  |  |         # Websecure
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx.rule: Host(`${APP_DOMAIN}`)
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx.entrypoints: websecure
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx.service: paperless-ngx
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx.tls.certresolver: myresolver
 | 
					
						
							|  |  |  |         # Local domain
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local-insecure.rule: Host(`paperless-ngx.${LOCAL_DOMAIN}`)
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local-insecure.entrypoints: web
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local-insecure.service: paperless-ngx
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local-insecure.middlewares: paperless-ngx-web-redirect
 | 
					
						
							|  |  |  |         # Local domain secure
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local.rule: Host(`paperless-ngx.${LOCAL_DOMAIN}`)
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local.entrypoints: websecure
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local.service: paperless-ngx
 | 
					
						
							|  |  |  |       traefik.http.routers.paperless-ngx-local.tls: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-26 17:49:16 +00:00
										 |  |  |   # Redis
 | 
					
						
							|  |  |  |   broker:
 | 
					
						
							|  |  |  |     image: docker.io/library/redis:7
 | 
					
						
							|  |  |  |     restart: unless-stopped
 | 
					
						
							|  |  |  |     volumes:
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/redis:/data
 | 
					
						
							|  |  |  |     networks:
 | 
					
						
							|  |  |  |       - tipi_main_network
 | 
					
						
							|  |  |  |   
 | 
					
						
							|  |  |  |   # Postgres SQL
 | 
					
						
							|  |  |  |   db:
 | 
					
						
							| 
									
										
										
										
											2023-09-16 00:26:40 +00:00
										 |  |  |     image: docker.io/library/postgres:16
 | 
					
						
							| 
									
										
										
										
											2023-04-26 17:49:16 +00:00
										 |  |  |     restart: unless-stopped
 | 
					
						
							|  |  |  |     volumes:
 | 
					
						
							|  |  |  |       - ${APP_DATA_DIR}/data/postgres:/var/lib/postgresql/data
 | 
					
						
							|  |  |  |     environment:
 | 
					
						
							|  |  |  |       POSTGRES_DB: paperless
 | 
					
						
							|  |  |  |       POSTGRES_USER: paperless
 | 
					
						
							|  |  |  |       POSTGRES_PASSWORD: paperless
 | 
					
						
							|  |  |  |     networks:
 | 
					
						
							|  |  |  |       - tipi_main_network
 | 
					
						
							|  |  |  |       
 | 
					
						
							|  |  |  |   gotenberg:
 | 
					
						
							| 
									
										
										
										
											2024-01-04 20:32:50 +00:00
										 |  |  |     image: docker.io/gotenberg/gotenberg:8.0
 | 
					
						
							| 
									
										
										
										
											2023-04-26 17:49:16 +00:00
										 |  |  |     restart: unless-stopped
 | 
					
						
							|  |  |  |     # The gotenberg chromium route is used to convert .eml files. We do not
 | 
					
						
							|  |  |  |     # want to allow external content like tracking pixels or even javascript.
 | 
					
						
							|  |  |  |     command:
 | 
					
						
							|  |  |  |       - "gotenberg"
 | 
					
						
							|  |  |  |       - "--chromium-disable-javascript=true"
 | 
					
						
							|  |  |  |       - "--chromium-allow-list=file:///tmp/.*"
 | 
					
						
							|  |  |  |     networks:
 | 
					
						
							|  |  |  |     - tipi_main_network
 | 
					
						
							|  |  |  |       
 | 
					
						
							|  |  |  |   tika:
 | 
					
						
							|  |  |  |     image: ghcr.io/paperless-ngx/tika:latest
 | 
					
						
							|  |  |  |     restart: unless-stopped
 | 
					
						
							|  |  |  |     networks:
 | 
					
						
							|  |  |  |     - tipi_main_network
 | 
					
						
							|  |  |  |       
 |