English
|
繁體中文
Burni is a user-friendly implementation of the FHIR server built using Node, Express, and MongoDB. It offers a straightforward way for developers to customize the HL7 FHIR® specification, with support for both Windows and Linux environments, making it easy to deploy a FHIR service. Burni allows you to import your Implementation Guide and store FHIR Resources, while also creating FHIR RESTful APIs.
Burni uses version 4.0.1 (R4) of the HL7 FHIR specification.
Burni is a user-friendly implementation of the FHIR server built using Node, Express, and MongoDB. It offers a straightforward way for developers to customize the HL7 FHIR® specification, with support for both Windows and Linux environments, making it easy to deploy a FHIR service. Burni allows you to import your Implementation Guide and store FHIR Resources, while also creating FHIR RESTful APIs.
Burni uses version 4.0.1 (R4) of the HL7 FHIR specification.
Burni has been tested by AEGIS Touchstone Basic-R4-Server. The conformance results show below:
- FHIR4-0-1-Basic-Server version 23 (2,282 tests has been passed, 100% pass)
- FHIR4-0-1-Basic-Server version 18 (2,216 tests has been passed, 100% Pass)
- FHIR4-0-1-Basic-Server version 14 (1,948 tests has been passed, 100% Pass)
This server supported FHIR RESTFul API below:
- read (e.g. GET http://example.com/fhir/Patient/example)
- update (e.g. PUT http://example.com/fhir/Patient/example)
- delete (e.g. DELETE http://example.com/fhir/Patient/example)
- search (e.g. http://example.com/fhir/Patient?_id=example)
- history-type (e.g. http://example.com/fhir/Patient/1/_history)
- history-type-version (e.g. e.g. http://example.com/fhir/Patient/1/_history/1)
Don't remove Bundle.js in models/mongodb/FHIRTypeSchema
- node.js >= 16
- MongoDB >= 4
- Java JDK >= 11 (For validator)
npm install
The resources config in config\config.js
module.exports = {
// add the resource name that you need
"Patient" : {
"interaction": {
"read": true,
"vread": true,
"update": true,
"delete": true,
"history": true,
"create": true,
"search": true
}
}
}
dotenv in root path .env
MONGODB_NAME="dbName"
MONGODB_HOSTS=["mongodb"]
MONGODB_PORTS=[27017]
MONGODB_USER="myAdmin"
MONGODB_PASSWORD="MymongoAdmin1"
MONGODB_IS_SHARDING_MODE=false
MONGODB_SLAVEMODE=false
SERVER_PORT=8080
SERVER_SESSION_SECRET_KEY="secretKey"
FHIRSERVER_HOST="localhost"
FHIRSERVER_PORT=8080 #use by creating bundle url
FHIRSERVER_APIPATH="fhir"
#If u want to use token auth, add below.
ENABLE_TOKEN_AUTH=true
ADMIN_LOGIN_PATH="adminLogin"
ADMIN_USERNAME="adminUsername"
ADMIN_PASSWORD="adminPassword"
ENABLE_CHECK_ALL_RESOURCE_ID=false #true that want to check resource id cross all resource
ENABLE_CHECK_REFERENCE #true that want to check reference is exist in resource content
ENABLE_VALIDATOR=true
After configuration, run npm run build
to generate resources
npm run build
TypeError: genParamFunc[type] is not a function mean that search parameter method not support
node server.js
- get (search)
- Number
- Date (DateTime, Instance Not yet)
- String
- Token
- Reference
- getById (read)
- getHistoryById (history, vread)
- putById (update)
- deleteById (delete)
The details of postman's request body and response: Examples Using Postman
Burni use the node-java-fhir-validator to do validation.
- You can put IG's (package.tgz) or json (StructureDefinition) file in
utils/validator/igs
, and Burni will load it into the validator - You must configure
ENABLE_VALIDATOR
in.env
(dotenv) to true to enable validation feature
-
Search parameters
- composite
- uri
-
Narrative generate