 511c28150b
			
		
	
	
		511c28150b
		
			
		
	
	
	
	
		
			
			* feat: add AFFiNE * fix: add min and max values to password field * dezoom logo * fix password error message * change password requirements and error message * change version to "stable" * fix password min max in accordance to the regex validator Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> * add supported architectures * refactor(affine): small changes in compose file * fix(affine): change container names --------- Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> Co-authored-by: Stavros <steveiliop56@gmail.com>
		
			
				
	
	
		
			92 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| version: "3.9"
 | |
| services:
 | |
|   affine:
 | |
|     image: ghcr.io/toeverything/affine-graphql:stable
 | |
|     container_name: affine
 | |
|     command: ["sh", "-c", "node ./scripts/self-host-predeploy && node ./dist/index.js"]
 | |
|     ports:
 | |
|       - ${APP_PORT}:3010
 | |
|     depends_on:
 | |
|       affine-redis:
 | |
|         condition: service_healthy
 | |
|       affine-postgres:
 | |
|         condition: service_healthy
 | |
|     volumes:
 | |
|       # Custom configurations
 | |
|       - ${APP_DATA_DIR}/data/config:/root/.affine/config
 | |
|       # Blob storage
 | |
|       - ${APP_DATA_DIR}/data/storage:/root/.affine/storage
 | |
|     logging:
 | |
|       driver: "json-file"
 | |
|       options:
 | |
|         max-size: "1000m"
 | |
|     restart: unless-stopped
 | |
|     environment:
 | |
|       - NODE_OPTIONS="--import=./scripts/register.js"
 | |
|       - AFFINE_CONFIG_PATH=/root/.affine/config
 | |
|       - REDIS_SERVER_HOST=affine-redis
 | |
|       - DATABASE_URL=postgres://tipi:${AFFINE_POSTGRES_PASSWORD}@affine-postgres:5432/affine
 | |
|       - NODE_ENV=production
 | |
|       - AFFINE_ADMIN_EMAIL=${AFFINE_ADMIN_EMAIL}
 | |
|       - AFFINE_ADMIN_PASSWORD=${AFFINE_ADMIN_PASSWORD}
 | |
|       - TELEMETRY_ENABLE=${AFFINE_TELEMETRY_ENABLE}
 | |
|     networks:
 | |
|       - tipi_main_network
 | |
|     labels:
 | |
|       # Main
 | |
|       traefik.enable: true
 | |
|       traefik.http.middlewares.affine-web-redirect.redirectscheme.scheme: https
 | |
|       traefik.http.services.affine.loadbalancer.server.port: 3010
 | |
|       # Web
 | |
|       traefik.http.routers.affine-insecure.rule: Host(`${APP_DOMAIN}`)
 | |
|       traefik.http.routers.affine-insecure.entrypoints: web
 | |
|       traefik.http.routers.affine-insecure.service: affine
 | |
|       traefik.http.routers.affine-insecure.middlewares: affine-web-redirect
 | |
|       # Websecure
 | |
|       traefik.http.routers.affine.rule: Host(`${APP_DOMAIN}`)
 | |
|       traefik.http.routers.affine.entrypoints: websecure
 | |
|       traefik.http.routers.affine.service: affine
 | |
|       traefik.http.routers.affine.tls.certresolver: myresolver
 | |
|       # Local domain
 | |
|       traefik.http.routers.affine-local-insecure.rule: Host(`affine.${LOCAL_DOMAIN}`)
 | |
|       traefik.http.routers.affine-local-insecure.entrypoints: web
 | |
|       traefik.http.routers.affine-local-insecure.service: affine
 | |
|       traefik.http.routers.affine-local-insecure.middlewares: affine-web-redirect
 | |
|       # Local domain secure
 | |
|       traefik.http.routers.affine-local.rule: Host(`affine.${LOCAL_DOMAIN}`)
 | |
|       traefik.http.routers.affine-local.entrypoints: websecure
 | |
|       traefik.http.routers.affine-local.service: affine
 | |
|       traefik.http.routers.affine-local.tls: true
 | |
| 
 | |
|   affine-redis:
 | |
|     image: redis
 | |
|     container_name: affine-redis
 | |
|     restart: unless-stopped
 | |
|     volumes:
 | |
|       - ${APP_DATA_DIR}/data/redis:/data
 | |
|     healthcheck:
 | |
|       test: [ "CMD", "redis-cli", "--raw", "incr", "ping" ]
 | |
|       interval: 10s
 | |
|       timeout: 5s
 | |
|       retries: 5
 | |
|     networks:
 | |
|       - tipi_main_network
 | |
| 
 | |
|   affine-postgres:
 | |
|     image: postgres
 | |
|     container_name: affinepostgres
 | |
|     restart: unless-stopped
 | |
|     volumes:
 | |
|       - ${APP_DATA_DIR}/data/postgres:/var/lib/postgresql/data
 | |
|     healthcheck:
 | |
|       test: [ "CMD-SHELL", "pg_isready -U affine" ]
 | |
|       interval: 10s
 | |
|       timeout: 5s
 | |
|       retries: 5
 | |
|     environment:
 | |
|       POSTGRES_USER: tipi
 | |
|       POSTGRES_PASSWORD: ${AFFINE_POSTGRES_PASSWORD}
 | |
|       POSTGRES_DB: affine
 | |
|     networks:
 | |
|       - tipi_main_network
 |