# Copyright (c) Abstract Machines # SPDX-License-Identifier: Apache-2.0 # This docker-compose file contains optional MongoDB-reader service # for Magistrala platform. Since these are optional, this file is dependent of docker-compose file # from /docker. In order to run this service, execute command: # docker compose -f docker/docker-compose.yml -f docker/addons/mongodb-reader/docker-compose.yml up # from project root. MongoDB service is defined in docker/addons/mongodb-writer/docker-compose.yml. networks: magistrala-base-net: services: mongodb-reader: image: magistrala/mongodb-reader:${MG_RELEASE_TAG} container_name: magistrala-mongodb-reader restart: on-failure environment: MG_MONGO_READER_LOG_LEVEL: ${MG_MONGO_READER_LOG_LEVEL} MG_MONGO_READER_HTTP_HOST: ${MG_MONGO_READER_HTTP_HOST} MG_MONGO_READER_HTTP_PORT: ${MG_MONGO_READER_HTTP_PORT} MG_MONGO_READER_HTTP_SERVER_CERT: ${MG_MONGO_READER_HTTP_SERVER_CERT} MG_MONGO_READER_HTTP_SERVER_KEY: ${MG_MONGO_READER_HTTP_SERVER_KEY} MG_MONGO_HOST: ${MG_MONGO_HOST} MG_MONGO_PORT: ${MG_MONGO_PORT} MG_MONGO_NAME: ${MG_MONGO_NAME} MG_THINGS_AUTH_GRPC_URL: ${MG_THINGS_AUTH_GRPC_URL} MG_THINGS_AUTH_GRPC_TIMEOUT: ${MG_THINGS_AUTH_GRPC_TIMEOUT} MG_THINGS_AUTH_GRPC_CLIENT_CERT: ${MG_THINGS_AUTH_GRPC_CLIENT_CERT:+/things-grpc-client.crt} MG_THINGS_AUTH_GRPC_CLIENT_KEY: ${MG_THINGS_AUTH_GRPC_CLIENT_KEY:+/things-grpc-client.key} MG_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MG_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt} MG_AUTH_GRPC_URL: ${MG_AUTH_GRPC_URL} MG_AUTH_GRPC_TIMEOUT: ${MG_AUTH_GRPC_TIMEOUT} MG_AUTH_GRPC_CLIENT_CERT: ${MG_AUTH_GRPC_CLIENT_CERT:+/auth-grpc-client.crt} MG_AUTH_GRPC_CLIENT_KEY: ${MG_AUTH_GRPC_CLIENT_KEY:+/auth-grpc-client.key} MG_AUTH_GRPC_SERVER_CA_CERTS: ${MG_AUTH_GRPC_SERVER_CA_CERTS:+/auth-grpc-server-ca.crt} MG_SEND_TELEMETRY: ${MG_SEND_TELEMETRY} MG_MONGO_READER_INSTANCE_ID: ${MG_MONGO_READER_INSTANCE_ID} ports: - ${MG_MONGO_READER_HTTP_PORT}:${MG_MONGO_READER_HTTP_PORT} networks: - magistrala-base-net volumes: - ../../ssl/certs:/etc/ssl/certs # Auth gRPC client certificates - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_AUTH_GRPC_CLIENT_CERT:-./ssl/certs/dummy/client_cert} target: /auth-grpc-client${MG_AUTH_GRPC_CLIENT_CERT:+.crt} bind: create_host_path: true - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_AUTH_GRPC_CLIENT_KEY:-./ssl/certs/dummy/client_key} target: /auth-grpc-client${MG_AUTH_GRPC_CLIENT_KEY:+.key} bind: create_host_path: true - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_AUTH_GRPC_SERVER_CA_CERTS:-./ssl/certs/dummy/server_ca} target: /auth-grpc-server-ca${MG_AUTH_GRPC_SERVER_CA_CERTS:+.crt} bind: create_host_path: true # Things gRPC mTLS client certificates - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_THINGS_AUTH_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert} target: /things-grpc-client${MG_THINGS_AUTH_GRPC_CLIENT_CERT:+.crt} bind: create_host_path: true - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_THINGS_AUTH_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key} target: /things-grpc-client${MG_THINGS_AUTH_GRPC_CLIENT_KEY:+.key} bind: create_host_path: true - type: bind source: ${MG_ADDONS_CERTS_PATH_PREFIX}${MG_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca} target: /things-grpc-server-ca${MG_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt} bind: create_host_path: true