mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
870c4403e4
* dev: initiate external apis * dev: external api * dev: external public api implementation * dev: add prefix to all api tokens * dev: flag to enable disable api token api access * dev: webhook model create and apis * dev: webhook settings * fix: webhook logs * chore: removed drf spectacular * dev: remove retry_count and fix api logging for get requests * dev: refactor webhook logic * fix: celery retry mechanism * chore: event and action change * chore: migrations changes * dev: proxy setup for apis * chore: changed retry time and cleanup * chore: added issue comment and inbox issue api endpoints * fix: migration files * fix: added env variables * fix: removed issue attachment from proxy * fix: added new migration file * fix: restricted wehbook access * chore: changed urls * chore: fixed porject serializer * fix: set expire for api token * fix: retrive endpoint for api token * feat: Api Token screens & api integration * dev: webhook endpoint changes * dev: add fields for webhook updates * feat: Download Api secret key * chore: removed BASE API URL * feat: revoke token access * dev: migration fixes * feat: workspace webhooks (#2748) * feat: workspace webhook store, services integeration and rendered webhook list and create * chore: handled webhook update and rengenerate token in workspace webhooks * feat: regenerate key and delete functionality --------- Co-authored-by: Ramesh Kumar <rameshkumar@rameshs-MacBook-Pro.local> Co-authored-by: gurusainath <gurusainath007@gmail.com> Co-authored-by: Ramesh Kumar Chandra <rameshkumar2299@gmail.com> * fix: url validation added * fix: seperated env for webhook and api * Web hooks refactoring * add show option for generated hook key * Api token restructure * webhook minor fixes * fix build errors * chore: improvements in file structring * dev: rate limiting the open apis --------- Co-authored-by: pablohashescobar <nikhilschacko@gmail.com> Co-authored-by: LAKHAN BAHETI <lakhanbaheti9@gmail.com> Co-authored-by: rahulramesha <71900764+rahulramesha@users.noreply.github.com> Co-authored-by: Ramesh Kumar <rameshkumar@rameshs-MacBook-Pro.local> Co-authored-by: gurusainath <gurusainath007@gmail.com> Co-authored-by: Ramesh Kumar Chandra <rameshkumar2299@gmail.com> Co-authored-by: Nikhil <118773738+pablohashescobar@users.noreply.github.com> Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> Co-authored-by: rahulramesha <rahulramesham@gmail.com>
170 lines
4.9 KiB
YAML
170 lines
4.9 KiB
YAML
version: "3.8"
|
|
|
|
x-app-env : &app-env
|
|
environment:
|
|
- NGINX_PORT=${NGINX_PORT:-84}
|
|
- DEBUG=${DEBUG:-0}
|
|
- DJANGO_SETTINGS_MODULE=${DJANGO_SETTINGS_MODULE:-plane.settings.selfhosted}
|
|
- NEXT_PUBLIC_ENABLE_OAUTH=${NEXT_PUBLIC_ENABLE_OAUTH:-0}
|
|
- NEXT_PUBLIC_DEPLOY_URL=${NEXT_PUBLIC_DEPLOY_URL:-http://localhost/spaces}
|
|
- SENTRY_DSN=${SENTRY_DSN:-""}
|
|
- GITHUB_CLIENT_SECRET=${GITHUB_CLIENT_SECRET:-""}
|
|
- DOCKERIZED=${DOCKERIZED:-1}
|
|
# BASE WEBHOOK
|
|
- ENABLE_WEBHOOK=${ENABLE_WEBHOOK:-1}
|
|
# BASE API
|
|
- ENABLE_API=${ENABLE_API:-1}
|
|
- CORS_ALLOWED_ORIGINS=${CORS_ALLOWED_ORIGINS:-http://localhost}
|
|
# Gunicorn Workers
|
|
- GUNICORN_WORKERS=${GUNICORN_WORKERS:-2}
|
|
#DB SETTINGS
|
|
- PGHOST=${PGHOST:-plane-db}
|
|
- PGDATABASE=${PGDATABASE:-plane}
|
|
- POSTGRES_USER=${POSTGRES_USER:-plane}
|
|
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-plane}
|
|
- POSTGRES_DB=${POSTGRES_DB:-plane}
|
|
- PGDATA=${PGDATA:-/var/lib/postgresql/data}
|
|
- DATABASE_URL=${DATABASE_URL:-postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${PGHOST}/${PGDATABASE}}
|
|
# REDIS SETTINGS
|
|
- REDIS_HOST=${REDIS_HOST:-plane-redis}
|
|
- REDIS_PORT=${REDIS_PORT:-6379}
|
|
- REDIS_URL=${REDIS_URL:-redis://${REDIS_HOST}:6379/}
|
|
# EMAIL SETTINGS
|
|
- EMAIL_HOST=${EMAIL_HOST:-""}
|
|
- EMAIL_HOST_USER=${EMAIL_HOST_USER:-""}
|
|
- EMAIL_HOST_PASSWORD=${EMAIL_HOST_PASSWORD:-""}
|
|
- EMAIL_PORT=${EMAIL_PORT:-587}
|
|
- EMAIL_FROM=${EMAIL_FROM:-"Team Plane <team@mailer.plane.so>"}
|
|
- EMAIL_USE_TLS=${EMAIL_USE_TLS:-1}
|
|
- EMAIL_USE_SSL=${EMAIL_USE_SSL:-0}
|
|
- DEFAULT_EMAIL=${DEFAULT_EMAIL:-captain@plane.so}
|
|
- DEFAULT_PASSWORD=${DEFAULT_PASSWORD:-password123}
|
|
# OPENAI SETTINGS
|
|
- OPENAI_API_BASE=${OPENAI_API_BASE:-https://api.openai.com/v1}
|
|
- OPENAI_API_KEY=${OPENAI_API_KEY:-"sk-"}
|
|
- GPT_ENGINE=${GPT_ENGINE:-"gpt-3.5-turbo"}
|
|
# LOGIN/SIGNUP SETTINGS
|
|
- ENABLE_SIGNUP=${ENABLE_SIGNUP:-1}
|
|
- ENABLE_EMAIL_PASSWORD=${ENABLE_EMAIL_PASSWORD:-1}
|
|
- ENABLE_MAGIC_LINK_LOGIN=${ENABLE_MAGIC_LINK_LOGIN:-0}
|
|
- SECRET_KEY=${SECRET_KEY:-60gp0byfz2dvffa45cxl20p1scy9xbpf6d8c5y0geejgkyp1b5}
|
|
# DATA STORE SETTINGS
|
|
- USE_MINIO=${USE_MINIO:-1}
|
|
- 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}
|
|
- MINIO_ROOT_USER=${MINIO_ROOT_USER:-"access-key"}
|
|
- MINIO_ROOT_PASSWORD=${MINIO_ROOT_PASSWORD:-"secret-key"}
|
|
- BUCKET_NAME=${BUCKET_NAME:-uploads}
|
|
- FILE_SIZE_LIMIT=${FILE_SIZE_LIMIT:-5242880}
|
|
|
|
|
|
|
|
services:
|
|
web:
|
|
<<: *app-env
|
|
platform: linux/amd64
|
|
image: makeplane/plane-frontend:${APP_RELEASE:-latest}
|
|
restart: unless-stopped
|
|
command: /usr/local/bin/start.sh web/server.js web
|
|
deploy:
|
|
replicas: ${WEB_REPLICAS:-1}
|
|
depends_on:
|
|
- api
|
|
- worker
|
|
|
|
space:
|
|
<<: *app-env
|
|
platform: linux/amd64
|
|
image: makeplane/plane-space:${APP_RELEASE:-latest}
|
|
restart: unless-stopped
|
|
command: /usr/local/bin/start.sh space/server.js space
|
|
deploy:
|
|
replicas: ${SPACE_REPLICAS:-1}
|
|
depends_on:
|
|
- api
|
|
- worker
|
|
- web
|
|
|
|
api:
|
|
<<: *app-env
|
|
platform: linux/amd64
|
|
image: makeplane/plane-backend:${APP_RELEASE:-latest}
|
|
restart: unless-stopped
|
|
command: ./bin/takeoff
|
|
deploy:
|
|
replicas: ${API_REPLICAS:-1}
|
|
depends_on:
|
|
- plane-db
|
|
- plane-redis
|
|
|
|
worker:
|
|
<<: *app-env
|
|
container_name: bgworker
|
|
platform: linux/amd64
|
|
image: makeplane/plane-backend:${APP_RELEASE:-latest}
|
|
restart: unless-stopped
|
|
command: ./bin/worker
|
|
depends_on:
|
|
- api
|
|
- plane-db
|
|
- plane-redis
|
|
|
|
beat-worker:
|
|
<<: *app-env
|
|
container_name: beatworker
|
|
platform: linux/amd64
|
|
image: makeplane/plane-backend:${APP_RELEASE:-latest}
|
|
restart: unless-stopped
|
|
command: ./bin/beat
|
|
depends_on:
|
|
- api
|
|
- plane-db
|
|
- plane-redis
|
|
|
|
plane-db:
|
|
<<: *app-env
|
|
container_name: plane-db
|
|
image: postgres:15.2-alpine
|
|
restart: unless-stopped
|
|
command: postgres -c 'max_connections=1000'
|
|
volumes:
|
|
- pgdata:/var/lib/postgresql/data
|
|
|
|
plane-redis:
|
|
<<: *app-env
|
|
container_name: plane-redis
|
|
image: redis:6.2.7-alpine
|
|
restart: unless-stopped
|
|
volumes:
|
|
- redisdata:/data
|
|
|
|
plane-minio:
|
|
<<: *app-env
|
|
container_name: plane-minio
|
|
image: minio/minio
|
|
restart: unless-stopped
|
|
command: server /export --console-address ":9090"
|
|
volumes:
|
|
- uploads:/export
|
|
|
|
# Comment this if you already have a reverse proxy running
|
|
proxy:
|
|
<<: *app-env
|
|
container_name: proxy
|
|
platform: linux/amd64
|
|
image: makeplane/plane-proxy:${APP_RELEASE:-latest}
|
|
ports:
|
|
- ${NGINX_PORT}:80
|
|
depends_on:
|
|
- web
|
|
- api
|
|
- space
|
|
|
|
volumes:
|
|
pgdata:
|
|
redisdata:
|
|
uploads:
|