.. _installation: Installation ================ Docker ------------- openFHIR can be easily installed using Docker. The official Docker image is available at `openfhir/openfhir:latest`. To run Open-FHIR using Docker, use the following command: .. code-block:: bash docker run -e SPRING_DATA_MONGODB_URI=mongodb://your-mongodb-url \ -e LICENSE=/path/to/license \ -p 8080:8080 openfhir/openfhir:latest Database -------- At the moment, mongodb and postgres are supported. By default, mongodb will be used. To change this, configure "db.type" property. MongoDB ####### ``-e DB.TYPE=mongo`` or in docker compose .. code-block:: bash services: openfhir: .... environment: SPRING_DATA_MONGODB_URI: "mongodb://openfhir:openfhir@localhost:27017/openfhir" DB_TYPE: "mongo" .. _postgres-section: Postgres ######## ``-e DB.TYPE=postgres`` or in docker compose .. code-block:: bash services: openfhir: .... environment: SPRING_DATASOURCE_URL: jdbc:postgresql://localhost:5432/openfhir SPRING_DATASOURCE_USERNAME: postgres SPRING_DATASOURCE_PASSWORD: postgres DB_TYPE: "postgres" Database stores the following state: - `bootstrapEntity`: collection holding a state of all files that were bootstrapped at startup (so they aren't processed again at each startup) - `conceptMapFhirEntity`: concept maps for terminology (see more: :doc:`terminology`) - `fhirConnectContextEntity`: FHIR Connect context mappers - `fhirConnectMapperEntity`: FHIR Connect model mappers - `optEntity`: Operational templates (unless the engine is integrated to an external openEHR repository, see more: :doc:`integrations`) docker compose -------------- Example docker compose file :: services: openfhir: image: openfhir/openfhir:latest container_name: openfhir ports: - "8080:8080" volumes: - "/home/user/Documents/openFHIR/license.json:/app/openfhir-license.json" - "/home/user/Documents/openFHIR/openfhir-bootstrap/:/app/bootstrap/" environment: SPRING_DATA_MONGODB_URI: "mongodb://openfhir:openfhir@localhost:27017/openfhir" LICENSE: "/app/openfhir-license.json" # could also be left out, as this is the default BOOTSTRAP_DIR: "/app/bootstrap/" # could also be left out, as this is the default mongodb: image: mongo:latest container_name: mongodb ports: - "27017:27017" environment: MONGO_INITDB_ROOT_USERNAME: "admin" MONGO_INITDB_ROOT_PASSWORD: "admin" MONGO_INITDB_DATABASE: "openfhir" volumes: - ./init-mongo.js:/docker-entrypoint-initdb.d/init-mongo.js:ro init-mongo.js :: // Connect to the admin database to create a user for a specific database db = db.getSiblingDB('openfhir'); // Create a new user with readWrite access to the 'openfhir' database db.createUser({ user: 'openfhir', pwd: 'openfhir', roles: [ { role: 'readWrite', db: 'openfhir' } ] });