2022-12-31 10:22:38 +01:00
|
|
|
version: '3.8'
|
|
|
|
|
|
|
|
services:
|
|
|
|
api:
|
|
|
|
build:
|
|
|
|
context: .
|
|
|
|
dockerfile: docker/api/Dockerfile
|
|
|
|
depends_on:
|
2023-10-24 09:27:34 +02:00
|
|
|
shared-volume-init:
|
|
|
|
condition: service_completed_successfully
|
2023-05-29 20:03:01 +02:00
|
|
|
mysql:
|
|
|
|
condition: service_healthy
|
2023-10-24 09:27:34 +02:00
|
|
|
group_add:
|
|
|
|
- '1000'
|
2022-12-31 10:22:38 +01:00
|
|
|
volumes:
|
|
|
|
- ./migrations:/migrations
|
|
|
|
- go-modules:/go/pkg/mod
|
2023-10-24 09:27:34 +02:00
|
|
|
- shared-volume:/tmp/2fas
|
2022-12-31 10:22:38 +01:00
|
|
|
ports:
|
|
|
|
- "80:8080"
|
|
|
|
env_file:
|
|
|
|
- .env
|
|
|
|
|
2023-09-22 15:19:04 +02:00
|
|
|
admin:
|
|
|
|
build:
|
|
|
|
context: .
|
|
|
|
dockerfile: docker/admin/Dockerfile
|
|
|
|
depends_on:
|
2023-10-24 09:27:34 +02:00
|
|
|
shared-volume-init:
|
|
|
|
condition: service_completed_successfully
|
2023-09-22 15:19:04 +02:00
|
|
|
mysql:
|
|
|
|
condition: service_healthy
|
2023-10-24 09:27:34 +02:00
|
|
|
group_add:
|
|
|
|
- '1000'
|
|
|
|
volumes:
|
|
|
|
- shared-volume:/tmp/2fas
|
2023-09-22 15:19:04 +02:00
|
|
|
ports:
|
|
|
|
- "8082:8080"
|
|
|
|
env_file:
|
|
|
|
- .env
|
|
|
|
|
2022-12-31 10:22:38 +01:00
|
|
|
websocket:
|
|
|
|
build:
|
|
|
|
context: .
|
|
|
|
dockerfile: docker/websocket/Dockerfile
|
|
|
|
depends_on:
|
|
|
|
- mysql
|
|
|
|
ports:
|
|
|
|
- "8081:8081"
|
|
|
|
env_file:
|
|
|
|
- .env
|
|
|
|
|
|
|
|
mysql:
|
|
|
|
image: mysql:8
|
|
|
|
volumes:
|
|
|
|
- ./data/mysql:/var/lib/mysql
|
|
|
|
- ./docker/mysql/dev-schema.sql:/docker-entrypoint-initdb.d/schema.sql
|
|
|
|
ports:
|
|
|
|
- "127.0.0.1:3306:3306"
|
|
|
|
environment:
|
|
|
|
- MYSQL_ROOT_PASSWORD=root
|
2023-05-29 20:03:01 +02:00
|
|
|
healthcheck:
|
|
|
|
test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
|
|
|
|
timeout: 20s
|
|
|
|
retries: 10
|
2022-12-31 10:22:38 +01:00
|
|
|
|
|
|
|
redis:
|
|
|
|
image: bitnami/redis:latest
|
|
|
|
ports:
|
|
|
|
- "127.0.0.1:6379:6379"
|
|
|
|
environment:
|
|
|
|
- ALLOW_EMPTY_PASSWORD=yes
|
|
|
|
|
2023-10-24 09:27:34 +02:00
|
|
|
# docker compose always mount named volumes as root (https://github.com/docker/compose/issues/3270)
|
|
|
|
# and without changing permission, we want be able to access shared volume
|
|
|
|
shared-volume-init:
|
|
|
|
image: ubuntu
|
|
|
|
user: root
|
|
|
|
group_add:
|
|
|
|
- '1000'
|
|
|
|
volumes:
|
|
|
|
- shared-volume:/tmp/2fas
|
|
|
|
command: chown -R 1000:1000 /tmp/2fas
|
|
|
|
|
2024-01-03 17:15:03 +01:00
|
|
|
pass:
|
|
|
|
build:
|
|
|
|
context: .
|
|
|
|
dockerfile: docker/pass/Dockerfile
|
|
|
|
group_add:
|
|
|
|
- '1000'
|
|
|
|
ports:
|
2024-04-27 15:24:58 +02:00
|
|
|
- "8088:8082"
|
2024-01-24 20:57:31 +01:00
|
|
|
environment:
|
|
|
|
# overwrite AWS_ENDPOINT from .env file. One in env is used to running app from local also.
|
|
|
|
AWS_ENDPOINT: http://localstack-main:4566
|
2024-04-27 15:24:58 +02:00
|
|
|
AWS_REGION: us-east-1
|
2024-01-03 17:15:03 +01:00
|
|
|
env_file:
|
|
|
|
- .env
|
2024-01-24 20:57:31 +01:00
|
|
|
depends_on:
|
|
|
|
localstack:
|
|
|
|
condition: service_healthy
|
2023-10-24 09:27:34 +02:00
|
|
|
|
2024-01-19 15:34:02 +01:00
|
|
|
localstack:
|
|
|
|
container_name: "${LOCALSTACK_DOCKER_NAME:-localstack-main}"
|
|
|
|
image: localstack/localstack
|
|
|
|
ports:
|
|
|
|
- "127.0.0.1:4566:4566"
|
|
|
|
environment:
|
|
|
|
- DEBUG=1
|
2024-01-24 20:57:31 +01:00
|
|
|
healthcheck:
|
|
|
|
test: >-
|
|
|
|
curl -s localhost:4566/_localstack/health | grep -q '"kms": "running"'
|
|
|
|
interval: 5s
|
|
|
|
timeout: 5s
|
|
|
|
retries: 5
|
2024-01-19 15:34:02 +01:00
|
|
|
volumes:
|
2024-04-27 15:24:58 +02:00
|
|
|
- "./e2e-tests/localstack_init.sh:/etc/localstack/init/ready.d/localstack_init.sh" # ready hook
|
2024-01-19 15:34:02 +01:00
|
|
|
- "./data/localstack:/var/lib/localstack"
|
|
|
|
- "/var/run/docker.sock:/var/run/docker.sock"
|
|
|
|
|
2022-12-31 10:22:38 +01:00
|
|
|
volumes:
|
2023-09-22 15:19:04 +02:00
|
|
|
go-modules:
|
2023-10-24 09:27:34 +02:00
|
|
|
# shared-volume is used to share volume between api and admin. On producition AWS S3 is used,
|
|
|
|
# but here for local dev shared volume is fine.
|
|
|
|
shared-volume:
|