forked from wl-buildingtools/nightfall
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose.yml
288 lines (272 loc) · 7.8 KB
/
docker-compose.yml
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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
version: '3.5'
services:
accounts:
build:
context: ./accounts
dockerfile: Dockerfile
restart: on-failure
depends_on:
- ganache
volumes:
- ./accounts/src:/app/src
- ./accounts/config:/app/config
- ./accounts/.babelrc:/app/.babelrc
environment:
BLOCKCHAIN_HOST: http://ganache
BLOCKCHAIN_PORT: 8545
networks:
- nightfall_network
api-gateway:
build:
context: ./api-gateway
dockerfile: Dockerfile
restart: on-failure
depends_on:
- accounts
- offchain
- zkp
- database
volumes:
- ./api-gateway/src:/app/src
- ./api-gateway/config:/app/config
- ./api-gateway/.babelrc:/app/.babelrc
ports:
- '8001:80'
environment:
ACCOUNTS_HOST: http://accounts
ACCOUNTS_PORT: 80
DATABASE_HOST: http://database
DATABASE_PORT: 80
OFFCHAIN_HOST: http://offchain
OFFCHAIN_PORT: 80
ZKP_HOST: http://zkp
ZKP_PORT: 80
RABBITMQ_HOST: amqp://rabbitmq
RABBITMQ_PORT: 5672
networks:
- nightfall_network
offchain:
build:
context: ./offchain
dockerfile: Dockerfile
restart: on-failure
depends_on:
- ganache
volumes:
- ./offchain/src:/app/src
- ./offchain/build:/app/build
- ./offchain/.babelrc:/app/.babelrc
- ./offchain/__tests__:/app/__tests__
- ./offchain/config:/app/config
environment:
AUTHENTICATION_API_HOST: http://api-gateway
AUTHENTICATION_API_PORT: 80
BLOCKCHAIN_HOST: ws://ganache
BLOCKCHAIN_PORT: 8545
networks:
- nightfall_network
zkp:
build:
context: ./zkp
dockerfile: Dockerfile
restart: on-failure
depends_on:
- ganache
- merkle-tree
volumes:
# - ./zkp/.yalc:/app/.yalc
- ./zkp/src:/app/src
- ./zkp/build:/app/build
- ./zkp/code:/app/code
- ./zkp/.babelrc:/app/.babelrc
- ./zkp/__tests__:/app/__tests__
- ./zkp/config:/app/config
- /var/run/docker.sock:/var/run/docker.sock
- /dev:/dev # only for github actions
environment:
HASH_TYPE: 'sha' #override this with docker-compose.override.mimc
BLOCKCHAIN_HOST: ws://ganache
BLOCKCHAIN_PORT: 8545
MERKLE_TREE_HOST: http://merkle-tree
MERKLE_TREE_PORT: 80
ZKP_CODE_VOLUME: nightfall_zkp-code-volume
NIGHTLITE_LOG_LEVEL: debug
networks:
- nightfall_network
ui:
build:
context: ./ui
dockerfile: Dockerfile
restart: on-failure
depends_on:
- rabbitmq
volumes:
- ./ui/src:/app/src
- ./ui/angular.json:/app/angular.json
- ./ui/tsconfig.json:/app/tsconfig.json
- ./ui/tsconfig.base.json:/app/tsconfig.base.json
ports:
- '8000:80'
environment:
API_GATEWAY_HOST: http://localhost
API_GATEWAY_PORT: 8001
RABBITMQ_HOST: ws://localhost
RABBITMQ_PORT: 15674
networks:
- nightfall_network
ganache:
image: trufflesuite/ganache-cli:latest
command: ganache-cli --accounts=10 --defaultBalanceEther=1000
ports:
- '8545:8545'
networks:
- nightfall_network
database:
build:
context: ./database
dockerfile: Dockerfile
restart: on-failure
depends_on:
- mongo-nightfall
volumes:
- ./database/src:/app/src
- ./database/.babelrc:/app/.babelrc
- ./database/config:/app/config
- ./database/setup-mongo-acl-for-new-users.js:/app/setup-mongo-acl-for-new-users.js
command: npm start
environment:
MONGO_HOST: mongo-nightfall
MONGO_PORT: 27017
MONGO_NAME: nightfall
MONGO_USERNAME: admin
MONGO_PASSWORD: admin
networks:
- nightfall_network
mongo-nightfall:
image: mongo
environment:
- MONGO_INITDB_ROOT_USERNAME=admin
- MONGO_INITDB_ROOT_PASSWORD=admin
- MONGO_INITDB_DATABASE=nightfall
volumes:
- ./database/docker-entrypoint-initdb.d/01_setup_admin_user.js:/docker-entrypoint-initdb.d/01_setup_admin_user.js
- ./database/is-mongo-ready.js:/is-mongo-ready.js
- mongo-nightfall-volume:/data/db
networks:
- nightfall_network
truffle-offchain:
image: ajmay/truffle:5.0.9
environment:
SOLC_VERSION: 0.5.8
ETH_HOST: ganache
ETH_GAS: 6000000
ETH_GAS_PRICE: 20000000000
volumes:
- ./offchain/contracts:/truffle/contracts:delegated
- ./offchain/migrations/:/truffle/migrations:delegated
- ./offchain/build/contracts/:/truffle/build/contracts:cached
- ./offchain/test/:/truffle/test:delegated
depends_on:
- ganache
logging:
options:
max-size: 10m
networks:
- nightfall_network
truffle-zkp:
image: ajmay/truffle:5.0.9
environment:
SOLC_VERSION: 0.5.8
ETH_HOST: ganache
ETH_GAS: 6000000
ETH_GAS_PRICE: 20000000000
volumes:
- ./zkp/contracts/:/truffle/contracts:delegated
- ./zkp/migrations/:/truffle/migrations:delegated
- ./zkp/build/contracts/:/truffle/build/contracts:cached
depends_on:
- ganache
logging:
options:
max-size: 10m
networks:
- nightfall_network
truffle-nightlite:
image: ajmay/truffle:5.0.9
environment:
SOLC_VERSION: 0.5.8
ETH_HOST: ganache
ETH_GAS: 6000000
ETH_GAS_PRICE: 20000000000
volumes:
- ./zkp/node_modules/@eyblockchain/nightlite/contracts/:/truffle/contracts:delegated
- ./zkp/node_modules/@eyblockchain/nightlite/contracts/sha/MerkleTree.sol:/truffle/contracts/MerkleTree.sol:delegated
- ./zkp/node_modules/@eyblockchain/nightlite/contracts/mimc/MiMC.sol:/truffle/contracts/MiMC.sol:delegated
- ./zkp/node_modules/@eyblockchain/nightlite/migrations/:/truffle/migrations:delegated
- ./zkp/build/contracts/:/truffle/build/contracts:cached
depends_on:
- ganache
logging:
options:
max-size: 10m
networks:
- nightfall_network
merkle-tree:
image: eyblockchain/timber:v2.1.0
restart: on-failure
depends_on:
- mongo-merkle-tree
- ganache
volumes:
- ./config/merkle-tree:/app/config # mount point might be different if configuring from another application
- ./zkp/contracts/:/app/contracts:consistent # required if deploying contracts from within this service (if CONTRACT_LOCATION = 'default')
- ./zkp/build/:/app/build:consistent # required if CONTRACT_LOCATION = 'default'
- app/node_modules
ports:
- '9000:80'
environment:
BLOCKCHAIN_HOST: ws://ganache
BLOCKCHAIN_PORT: 8545
CONTRACT_LOCATION: 'default' # Where to find the contractInstances?
# Specify one of:
# - 'remote' (to GET them from a remote microservice); or
# - 'mongodb' (to get them from mongodb); or
# - 'default' (to get them from the app/build/ folder)
MONGO_HOST: mongodb://mongo-merkle-tree
MONGO_PORT: 27017
MONGO_NAME: merkle_tree
MONGO_USERNAME: admin
MONGO_PASSWORD: admin
networks:
- nightfall_network
# The database storing the merkle tree
mongo-merkle-tree:
image: mongo
environment:
- MONGO_INITDB_ROOT_USERNAME=admin
- MONGO_INITDB_ROOT_PASSWORD=admin
- MONGO_INITDB_DATABASE=merkle_tree
volumes:
- ./database/docker-entrypoint-initdb.d/02_setup_admin_user.js:/docker-entrypoint-initdb.d/02_setup_admin_user.js
- mongo-merkle-tree-volume:/data/db
networks:
- nightfall_network
rabbitmq:
image: rabbitmq
volumes:
- ./rabbitmq-enabled-plugins:/etc/rabbitmq/enabled_plugins
ports:
- '15674:15674'
networks:
- nightfall_network
volumes:
mongo-nightfall-volume: {}
mongo-merkle-tree-volume: {}
zkp-code-volume:
driver_opts:
type: none
device: $PWD/zkp/code/
o: bind
networks:
nightfall_network:
name: nightfall_network