Profiles & Interactions > Interactions: Submit New Client Data
Interaction: Submit Client Data
The Submit Client Data interaction is used to transfer client records to the Mental Health and Addictions Provincial Data Set Repository. This interaction can be used for create or update scenarios.
Scope
This transaction involves a request by a Point of Service system to transfer a Health Information Custodian's (HIC) client bundle containing a single client record along with linked resources, to the Mental Health and Addictions Provincial Data Set Repository (MHA PDS Repository). The MHA PDS Repository will store the received bundle and returns an HTTP response code and an InteractionsOutcome resource if applicable.
For example, a user at a HIC site records client data in a Point of Service (PoS) System. The PoS system will extract and assemble client data as per the Mental Health and Addictions Provincial Data Set HL7 FHIR Implemenation Guide specifications and submit it to the MHA PDS Repository.
Interaction Diagram
Actor: MHA PDS Data Source
Role: Submits a client record bundle containing one client record and, at a minimum, patient, organization, and location resources, along with other additional resources that may be populated with data to the MHA PDS Data Recipient.
Actor: MHA PDS Data Recipient
Role: Receives and stores client record bundles from the MHA PDS Data Sources.
Specification
This specification is based on the FHIR R4.0.1 Create Interactions.
Submit Client Record Request
The Submitt Client Record Request will create a client record bundle based upon data stored in the MHA PDS Data Source.
POST [base]/Bundle/
Example Create Message
HTTP Method:
POST
Headers:
Content-Type: application/fhir+json
Address:
[base]/Bundle/
Message body:
{
  "resourceType" : "Bundle",
  "id": "MHAPDS-example-Bundle-01",
  "meta" : {
    "lastUpdated" : "2022-02-01T14:30:00+01:00",
    "profile" : [
      "http://ontariohealth.ca/fhir/StructureDefinition/ca-on-mha-profile-bundle"
    ]
  },
  "identifier" : {
    "system" : "http://ex-ps-identifier-system.org",
    "value" : "urn:uuid:f0065a28-9990-11ec-b909-0242ac120002"
  },
  "type" : "collection",
  "timestamp" : "2022-02-01T14:30:00+01:00",
  "entry" : [
    {
	  "fullUrl": "c3f1e2a6-f792-4502-85eb-ee79fb09da49",
      "resource" : {
			"resourceType": "Patient",
			"id": "a0df9da6-3157-4b72-95f1-729853718c09",
			"meta": {
				"profile": [
					"http://ontariohealth.ca/fhir/StructureDefinition/ca-on-mha-profile-patient"
				]
			},
			"extension": [
					{
						"url": "http://hl7.org/fhir/StructureDefinition/patient-religion",
						"valueCodeableConcept":
						{
							"coding": [
								{
									"system": "http://terminology.hl7.org/CodeSystem/v3-ReligiousAffiliation",
									"code":"1033",
									"display":"New Age"
								}
							]
						}
					},
					{
						"url": "http://ontariohealth.ca/fhir/StructureDefinition/ca-on-mha-ext-ethnicity",
						"valueCodeableConcept":
						{
							"coding": [
								{
									"system": "http://snomed.info/sct",
									"code":"309644006"
								}
							]
						}
					}
...
Expected Behaviour
| Case | Scenario Description | HTTP Status Code | Response Payload | 
|---|---|---|---|
| 1 | A valid MHA PDS Client record Bundle is submitted, accepted, and published to the repository | HTTP 201 | Created. Interactions Outcome | 
| 2 | The submitted MHA PDS Bundle cannot be validated as it does not conform to the specification | HTTP 422 | Bad Request. Returns an OperationOutcome resource indicating an issue. The client must fix the request and try again. | 
| 3 | The submitted MHA PDS bundle contains a duplicate bundle identifer that was previous used | HTTP 409 | Bad Reequest. Returns an OperationOutcome resource indicating an issue. The client must generate a new bundle identifier and re-submit. | 
| 4 | POST Interactions contains incorrect header value for "Content-Type" - should be "application/fhir+json" | HTTP 400 | Bad Request. Returns an InteractionsOutcome resource indicating an issue. | 
| 5 | MHA FHIR REST API validates the request but cannot return a valid response due to internal issues. | HTTP 500 | Internal Server Error. Returns an InteractionsOutcome resource indicating an issue. |