-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
95 lines (84 loc) · 2.34 KB
/
docker-compose.yml
File metadata and controls
95 lines (84 loc) · 2.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
version: "3.8"
services:
beckn-deg-bot:
build:
context: .
dockerfile: Dockerfile
container_name: beckn-deg-bot
ports:
- "${PORT:-3050}:3050"
environment:
# FastAPI Configuration
- PORT=3050
# OpenAI Configuration
- OPENAI_API_KEY=${OPENAI_API_KEY}
# Beckn Configuration
- BAP_ID=${BAP_ID:-bap-ps-network-deg.becknprotocol.io}
- BAP_URI=${BAP_URI:-https://bap-ps-network-deg.becknprotocol.io}
- BASE_URL=${BASE_URL:-https://bap-ps-client-deg.becknprotocol.io}
# MongoDB Configuration
- MONGODB_URL=${MONGODB_URL:-mongodb://mongodb:27017}
- DATABASE_NAME=${DATABASE_NAME:-beckn_deg_bot}
# JWT Authentication Configuration
- SECRET_KEY=${SECRET_KEY:-your-super-secret-jwt-key-here-change-in-production}
- ACCESS_TOKEN_EXPIRE_MINUTES=${ACCESS_TOKEN_EXPIRE_MINUTES:-30}
# Development/Production Environment
- ENVIRONMENT=${ENVIRONMENT:-development}
# Python Configuration
- PYTHONPATH=/app/src
- PYTHONUNBUFFERED=1
volumes:
# Optional: Mount source code for development
# - ./src:/app/src:ro
# Mount logs directory
- ./logs:/app/logs
restart: unless-stopped
depends_on:
mongodb:
condition: service_healthy
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:3050/ping"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
networks:
- beckn-network
# MongoDB service
mongodb:
image: mongo:7.0
container_name: beckn-mongodb
ports:
- "27017:27017"
environment:
- MONGO_INITDB_DATABASE=${DATABASE_NAME:-beckn_deg_bot}
volumes:
- mongodb_data:/data/db
- ./mongo-init:/docker-entrypoint-initdb.d
restart: unless-stopped
healthcheck:
test: ["CMD", "mongosh", "--eval", "db.adminCommand('ping')"]
interval: 10s
timeout: 5s
retries: 5
start_period: 30s
networks:
- beckn-network
# Optional: Add Redis for session storage (if needed for production)
# redis:
# image: redis:7-alpine
# container_name: beckn-redis
# ports:
# - "6379:6379"
# volumes:
# - redis_data:/data
# restart: unless-stopped
# networks:
# - beckn-network
networks:
beckn-network:
driver: bridge
# volumes:
# redis_data:
volumes:
mongodb_data: