-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
120 lines (114 loc) · 3.43 KB
/
docker-compose.yml
File metadata and controls
120 lines (114 loc) · 3.43 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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
version: '3.8'
services:
# Nginx Reverse Proxy
nginx:
image: nginx:1.27-alpine
container_name: chainscout-nginx
ports:
- "80:80"
- "443:443"
volumes:
- ./nginx/chainscout.conf:/etc/nginx/conf.d/default.conf:ro
- ./nginx/proxy_params.conf:/etc/nginx/proxy_params.conf:ro
- ./nginx/certs:/etc/nginx/certs:ro
- /etc/letsencrypt/live/chainscoutsecurity.com/fullchain.pem:/etc/letsencrypt/live/chainscoutsecurity.com/fullchain.pem:ro
- /etc/letsencrypt/live/chainscoutsecurity.com/privkey.pem:/etc/letsencrypt/live/chainscoutsecurity.com/privkey.pem:ro
depends_on:
- frontend
- api
networks:
- chainscout-network
restart: unless-stopped
healthcheck:
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost/health"]
interval: 10s
timeout: 5s
retries: 3
# React Frontend
frontend:
build:
context: .
dockerfile: Dockerfile.frontend
args:
- VITE_SUPABASE_URL=${VITE_SUPABASE_URL}
- VITE_SUPABASE_PUBLISHABLE_KEY=${VITE_SUPABASE_PUBLISHABLE_KEY}
- VITE_API_URL=${VITE_API_URL:-}
container_name: chainscout-frontend
expose:
- "5173"
networks:
- chainscout-network
restart: unless-stopped
environment:
- NODE_ENV=production
bot:
build: /opt/chainscout-bot
container_name: chainscout-bot
environment:
- BOT_TOKEN=${BOT_TOKEN}
restart: unless-stopped
networks:
- chainscout-network
# Node.js Backend API
api:
build:
context: ./server
dockerfile: Dockerfile
container_name: chainscout-api
dns:
- 8.8.8.8
- 1.1.1.1
expose:
- "4000"
depends_on:
- postgres
networks:
- chainscout-network
restart: unless-stopped
environment:
- NODE_ENV=${NODE_ENV:-production}
- PORT=4000
- SUPABASE_URL=${SUPABASE_URL}
- SUPABASE_SERVICE_KEY=${SUPABASE_SERVICE_KEY}
- VITE_SUPABASE_PUBLISHABLE_KEY=${VITE_SUPABASE_PUBLISHABLE_KEY}
- DATABASE_URL=${DATABASE_URL:-postgresql://chainscout:chainscout@postgres:5432/chainscout}
- CORS_ORIGIN=http://localhost,http://localhost:80,http://localhost:443,http://31.128.47.250,http://chainscoutsecurity.com,https://chainscoutsecurity.com,https://localhost,https://app.chainscout.com,https://api.chainscout.com
- API_REQUIRE_AUTH=${API_REQUIRE_AUTH:-true}
- RATE_LIMIT_WINDOW_MS=900000
- RATE_LIMIT_MAX=30
- MAX_UPLOAD_BYTES=26214400
- ETHERSCAN_API_KEY=${ETHERSCAN_API_KEY}
- INFURA_API_KEY=${INFURA_API_KEY}
- OPENROUTER_API_KEY=${OPENROUTER_API_KEY}
- OPENROUTER_MODEL=${OPENROUTER_MODEL:-gpt-4o-mini}
healthcheck:
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost:4000/health"]
interval: 10s
timeout: 5s
retries: 3
# PostgreSQL Database
postgres:
image: postgres:16-alpine
container_name: chainscout-postgres
expose:
- "5432"
networks:
- chainscout-network
restart: unless-stopped
environment:
- POSTGRES_USER=chainscout
- POSTGRES_PASSWORD=chainscout
- POSTGRES_DB=chainscout
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U chainscout"]
interval: 10s
timeout: 5s
retries: 3
volumes:
postgres_data:
driver: local
networks:
chainscout-network:
driver: bridge