475 lines
15 KiB
YAML
475 lines
15 KiB
YAML
version: "3"
|
|
|
|
volumes:
|
|
ganache-db: {}
|
|
postgres-db: {}
|
|
bee-data: {}
|
|
signer-data: {}
|
|
bloxberg-data: {}
|
|
contract-config:
|
|
driver_opts:
|
|
type: local
|
|
o: bind
|
|
device: ./service-configs
|
|
|
|
networks:
|
|
default:
|
|
name: cic-network
|
|
|
|
services:
|
|
# eth:
|
|
# image: trufflesuite/ganache-cli
|
|
# ports:
|
|
# - ${HTTP_PORT_ETH:-8545}
|
|
# - ${WS_PORT_ETH:-8546}
|
|
# # Note! -e switch doesnt work, whatever you put there, it will be 100
|
|
# command: "-i 8996 -e 1000 -l 90000000 \
|
|
# -m '${DEV_MNEMONIC:-\"history stumble mystery avoid embark arrive mom foil pledge keep grain dice\"}' \
|
|
# -v --db /tmp/cic/ganache/ganache.db \
|
|
# --noVMErrorsOnRPCResponse --allowUnlimitedContractSize"
|
|
# volumes:
|
|
# - ganache-db:/tmp/cic/ganache
|
|
|
|
eth:
|
|
build:
|
|
context: apps/bloxbergValidatorSetup
|
|
restart: unless-stopped
|
|
ports:
|
|
- ${HTTP_PORT_ETH:-8545}
|
|
- 8546
|
|
- 30303
|
|
volumes:
|
|
#- ./keys:/root/keys # stores the signing key locally
|
|
- bloxberg-data:/root/.local/share/io.parity.ethereum/
|
|
|
|
# See contents of /initdb/create_db.sql for app user, password and databases
|
|
postgres:
|
|
image: postgres:12.5-alpine
|
|
environment:
|
|
POSTGRES_HOST_AUTH_METHOD: trust # for postgres user access w/o password. Obvioulsy not safe but allows easy elevated debugging.
|
|
# PGDATA: /tmp/cic/postgres
|
|
ports:
|
|
- 5432
|
|
volumes:
|
|
- ./scripts/initdb/create_db.sql:/docker-entrypoint-initdb.d/1-create_all_db.sql
|
|
- ./apps/cic-meta/scripts/initdb/postgresql.sh:/docker-entrypoint-initdb.d/2-init-cic-meta.sh
|
|
- postgres-db:/var/lib/postgresql/data
|
|
|
|
redis:
|
|
image: redis:6.0.9-alpine
|
|
ports:
|
|
- ${HTTP_PORT_REDIS:-6379}
|
|
command: "--loglevel verbose"
|
|
|
|
bee:
|
|
image: ethersphere/bee:0.4.1
|
|
container_name: bee
|
|
environment:
|
|
BEE_NETWORK_ID: ${BEE_NETWORK_ID:-313}
|
|
BEE_PASSWORD: ${BEE_PASSWORD:-password}
|
|
ports:
|
|
- 1633
|
|
- 1635
|
|
command: "start --swap-enable=false --standalone"
|
|
volumes:
|
|
- bee-data:/tmp/cic/bee
|
|
|
|
contract-migration:
|
|
build:
|
|
context: apps/
|
|
dockerfile: contract-migration/docker/Dockerfile
|
|
environment:
|
|
# ETH_PROVIDER should be broken out into host/port but cic-eth expects this
|
|
ETH_PROVIDER: http://eth:8545
|
|
# And these two are for wait-for-it (could parse this)
|
|
ETH_PROVIDER_HOST: eth
|
|
ETH_PROVIDER_PORT: 8545
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
command: ["./reset.sh"]
|
|
depends_on:
|
|
- eth
|
|
volumes:
|
|
- contract-config:/tmp/cic/config
|
|
|
|
# cic-cache-tracker:
|
|
# # image: registry.gitlab.com/grassrootseconomics/cic-cache:master-latest
|
|
# build: apps/cic-cache
|
|
# environment:
|
|
# CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS # supplied at contract-config after contract provisioning
|
|
# ETH_PROVIDER: ${ETH_PROVIDER:-http://eth:8545}
|
|
# BANCOR_DIR: ${BANCOR_DIR:-/usr/local/share/cic/bancor}
|
|
# DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
# DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala} # this is is set at initdb see: postgres/initdb/create_db.sql
|
|
# DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
# DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
# DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
# DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
# DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
# ETH_ABI_DIR: ${ETH_ABI_DIR:-/usr/local/share/cic/solidity/abi}
|
|
# deploy:
|
|
# restart_policy:
|
|
# condition: on-failure
|
|
# depends_on:
|
|
# - postgres
|
|
# - eth
|
|
# command:
|
|
# - /bin/sh
|
|
# - -c
|
|
# - |
|
|
# if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
# /usr/local/bin/cic-cache-tracker -vv
|
|
# volumes:
|
|
# - contract-config:/tmp/cic/config/:ro
|
|
# entrypoint: ["/usr/local/bin/cic-cache-tracker", "-vv"]
|
|
# command: "/usr/local/bin/cic-cache-tracker -vv"
|
|
|
|
# cic-cache-server:
|
|
# image: grassrootseconomics:cic-cache-uwsgi
|
|
# environment:
|
|
# DATABASE_USER: $DATABASE_USER
|
|
# DATABASE_HOST: $DATABASE_HOST
|
|
# DATABASE_PORT: $DATABASE_PORT
|
|
# DATABASE_PASSWORD: $DATABASE_PASSWORD
|
|
# DATABASE_NAME: $DATABASE_NAME_CIC_CACHE
|
|
# PGPASSWORD: $DATABASE_PASSWORD
|
|
# SERVER_PORT: 80
|
|
# ports:
|
|
# - ${HTTP_PORT_CIC_CACHE}:80
|
|
# depends_on:
|
|
# - postgres
|
|
# deploy:
|
|
# restart_policy:
|
|
# condition: on-failure
|
|
# command: "/root/start_uwsgi.sh"
|
|
|
|
cic-eth-tasker:
|
|
# image: grassrootseconomics:cic-eth-service
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS
|
|
ETH_GAS_PROVIDER_ADDRESS: $DEV_ETH_ACCOUNT_GAS_PROVIDER
|
|
ETH_PROVIDER: http://eth:8545
|
|
ETH_ABI_DIR: ${ETH_ABI_DIR:-/usr/local/share/cic/solidity/abi}
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
PGPASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
BANCOR_DIR: ${BANCOR_DIR:-/usr/local/share/cic/bancor}
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_RESULT_URL:-redis://redis}
|
|
SIGNER_SOCKET_PATH: ${SIGNER_SOCKET_PATH:-/tmp/cic/signer/jsonrpc.ipc}
|
|
SIGNER_SECRET: ${SIGNER_SECRET:-deadbeef}
|
|
ETH_ACCOUNT_ACCOUNTS_INDEX_WRITER: ${DEV_ETH_ACCOUNT_ACCOUNTS_INDEX_WRITER:-0xACB0BC74E1686D62dE7DC6414C999EA60C09F0eA}
|
|
TASKS_TRACE_QUEUE_STATUS: ${TASKS_TRACE_QUEUE_STATUS:-1}
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- signer-data:/tmp/cic/signer
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
./start_tasker.sh -q cic-eth -vv
|
|
# command: [/bin/sh, "./start_tasker.sh", -q, cic-eth, -vv ]
|
|
|
|
cic-eth-manager-head:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
ETH_PROVIDER: http://eth:8545
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS
|
|
#BANCOR_DIR: $BANCOR_DIR
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_RESULT_URL:-redis://redis}
|
|
TASKS_TRANSFER_CALLBACKS: $TASKS_TRANSFER_CALLBACKS
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
./start_manager.sh head -vv
|
|
# command: "/root/start_manager.sh head -vv"
|
|
|
|
cic-eth-manager-history:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
ETH_PROVIDER: http://eth:8545
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS
|
|
#BANCOR_DIR: $BANCOR_DIR
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_RESULT_URL:-redis://redis}
|
|
TASKS_TRANSFER_CALLBACKS: $TASKS_TRANSFER_CALLBACKS
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
#deploy:
|
|
#restart_policy:
|
|
# condition: on-failure
|
|
volumes:
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
./start_manager.sh history -vv
|
|
# command: "/root/start_manager.sh history -vv"
|
|
|
|
cic-eth-dispatcher:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
ETH_PROVIDER: http://eth:8545
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS
|
|
#BANCOR_DIR: $BANCOR_DIR
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_RESULT_URL:-redis://redis}
|
|
TASKS_TRANSFER_CALLBACKS: $TASKS_TRANSFER_CALLBACKS
|
|
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
./start_dispatcher.sh -q cic-eth -vv
|
|
# command: "/root/start_dispatcher.sh -q cic-eth -vv"
|
|
|
|
|
|
cic-eth-retrier:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
ETH_PROVIDER: http://eth:8545
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_CACHE:-cic_cache}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
CIC_CHAIN_SPEC: ${CIC_CHAIN_SPEC:-Bloxberg:8996}
|
|
CIC_REGISTRY_ADDRESS: $CIC_REGISTRY_ADDRESS
|
|
#BANCOR_DIR: $BANCOR_DIR
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_RESULT_URL:-redis://redis}
|
|
TASKS_TRANSFER_CALLBACKS: $TASKS_TRANSFER_CALLBACKS
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
./start_retry.sh -vv
|
|
# command: "/root/start_retry.sh -q cic-eth -vv"
|
|
|
|
|
|
cic-eth-server:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-eth/docker/Dockerfile
|
|
environment:
|
|
CIC_CHAIN_SPEC: $CIC_CHAIN_SPEC
|
|
CELERY_BROKER_URL: $CELERY_BROKER_URL
|
|
CELERY_RESULT_URL: $CELERY_RESULT_URL
|
|
SERVER_PORT: 80
|
|
depends_on:
|
|
- eth
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- contract-config:/tmp/cic/config/:ro
|
|
command:
|
|
- /bin/bash
|
|
- -c
|
|
- |
|
|
if [[ -f /tmp/cic/config/.env ]]; then source /tmp/cic/config/.env; fi
|
|
"/usr/local/bin/uwsgi" \
|
|
--wsgi-file /usr/src/cic-eth/cic_eth/runnable/server_agent.py \
|
|
--http :80 \
|
|
--pyargv -vv
|
|
# entrypoint:
|
|
# - "/usr/local/bin/uwsgi"
|
|
# - "--wsgi-file"
|
|
# - "/usr/src/cic-eth/cic_eth/runnable/server_agent.py"
|
|
# - "--http"
|
|
# - ":80"
|
|
# command: "--pyargv -vv"
|
|
|
|
|
|
|
|
cic-notify-tasker:
|
|
image: grassrootseconomics:cic-notify-service
|
|
environment:
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_PASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
DATABASE_NAME: ${DATABASE_NAME_CIC_NOTIFY:-cic_notify}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
PGPASSWORD: ${DATABASE_PASSWORD:-tralala}
|
|
CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
CELERY_RESULT_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
TASKS_AFRICASTALKING: $TASKS_AFRICASTALKING
|
|
TASKS_SMS_DB: $TASKS_SMS_DB
|
|
TASKS_LOG: $TASKS_LOG
|
|
depends_on:
|
|
- postgres
|
|
- redis
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
command: "/root/start_tasker.sh -q cic-notify"
|
|
|
|
|
|
cic-meta-server:
|
|
build:
|
|
context: apps/
|
|
dockerfile: cic-meta/docker/Dockerfile
|
|
environment:
|
|
DATABASE_NAME: ${DATABASE_NAME:-cic_meta}
|
|
DATABASE_ENGINE: ${DATABASE_ENGINE:-postgres}
|
|
DATABASE_DRIVER: ${DATABASE_DRIVER:-psycopg2}
|
|
DATABASE_USER: ${DATABASE_USER:-grassroots}
|
|
DATABASE_HOST: ${DATABASE_HOST:-postgres}
|
|
DATABASE_PORT: ${DATABASE_PORT:-5432}
|
|
DATABASE_SCHEMA_SQL_PATH: ""
|
|
PGP_EXPORTS_DIR: /tmp/src/cic-meta/tests/
|
|
PGP_PRIVATEKEY_FILE: privatekeys.asc
|
|
PGP_PASSPHRASE: merman
|
|
PGP_PUBLICKEY_TRUSTED_FILE: publickeys.asc
|
|
PGP_PUBLICKEY_ACTIVE_FILE: publickeys.asc
|
|
PGP_PUBLICKEY_ENCRYPT_FILE: publickeys.asc
|
|
SERVER_ADDRESS: 0.0.0.0
|
|
SERVER_PORT: 7777
|
|
ports:
|
|
- ${HTTP_PORT_CIC_META:-80}
|
|
depends_on:
|
|
- postgres
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
volumes:
|
|
- ${LOCAL_VOLUME_DIR:-/tmp/cic}/pgp:/tmp/cic/pgp
|
|
command: "/root/start_server.sh -vv"
|
|
|
|
# cic-ussd-server:
|
|
# # image: grassrootseconomics:cic-ussd
|
|
# build:
|
|
# context: apps/
|
|
# dockerfile: cic-ussd/docker/Dockerfile
|
|
# environment:
|
|
# DATABASE_USER: grassroots
|
|
# DATABASE_HOST: postgres
|
|
# DATABASE_PORT: 5432
|
|
# DATABASE_PASSWORD: tralala
|
|
# DATABASE_NAME: cic_ussd
|
|
# DATABASE_ENGINE: postgresql
|
|
# DATABASE_DRIVER: psycopg2
|
|
# SERVER_PORT: 80
|
|
# ports:
|
|
# - 80:8082
|
|
# depends_on:
|
|
# - postgres
|
|
# - redis
|
|
# deploy:
|
|
# restart_policy:
|
|
# condition: on-failure
|
|
# command: "/root/start_uwsgi.sh"
|
|
#
|
|
# cic-ussd-tasker:
|
|
# # image: grassrootseconomics:cic-ussd
|
|
# build:
|
|
# context: apps
|
|
# dockerfile: cic-ussd/docker/Dockerfile
|
|
# environment:
|
|
# DATABASE_USER: grassroots
|
|
# DATABASE_HOST: postgres
|
|
# DATABASE_PORT: 5432
|
|
# DATABASE_PASSWORD: tralala
|
|
# DATABASE_NAME: cic_ussd
|
|
# DATABASE_ENGINE: postgresql
|
|
# DATABASE_DRIVER: psycopg2
|
|
# CELERY_BROKER_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
# CELERY_RESULT_URL: ${CELERY_BROKER_URL:-redis://redis}
|
|
# depends_on:
|
|
# - postgres
|
|
# - redis
|
|
# deploy:
|
|
# restart_policy:
|
|
# condition: on-failure
|
|
# command: "/root/start_tasker.sh -q cic-ussd"
|