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:
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
services:
openfhir:
....
environment:
SPRING_DATA_MONGODB_URI: "mongodb://openfhir:openfhir@localhost:27017/openfhir"
DB_TYPE: "mongo"
Postgres
-e DB.TYPE=postgres
or in docker compose
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: 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: 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'
}
]
});