From 7874183392863b2ffda01b32139b9228be50be78 Mon Sep 17 00:00:00 2001 From: Rishi Ghan Date: Wed, 31 Dec 2025 10:02:47 -0800 Subject: [PATCH] Added working plane-app configuration --- stacks/plane/README.md | 95 ++++--- .../archive/1767200198.docker-compose.yaml | 255 ++++++++++++++++++ stacks/plane/plane-app/archive/1767200198.env | 85 ++++++ stacks/plane/plane-app/docker-compose.yaml | 255 ++++++++++++++++++ stacks/plane/plane-app/plane.env | 85 ++++++ stacks/plane/plane-app/plane.env.bak | 85 ++++++ 6 files changed, 818 insertions(+), 42 deletions(-) create mode 100644 stacks/plane/plane-app/archive/1767200198.docker-compose.yaml create mode 100644 stacks/plane/plane-app/archive/1767200198.env create mode 100644 stacks/plane/plane-app/docker-compose.yaml create mode 100644 stacks/plane/plane-app/plane.env create mode 100644 stacks/plane/plane-app/plane.env.bak diff --git a/stacks/plane/README.md b/stacks/plane/README.md index 3766d95..747b774 100644 --- a/stacks/plane/README.md +++ b/stacks/plane/README.md @@ -1,51 +1,62 @@ -# Plane +# Flook Stacks -Project management and issue tracking with kanban boards. +Docker Compose stacks for Flook (192.168.1.75) managed via Portainer. -## Deployment +## Stacks -1. Create directories: -```bash -mkdir -p /mnt/user/appdata/plane/{db-data,redis-data,minio-data} -``` +| Stack | Services | Port(s) | Description | +|-------|----------|---------|-------------| +| portainer | portainer | 9000 | Stack management | +| documents | paperless, paperless-db, paperless-redis, paperless-tika, paperless-gotenberg, onlyoffice | 8777, 8089, 4430 | Document management | +| productivity | gitlab, vaultwarden, memos, mortis, freshrss | 8929, 4743, 5230, 5231, 8054 | Personal tools | +| backup | borgmatic | - | Borg backup to chook | +| seafile | seafile, seadoc, mysql, redis, notification, md-server, seasearch | 8098, 8888, 8083, 8084, 4080 | File sync | +| outline | outline, postgres, redis | 3000 | Wiki | +| plane | web, api, worker, beat-worker, admin, space, live, proxy, db, redis, mq, minio | 8082 | Project management | -2. Deploy via Portainer git stack or: +## External Services (qsrproxy - 192.168.1.72) + +| Service | Port(s) | Description | +|---------|---------|-------------| +| npm | 1880, 18443, 81 | Nginx Proxy Manager (CRITICAL) | +| prometheus | 9090 | Metrics collection | +| grafana | 3000 | Dashboards | +| alertmanager | 9093 | Alert routing | +| node-exporter | 9100 | System metrics | + +## Deployment Order + +1. `portainer` - Deploy first, manually +2. `productivity` - GitLab, Vaultwarden, Memos, FreshRSS, Mortis +3. `documents` - Paperless, OnlyOffice +4. `backup` - Borgmatic +5. `seafile` - File sync and collaboration +6. `outline` - Wiki +7. `plane` - Project management + +## Plane Notes + +Plane requires specific env variables. Run with: ```bash cd /mnt/user/data/flook-stacks/stacks/plane +docker compose --env-file plane.env up -d +``` + +Key env settings: +- `APP_DOMAIN=plane.rishighan.com` +- `LISTEN_HTTP_PORT=8082` +- `WEB_URL=https://plane.rishighan.com` +- `CERT_EMAIL=email admin@rishighan.com` + +## Seafile Notes + +Seafile uses multiple compose files and cannot be deployed via Portainer git stack. Deploy from command line: +```bash +cd /mnt/user/appdata/seafile docker compose up -d ``` -3. Wait for all services to start (may take a few minutes on first run) - -4. Access at `http://192.168.1.75:8082` or via NPM proxy - -## Services - -| Container | Description | -|-----------|-------------| -| plane-web | Frontend | -| plane-api | Backend API | -| plane-worker | Background jobs | -| plane-beat-worker | Scheduled tasks | -| plane-space | Public pages | -| plane-proxy | Nginx proxy | -| plane-db | PostgreSQL | -| plane-redis | Redis | -| plane-minio | S3-compatible storage | - -## NPM Proxy - -Add proxy host: -- Domain: `plane.rishighan.com` -- Forward: `192.168.1.75:8082` -- Enable SSL, force SSL, HTTP/2 - -## Volumes - -- `/mnt/user/appdata/plane/db-data` - PostgreSQL data -- `/mnt/user/appdata/plane/redis-data` - Redis data -- `/mnt/user/appdata/plane/minio-data` - File uploads - -## Default Login - -On first access, you'll create an admin account. +## Repository +``` +https://git.rishighan.com/root/flook-stacks.git +``` diff --git a/stacks/plane/plane-app/archive/1767200198.docker-compose.yaml b/stacks/plane/plane-app/archive/1767200198.docker-compose.yaml new file mode 100644 index 0000000..d4de33a --- /dev/null +++ b/stacks/plane/plane-app/archive/1767200198.docker-compose.yaml @@ -0,0 +1,255 @@ +x-db-env: &db-env + PGHOST: ${PGHOST:-plane-db} + PGDATABASE: ${PGDATABASE:-plane} + POSTGRES_USER: ${POSTGRES_USER:-plane} + POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-plane} + POSTGRES_DB: ${POSTGRES_DB:-plane} + POSTGRES_PORT: ${POSTGRES_PORT:-5432} + PGDATA: ${PGDATA:-/var/lib/postgresql/data} + +x-redis-env: &redis-env + REDIS_HOST: ${REDIS_HOST:-plane-redis} + REDIS_PORT: ${REDIS_PORT:-6379} + REDIS_URL: ${REDIS_URL:-redis://plane-redis:6379/} + +x-minio-env: &minio-env + MINIO_ROOT_USER: ${AWS_ACCESS_KEY_ID:-access-key} + MINIO_ROOT_PASSWORD: ${AWS_SECRET_ACCESS_KEY:-secret-key} + +x-aws-s3-env: &aws-s3-env + AWS_REGION: ${AWS_REGION:-} + AWS_ACCESS_KEY_ID: ${AWS_ACCESS_KEY_ID:-access-key} + AWS_SECRET_ACCESS_KEY: ${AWS_SECRET_ACCESS_KEY:-secret-key} + AWS_S3_ENDPOINT_URL: ${AWS_S3_ENDPOINT_URL:-http://plane-minio:9000} + AWS_S3_BUCKET_NAME: ${AWS_S3_BUCKET_NAME:-uploads} + +x-proxy-env: &proxy-env + APP_DOMAIN: ${APP_DOMAIN:-localhost} + FILE_SIZE_LIMIT: ${FILE_SIZE_LIMIT:-5242880} + CERT_EMAIL: ${CERT_EMAIL} + CERT_ACME_CA: ${CERT_ACME_CA} + CERT_ACME_DNS: ${CERT_ACME_DNS} + LISTEN_HTTP_PORT: ${LISTEN_HTTP_PORT:-80} + LISTEN_HTTPS_PORT: ${LISTEN_HTTPS_PORT:-443} + BUCKET_NAME: ${AWS_S3_BUCKET_NAME:-uploads} + SITE_ADDRESS: ${SITE_ADDRESS:-:80} + +x-mq-env: &mq-env # RabbitMQ Settings + RABBITMQ_HOST: ${RABBITMQ_HOST:-plane-mq} + RABBITMQ_PORT: ${RABBITMQ_PORT:-5672} + RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER:-plane} + RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD:-plane} + RABBITMQ_DEFAULT_VHOST: ${RABBITMQ_VHOST:-plane} + RABBITMQ_VHOST: ${RABBITMQ_VHOST:-plane} + +x-live-env: &live-env + API_BASE_URL: ${API_BASE_URL:-http://api:8000} + LIVE_SERVER_SECRET_KEY: ${LIVE_SERVER_SECRET_KEY:-2FiJk1U2aiVPEQtzLehYGlTSnTnrs7LW} + +x-app-env: &app-env + WEB_URL: ${WEB_URL:-http://localhost} + DEBUG: ${DEBUG:-0} + CORS_ALLOWED_ORIGINS: ${CORS_ALLOWED_ORIGINS} + GUNICORN_WORKERS: 1 + USE_MINIO: ${USE_MINIO:-1} + DATABASE_URL: ${DATABASE_URL:-postgresql://plane:plane@plane-db/plane} + SECRET_KEY: ${SECRET_KEY:-60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5} + AMQP_URL: ${AMQP_URL:-amqp://plane:plane@plane-mq:5672/plane} + API_KEY_RATE_LIMIT: ${API_KEY_RATE_LIMIT:-60/minute} + MINIO_ENDPOINT_SSL: ${MINIO_ENDPOINT_SSL:-0} + LIVE_SERVER_SECRET_KEY: ${LIVE_SERVER_SECRET_KEY:-2FiJk1U2aiVPEQtzLehYGlTSnTnrs7LW} + +services: + web: + image: artifacts.plane.so/makeplane/plane-frontend:${APP_RELEASE:-stable} + deploy: + replicas: ${WEB_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - worker + + space: + image: artifacts.plane.so/makeplane/plane-space:${APP_RELEASE:-stable} + deploy: + replicas: ${SPACE_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - worker + - web + + admin: + image: artifacts.plane.so/makeplane/plane-admin:${APP_RELEASE:-stable} + deploy: + replicas: ${ADMIN_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - web + + live: + image: artifacts.plane.so/makeplane/plane-live:${APP_RELEASE:-stable} + environment: + <<: [*live-env, *redis-env] + deploy: + replicas: ${LIVE_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - web + + api: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-stable} + command: ./bin/docker-entrypoint-api.sh + deploy: + replicas: ${API_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_api:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - plane-db + - plane-redis + - plane-mq + + worker: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-stable} + command: ./bin/docker-entrypoint-worker.sh + deploy: + replicas: ${WORKER_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_worker:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - api + - plane-db + - plane-redis + - plane-mq + + beat-worker: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-stable} + command: ./bin/docker-entrypoint-beat.sh + deploy: + replicas: ${BEAT_WORKER_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_beat-worker:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - api + - plane-db + - plane-redis + - plane-mq + + migrator: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-stable} + command: ./bin/docker-entrypoint-migrator.sh + deploy: + replicas: 1 + restart_policy: + condition: on-failure + volumes: + - logs_migrator:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - plane-db + - plane-redis + + # Comment this if you already have a database running + plane-db: + image: postgres:15.7-alpine + command: postgres -c 'max_connections=1000' + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *db-env + volumes: + - pgdata:/var/lib/postgresql/data + + plane-redis: + image: valkey/valkey:7.2.11-alpine + deploy: + replicas: 1 + restart_policy: + condition: any + volumes: + - redisdata:/data + + plane-mq: + image: rabbitmq:3.13.6-management-alpine + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *mq-env + volumes: + - rabbitmq_data:/var/lib/rabbitmq + + # Comment this if you using any external s3 compatible storage + plane-minio: + image: minio/minio:latest + command: server /export --console-address ":9090" + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *minio-env + volumes: + - uploads:/export + + # Comment this if you already have a reverse proxy running + proxy: + image: artifacts.plane.so/makeplane/plane-proxy:${APP_RELEASE:-stable} + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *proxy-env + ports: + - target: 80 + published: ${LISTEN_HTTP_PORT:-80} + protocol: tcp + mode: host + - target: 443 + published: ${LISTEN_HTTPS_PORT:-443} + protocol: tcp + mode: host + volumes: + - proxy_config:/config + - proxy_data:/data + depends_on: + - web + - api + - space + - admin + - live + +volumes: + pgdata: + redisdata: + uploads: + logs_api: + logs_worker: + logs_beat-worker: + logs_migrator: + rabbitmq_data: + proxy_config: + proxy_data: diff --git a/stacks/plane/plane-app/archive/1767200198.env b/stacks/plane/plane-app/archive/1767200198.env new file mode 100644 index 0000000..1fa6db6 --- /dev/null +++ b/stacks/plane/plane-app/archive/1767200198.env @@ -0,0 +1,85 @@ +APP_DOMAIN=localhost +APP_RELEASE=stable + +WEB_REPLICAS=1 +SPACE_REPLICAS=1 +ADMIN_REPLICAS=1 +API_REPLICAS=1 +WORKER_REPLICAS=1 +BEAT_WORKER_REPLICAS=1 +LIVE_REPLICAS=1 + +LISTEN_HTTP_PORT=80 +LISTEN_HTTPS_PORT=443 + +WEB_URL=http://${APP_DOMAIN} +DEBUG=0 +CORS_ALLOWED_ORIGINS=http://${APP_DOMAIN} +API_BASE_URL=http://api:8000 + +#DB SETTINGS +PGHOST=plane-db +PGDATABASE=plane +POSTGRES_USER=plane +POSTGRES_PASSWORD=plane +POSTGRES_DB=plane +POSTGRES_PORT=5432 +PGDATA=/var/lib/postgresql/data +DATABASE_URL= + +# REDIS SETTINGS +REDIS_HOST=plane-redis +REDIS_PORT=6379 +REDIS_URL= + +# RabbitMQ Settings +RABBITMQ_HOST=plane-mq +RABBITMQ_PORT=5672 +RABBITMQ_USER=plane +RABBITMQ_PASSWORD=plane +RABBITMQ_VHOST=plane +AMQP_URL= + +# If SSL Cert to be generated, set CERT_EMAIl="email " +CERT_ACME_CA=https://acme-v02.api.letsencrypt.org/directory +TRUSTED_PROXIES=0.0.0.0/0 +SITE_ADDRESS=:80 +CERT_EMAIL= + + + +# For DNS Challenge based certificate generation, set the CERT_ACME_DNS, CERT_EMAIL +# CERT_ACME_DNS="acme_dns " +CERT_ACME_DNS= + + +# Secret Key +SECRET_KEY=60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5 + +# DATA STORE SETTINGS +USE_MINIO=1 +AWS_REGION= +AWS_ACCESS_KEY_ID=access-key +AWS_SECRET_ACCESS_KEY=secret-key +AWS_S3_ENDPOINT_URL=http://plane-minio:9000 +AWS_S3_BUCKET_NAME=uploads +FILE_SIZE_LIMIT=5242880 + +# Gunicorn Workers +GUNICORN_WORKERS=1 + +# UNCOMMENT `DOCKER_PLATFORM` IF YOU ARE ON `ARM64` AND DOCKER IMAGE IS NOT AVAILABLE FOR RESPECTIVE `APP_RELEASE` +# DOCKER_PLATFORM=linux/amd64 + +# Force HTTPS for handling SSL Termination +MINIO_ENDPOINT_SSL=0 + +# API key rate limit +API_KEY_RATE_LIMIT=60/minute + +# Live server environment variables +# WARNING: You must set a secure value for LIVE_SERVER_SECRET_KEY in production environments. +LIVE_SERVER_SECRET_KEY= +DOCKERHUB_USER=artifacts.plane.so/makeplane +PULL_POLICY=if_not_present +CUSTOM_BUILD=false diff --git a/stacks/plane/plane-app/docker-compose.yaml b/stacks/plane/plane-app/docker-compose.yaml new file mode 100644 index 0000000..cfa693e --- /dev/null +++ b/stacks/plane/plane-app/docker-compose.yaml @@ -0,0 +1,255 @@ +x-db-env: &db-env + PGHOST: ${PGHOST:-plane-db} + PGDATABASE: ${PGDATABASE:-plane} + POSTGRES_USER: ${POSTGRES_USER:-plane} + POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-plane} + POSTGRES_DB: ${POSTGRES_DB:-plane} + POSTGRES_PORT: ${POSTGRES_PORT:-5432} + PGDATA: ${PGDATA:-/var/lib/postgresql/data} + +x-redis-env: &redis-env + REDIS_HOST: ${REDIS_HOST:-plane-redis} + REDIS_PORT: ${REDIS_PORT:-6379} + REDIS_URL: ${REDIS_URL:-redis://plane-redis:6379/} + +x-minio-env: &minio-env + MINIO_ROOT_USER: ${AWS_ACCESS_KEY_ID:-access-key} + MINIO_ROOT_PASSWORD: ${AWS_SECRET_ACCESS_KEY:-secret-key} + +x-aws-s3-env: &aws-s3-env + AWS_REGION: ${AWS_REGION:-} + AWS_ACCESS_KEY_ID: ${AWS_ACCESS_KEY_ID:-access-key} + AWS_SECRET_ACCESS_KEY: ${AWS_SECRET_ACCESS_KEY:-secret-key} + AWS_S3_ENDPOINT_URL: ${AWS_S3_ENDPOINT_URL:-http://plane-minio:9000} + AWS_S3_BUCKET_NAME: ${AWS_S3_BUCKET_NAME:-uploads} + +x-proxy-env: &proxy-env + APP_DOMAIN: ${APP_DOMAIN:-localhost} + FILE_SIZE_LIMIT: ${FILE_SIZE_LIMIT:-5242880} + CERT_EMAIL: ${CERT_EMAIL} + CERT_ACME_CA: ${CERT_ACME_CA} + CERT_ACME_DNS: ${CERT_ACME_DNS} + LISTEN_HTTP_PORT: ${LISTEN_HTTP_PORT:-80} + LISTEN_HTTPS_PORT: ${LISTEN_HTTPS_PORT:-443} + BUCKET_NAME: ${AWS_S3_BUCKET_NAME:-uploads} + SITE_ADDRESS: ${SITE_ADDRESS:-:80} + +x-mq-env: &mq-env # RabbitMQ Settings + RABBITMQ_HOST: ${RABBITMQ_HOST:-plane-mq} + RABBITMQ_PORT: ${RABBITMQ_PORT:-5672} + RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER:-plane} + RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD:-plane} + RABBITMQ_DEFAULT_VHOST: ${RABBITMQ_VHOST:-plane} + RABBITMQ_VHOST: ${RABBITMQ_VHOST:-plane} + +x-live-env: &live-env + API_BASE_URL: ${API_BASE_URL:-http://api:8000} + LIVE_SERVER_SECRET_KEY: ${LIVE_SERVER_SECRET_KEY:-2FiJk1U2aiVPEQtzLehYGlTSnTnrs7LW} + +x-app-env: &app-env + WEB_URL: ${WEB_URL:-http://localhost} + DEBUG: ${DEBUG:-0} + CORS_ALLOWED_ORIGINS: ${CORS_ALLOWED_ORIGINS} + GUNICORN_WORKERS: 1 + USE_MINIO: ${USE_MINIO:-1} + DATABASE_URL: ${DATABASE_URL:-postgresql://plane:plane@plane-db/plane} + SECRET_KEY: ${SECRET_KEY:-60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5} + AMQP_URL: ${AMQP_URL:-amqp://plane:plane@plane-mq:5672/plane} + API_KEY_RATE_LIMIT: ${API_KEY_RATE_LIMIT:-60/minute} + MINIO_ENDPOINT_SSL: ${MINIO_ENDPOINT_SSL:-0} + LIVE_SERVER_SECRET_KEY: ${LIVE_SERVER_SECRET_KEY:-2FiJk1U2aiVPEQtzLehYGlTSnTnrs7LW} + +services: + web: + image: artifacts.plane.so/makeplane/plane-frontend:${APP_RELEASE:-v1.2.1} + deploy: + replicas: ${WEB_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - worker + + space: + image: artifacts.plane.so/makeplane/plane-space:${APP_RELEASE:-v1.2.1} + deploy: + replicas: ${SPACE_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - worker + - web + + admin: + image: artifacts.plane.so/makeplane/plane-admin:${APP_RELEASE:-v1.2.1} + deploy: + replicas: ${ADMIN_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - web + + live: + image: artifacts.plane.so/makeplane/plane-live:${APP_RELEASE:-v1.2.1} + environment: + <<: [*live-env, *redis-env] + deploy: + replicas: ${LIVE_REPLICAS:-1} + restart_policy: + condition: any + depends_on: + - api + - web + + api: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-v1.2.1} + command: ./bin/docker-entrypoint-api.sh + deploy: + replicas: ${API_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_api:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - plane-db + - plane-redis + - plane-mq + + worker: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-v1.2.1} + command: ./bin/docker-entrypoint-worker.sh + deploy: + replicas: ${WORKER_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_worker:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - api + - plane-db + - plane-redis + - plane-mq + + beat-worker: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-v1.2.1} + command: ./bin/docker-entrypoint-beat.sh + deploy: + replicas: ${BEAT_WORKER_REPLICAS:-1} + restart_policy: + condition: any + volumes: + - logs_beat-worker:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - api + - plane-db + - plane-redis + - plane-mq + + migrator: + image: artifacts.plane.so/makeplane/plane-backend:${APP_RELEASE:-v1.2.1} + command: ./bin/docker-entrypoint-migrator.sh + deploy: + replicas: 1 + restart_policy: + condition: on-failure + volumes: + - logs_migrator:/code/plane/logs + environment: + <<: [*app-env, *db-env, *redis-env, *minio-env, *aws-s3-env, *proxy-env] + depends_on: + - plane-db + - plane-redis + + # Comment this if you already have a database running + plane-db: + image: postgres:15.7-alpine + command: postgres -c 'max_connections=1000' + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *db-env + volumes: + - pgdata:/var/lib/postgresql/data + + plane-redis: + image: valkey/valkey:7.2.11-alpine + deploy: + replicas: 1 + restart_policy: + condition: any + volumes: + - redisdata:/data + + plane-mq: + image: rabbitmq:3.13.6-management-alpine + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *mq-env + volumes: + - rabbitmq_data:/var/lib/rabbitmq + + # Comment this if you using any external s3 compatible storage + plane-minio: + image: minio/minio:latest + command: server /export --console-address ":9090" + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *minio-env + volumes: + - uploads:/export + + # Comment this if you already have a reverse proxy running + proxy: + image: artifacts.plane.so/makeplane/plane-proxy:${APP_RELEASE:-v1.2.1} + deploy: + replicas: 1 + restart_policy: + condition: any + environment: + <<: *proxy-env + ports: + - target: 80 + published: ${LISTEN_HTTP_PORT:-80} + protocol: tcp + mode: host + - target: 443 + published: ${LISTEN_HTTPS_PORT:-443} + protocol: tcp + mode: host + volumes: + - proxy_config:/config + - proxy_data:/data + depends_on: + - web + - api + - space + - admin + - live + +volumes: + pgdata: + redisdata: + uploads: + logs_api: + logs_worker: + logs_beat-worker: + logs_migrator: + rabbitmq_data: + proxy_config: + proxy_data: diff --git a/stacks/plane/plane-app/plane.env b/stacks/plane/plane-app/plane.env new file mode 100644 index 0000000..d1295ad --- /dev/null +++ b/stacks/plane/plane-app/plane.env @@ -0,0 +1,85 @@ +APP_DOMAIN=plane.rishighan.com +APP_RELEASE=v1.2.1 + +WEB_REPLICAS=1 +SPACE_REPLICAS=1 +ADMIN_REPLICAS=1 +API_REPLICAS=1 +WORKER_REPLICAS=1 +BEAT_WORKER_REPLICAS=1 +LIVE_REPLICAS=1 + +LISTEN_HTTP_PORT=8082 +LISTEN_HTTPS_PORT=8445 + +WEB_URL=https://${APP_DOMAIN} +DEBUG=0 +CORS_ALLOWED_ORIGINS=https://${APP_DOMAIN} +API_BASE_URL=http://api:8000 + +#DB SETTINGS +PGHOST=plane-db +PGDATABASE=plane +POSTGRES_USER=plane +POSTGRES_PASSWORD=plane +POSTGRES_DB=plane +POSTGRES_PORT=5432 +PGDATA=/var/lib/postgresql/data +DATABASE_URL= + +# REDIS SETTINGS +REDIS_HOST=plane-redis +REDIS_PORT=6379 +REDIS_URL= + +# RabbitMQ Settings +RABBITMQ_HOST=plane-mq +RABBITMQ_PORT=5672 +RABBITMQ_USER=plane +RABBITMQ_PASSWORD=plane +RABBITMQ_VHOST=plane +AMQP_URL= + +# If SSL Cert to be generated, set CERT_EMAIl="email " +CERT_ACME_CA=https://acme-v02.api.letsencrypt.org/directory +TRUSTED_PROXIES=0.0.0.0/0 +SITE_ADDRESS=:80 +CERT_EMAIL=email rishi@rishighan.com + + + +# For DNS Challenge based certificate generation, set the CERT_ACME_DNS, CERT_EMAIL +# CERT_ACME_DNS="acme_dns " +CERT_ACME_DNS= + + +# Secret Key +SECRET_KEY=60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5 + +# DATA STORE SETTINGS +USE_MINIO=1 +AWS_REGION= +AWS_ACCESS_KEY_ID=access-key +AWS_SECRET_ACCESS_KEY=secret-key +AWS_S3_ENDPOINT_URL=http://plane-minio:9000 +AWS_S3_BUCKET_NAME=uploads +FILE_SIZE_LIMIT=5242880 + +# Gunicorn Workers +GUNICORN_WORKERS=1 + +# UNCOMMENT `DOCKER_PLATFORM` IF YOU ARE ON `ARM64` AND DOCKER IMAGE IS NOT AVAILABLE FOR RESPECTIVE `APP_RELEASE` +# DOCKER_PLATFORM=linux/amd64 + +# Force HTTPS for handling SSL Termination +MINIO_ENDPOINT_SSL=0 + +# API key rate limit +API_KEY_RATE_LIMIT=60/minute + +# Live server environment variables +# WARNING: You must set a secure value for LIVE_SERVER_SECRET_KEY in production environments. +LIVE_SERVER_SECRET_KEY= +DOCKERHUB_USER=artifacts.plane.so/makeplane +PULL_POLICY=if_not_present +CUSTOM_BUILD=false diff --git a/stacks/plane/plane-app/plane.env.bak b/stacks/plane/plane-app/plane.env.bak new file mode 100644 index 0000000..1fa6db6 --- /dev/null +++ b/stacks/plane/plane-app/plane.env.bak @@ -0,0 +1,85 @@ +APP_DOMAIN=localhost +APP_RELEASE=stable + +WEB_REPLICAS=1 +SPACE_REPLICAS=1 +ADMIN_REPLICAS=1 +API_REPLICAS=1 +WORKER_REPLICAS=1 +BEAT_WORKER_REPLICAS=1 +LIVE_REPLICAS=1 + +LISTEN_HTTP_PORT=80 +LISTEN_HTTPS_PORT=443 + +WEB_URL=http://${APP_DOMAIN} +DEBUG=0 +CORS_ALLOWED_ORIGINS=http://${APP_DOMAIN} +API_BASE_URL=http://api:8000 + +#DB SETTINGS +PGHOST=plane-db +PGDATABASE=plane +POSTGRES_USER=plane +POSTGRES_PASSWORD=plane +POSTGRES_DB=plane +POSTGRES_PORT=5432 +PGDATA=/var/lib/postgresql/data +DATABASE_URL= + +# REDIS SETTINGS +REDIS_HOST=plane-redis +REDIS_PORT=6379 +REDIS_URL= + +# RabbitMQ Settings +RABBITMQ_HOST=plane-mq +RABBITMQ_PORT=5672 +RABBITMQ_USER=plane +RABBITMQ_PASSWORD=plane +RABBITMQ_VHOST=plane +AMQP_URL= + +# If SSL Cert to be generated, set CERT_EMAIl="email " +CERT_ACME_CA=https://acme-v02.api.letsencrypt.org/directory +TRUSTED_PROXIES=0.0.0.0/0 +SITE_ADDRESS=:80 +CERT_EMAIL= + + + +# For DNS Challenge based certificate generation, set the CERT_ACME_DNS, CERT_EMAIL +# CERT_ACME_DNS="acme_dns " +CERT_ACME_DNS= + + +# Secret Key +SECRET_KEY=60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5 + +# DATA STORE SETTINGS +USE_MINIO=1 +AWS_REGION= +AWS_ACCESS_KEY_ID=access-key +AWS_SECRET_ACCESS_KEY=secret-key +AWS_S3_ENDPOINT_URL=http://plane-minio:9000 +AWS_S3_BUCKET_NAME=uploads +FILE_SIZE_LIMIT=5242880 + +# Gunicorn Workers +GUNICORN_WORKERS=1 + +# UNCOMMENT `DOCKER_PLATFORM` IF YOU ARE ON `ARM64` AND DOCKER IMAGE IS NOT AVAILABLE FOR RESPECTIVE `APP_RELEASE` +# DOCKER_PLATFORM=linux/amd64 + +# Force HTTPS for handling SSL Termination +MINIO_ENDPOINT_SSL=0 + +# API key rate limit +API_KEY_RATE_LIMIT=60/minute + +# Live server environment variables +# WARNING: You must set a secure value for LIVE_SERVER_SECRET_KEY in production environments. +LIVE_SERVER_SECRET_KEY= +DOCKERHUB_USER=artifacts.plane.so/makeplane +PULL_POLICY=if_not_present +CUSTOM_BUILD=false