Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
minLevel1
maxLevel6
outlinefalse
stylenone
typelist
printabletrue

Adding Practitioners into FHIRstore


Ensure OE is set to pull pracrittioners from the Consolidated server by setting org.openelisglobal.providerlist.fhirstore=https://cs-path:5000/fhir/

Step 1 : Set up a Connection Through OpenHIM

Communicate through OpenHIM so you can use HTTP Basic auth to authenticate instead of certs.

Create a client in OpenHIM using the instructions here.

  • Remember your client ID as it will be your username

  • Give the client a role that has access to the FHIRstore channel (most likely one of fhir-pusher, fhir-puller, otherwise you will have to add the user to the channel as shown here)

  • Configure authentication with Basic Auth, and keep track of your password

Test that your connection works by navigating to or making a GET request to https://<OpenHIMaddress>:5000/fhir/Practitioner with basic auth properties set.

You should receive a page of the current Practitioner in JSON format.

Step 2: Generating a UUID

Because we want to use uuid’s for all our fhir objects, you will need to generate one. There are many generators online such as https://www.uuidgenerator.net/ . It is recommended to use UUID version 4 when generating.

Step 3: Write your Practitioner in FHIR notation

Below is a template of a FHIR Organization. highlighted fields should be replaced

{

Code Block
"resourceType": "Practitioner",

"id": "generated uuid",

"identifier": [

{

"system": "http://openelis-global.org/org_regNum",

"value": "regNum"

}

Code Block
],

"active": true,

"name": [

{

"family": "familyName",

"given": [

"givenName"

],

"prefix": [

"Dr"

]

}

Code Block
],

"telecom": [

{

"system": "phone"

},

{

"system": "email"

},

{

"system": "fax"

}

Code Block
]

}

Step 5:

Decide whether you want to add entities one by one, or commit them in one large transaction.

Step 5a: Add a Single Practitioner to Fhir place

In POSTman:

  • select PUT operation

  • Set address as the either the FHIR address or the OpenHIM address https://<fhir or OpenHIM address>:<port>/fhir/Practitioner/generated uuid

  • Add Practitioner as the request body

  • set Content-Type header to application/json

  • execute the command

Alternatively use the FHIR UI:

  • Navigate to https://<fhir or OpenHIM address>:<port>

  • select Practitioner on the left hand list

  • go to CRUD operation and do an UPDATE (NOT INSERT)

  • Set the id as the generated uuid

  • Execute the command

Step 5b: Add Organization to Bundle

Template for the bundle is below. The entity in green represents a single entry in the bundle. Multiple entries can be added as a comma delimited list.

Code Block
{

"resourceType": "Bundle",

"id": "bundle-transaction",

"type": "transaction",

"entry": [
{

  "resource":

{Practitioner JSON here},

  "request": {

    "method": "PUT",

    "url": "Practitioner/generated uuid"

}
}

]

}

Once your bundle contains all the entries you want you can execute the transaction bundle

In POSTman:

  • select POST operation

  • Set address as https://<fhir or OpenHIM address>:<port>/fhir

  • Add Bundle as the request body

  • set Content-Type header to application/json

  • execute the command

Troubleshooting:

No new doctors are being imported

  • ensure the OpenELIS is configured to pull practitioners from the FhirStore: by setting in extra.properties: org.openelisglobal.providerlist.fhirstore=https://server-url:5000/fhir/

  • ensure the configured endpoint is reachable from the OE server: telnet server-url 5000

  • ensure the doctors name has no illegal characters. The supported characters are set in Admin > Field Validation Configuration under the firstNameCharset and lastNameCharset

  • ensure the system is running the import procedure (by default, it runs on startup and every hour. The system can be restarted to trigger the import or by visiting the endpoint https://server-url:8443/OpenELIS-Global/import/provider

  • check the logs to see if an unknown error is occurring and if you can't understand what is going wrong, escalate the problem.