Difference between revisions of "201701 Medication Track"
Line 228: | Line 228: | ||
====Bonus point:==== | ====Bonus point:==== | ||
+ | 1. In this scenario, the medication list includes MedicationRequest, MedicationAdministration and MedicationDispense resources and using the [http://build.fhir.org/http.html#vsearch cross resource queries] to search for a Patients active medication list. | ||
+ | |||
+ | # The medication list includes MedicationRequest, MedicationAdministration and MedicationDispense resources | ||
+ | # Search on these resources with the following common parameters: | ||
+ | #* patient | ||
+ | #* status | ||
+ | #* note: category is not a common search paramenter | ||
+ | <!-- | ||
+ | #* encounter for extension Reference Encounter )[see issue 5] | ||
+ | #**for historical inpatient medications - (see example below) | ||
+ | #**if absent return the most recent hospitalization | ||
+ | --> | ||
+ | |||
+ | With Server Conforming to Pharmacy FHIR Maturity Project [http://healthedatainc.com/go-ftp/FHIR-ONC-Meds/StructureDefinition-medicationadministration.html MedicationAdministration Profile] and [http://healthedatainc.com/go-ftp/FHIR-ONC-Meds/StructureDefinition-medicationdispense.html MedicationDispense Profile] | ||
+ | |||
+ | GET [base]?_type=MedicationStatement,MedicationRequest,MedicationDispense?status=active,completed,stopped,on-hold&patient=[id]&_format=[mime-type] | ||
Revision as of 17:25, 7 December 2016
Return to January 2017 Proposals
Medication Track
Coordinated with other related Connectathon tracks
- US-Core IG
Submitting WG/Project/Implementer Group
Pharmacy FHIR Profiles Project
Justification
This project is intended to support the Pharmacy WG in moving the Pharmacy FHIR resources to a higher maturity level based on feedback from the Argonaut Project, HL7 work groups and industry implementers. The key objective for this project is to use implement and test the following FHIR Medication related resources and the corresponding US-Core medication Profiles:
In addition to implementing the existing US-Core medication Profiles this tract will examine and support the development of new proposed US-Realm profiles for MedicationAdministration and MedicationDispense.
We will also introduce the scenario for search across all Medication Resources using common search parameter as it is described in the Core Specification
Proposed Track Lead
See Connectathon_Track_Lead_Responsibilities
Expected participants
Please sign up!
If you're working on a server, please complete the "servers" tab of the Signup Spreadsheet **This time around you'll need to update the `status` flag to indicate whether you've begun work (or completed work), so clients will know when to start testing.** You'll also share details about how a developer can obtain OAuth client credentials (`client_id` for public apps, or a `client_id` and `client_secret` for confidential apps) as well as user login credentials. You might consider simply sharing a set of fixed credentials in this spreadsheet, or else directing users to a web page where they can complete self-service registration. If absolutely necessary, you can ask developers to e-mail you directly.
If you're working on a client, please complete the "clients" tab of the Spreadsheet. You'll also need to update the `status` flag to indicate whether you've begun work (or completed work).
Roles
(reproduced from Argonaut Project implementation-program Resprint)
Server/EHR
If you're working on a server, please complete the "servers" tab of the Sprints Spreadsheet (see above). You'll need to update the status flag to indicate whether you've begun work (or completed work), so clients will know when to start testing. You'll also share details about how a developer can obtain OAuth client credentials (client_id for public apps, or a client_id and client_secret for confidential apps) as well as **user login credentials. The preferred approach is to direct users to a web page where they can complete self-service registration. (If absolutely necessary, you can ask developers to e-mail you directly.) Work on your OAuth implementation
The expectation is that servers will follow Argonaut’s best-practice approach by implementing the OAuth2-based SMART on FHIR authorization specification. To make this more approachable for new implementers, you can think about handling security in four parts:
- open server. Before you get OAuth working, and even once you have an OAuth-secured server, it can be helpful to host sample data at a totally unprotected https endpoint. This facilitates testing, debugging, and exploration
- Standalone launch. Following SMART’s “standalone launch” flow means that the user (patient, or clinician) can begin by launching an app, and from there can engage in a “connect to my EHR” workflow. This approach is suitable for MU3 patient API access.
- EHR launch. Following SMART’s “EHR launch” flow means that the user (patient, or clinician) can begin from the EHR or potal, and launch an app from there, ensuring that the app learns the context about the surrounding EHR or portal environment. This approach is suitable for embedding apps in an EHR or portal.
- Single Sign-on. Using the OAuth2-based OpenID Connect framework for single sign-on, your authorization server can “vouch for” a user’s identity. This helps ensure that users don’t need to create a new account, with new credentials, for every app they use. This approach to SSO can be used with either of SMART’s launch flows.
Client
If you're working on a client, please complete the "clients" tab of the Sprints Spreadsheet (see above) . You'll also need to update the status flag to indicate whether you've begun work (or completed work).
Scenarios
Dedicated Zulip chat stream for this Track.
Use cases:
- Patient and Provider access to a patient’s active and historical medication list
- Patient and Provider updates to a patient’s active and historical medication list
- Create a new outpatient Prescription
Return to January 2017 Proposals
Medication Track
Coordinated with other related Connectathon tracks
- US-Core IG
Submitting WG/Project/Implementer Group
Pharmacy FHIR Profiles Project
Justification
This project is intended to support the Pharmacy WG in moving the Pharmacy FHIR resources to a higher maturity level based on feedback from the Argonaut Project, HL7 work groups and industry implementers. The key objective for this project is to use implement and test the following FHIR Medication related resources and the corresponding US-Core medication Profiles:
In addition to implementing the existing US-Core medication Profiles this tract will examine and support the development of new proposed US-Realm profiles for MedicationAdministration and MedicationDispense.
Proposed Track Lead
See Connectathon_Track_Lead_Responsibilities
Expected participants
Please sign up!
If you're working on a server, please complete the "servers" tab of the Signup Spreadsheet **This time around you'll need to update the `status` flag to indicate whether you've begun work (or completed work), so clients will know when to start testing.** You'll also share details about how a developer can obtain OAuth client credentials (`client_id` for public apps, or a `client_id` and `client_secret` for confidential apps) as well as user login credentials. You might consider simply sharing a set of fixed credentials in this spreadsheet, or else directing users to a web page where they can complete self-service registration. If absolutely necessary, you can ask developers to e-mail you directly.
If you're working on a client, please complete the "clients" tab of the Spreadsheet. You'll also need to update the `status` flag to indicate whether you've begun work (or completed work).
Roles
(reproduced from Argonaut Project implementation-program ReConnectathon)
Server/EHR
If you're working on a server, please complete the "servers" tab of the Connectathons Spreadsheet (see above). You'll need to update the status flag to indicate whether you've begun work (or completed work), so clients will know when to start testing. You'll also share details about how a developer can obtain OAuth client credentials (client_id for public apps, or a client_id and client_secret for confidential apps) as well as **user login credentials. The preferred approach is to direct users to a web page where they can complete self-service registration. (If absolutely necessary, you can ask developers to e-mail you directly.) Work on your OAuth implementation
The expectation is that servers will follow Argonaut’s best-practice approach by implementing the OAuth2-based SMART on FHIR authorization specification. To make this more approachable for new implementers, you can think about handling security in four parts:
- open server. Before you get OAuth working, and even once you have an OAuth-secured server, it can be helpful to host sample data at a totally unprotected https endpoint. This facilitates testing, debugging, and exploration
- Standalone launch. Following SMART’s “standalone launch” flow means that the user (patient, or clinician) can begin by launching an app, and from there can engage in a “connect to my EHR” workflow. This approach is suitable for MU3 patient API access.
- EHR launch. Following SMART’s “EHR launch” flow means that the user (patient, or clinician) can begin from the EHR or potal, and launch an app from there, ensuring that the app learns the context about the surrounding EHR or portal environment. This approach is suitable for embedding apps in an EHR or portal.
- Single Sign-on. Using the OAuth2-based OpenID Connect framework for single sign-on, your authorization server can “vouch for” a user’s identity. This helps ensure that users don’t need to create a new account, with new credentials, for every app they use. This approach to SSO can be used with either of SMART’s launch flows.
Client
If you're working on a client, please complete the "clients" tab of the Connectathons Spreadsheet (see above) . You'll also need to update the status flag to indicate whether you've begun work (or completed work).
Scenarios
Dedicated Zulip chat stream for this Track.
Use cases:
- Patient and Provider access to a patient’s active medication list
- Patient and Provider updates to a patient’s active medication list
- Create a new outpatient Prescription
1. Patient and Provider access to a patient’s active and historical medication list
Action: (Patient consumer or Provider) requests active medications or historical medication list.
Using a search on MedicationStatement with the following parameters:
- patient
- status
- category ! note : not defined in core made a CR [#12337] to support as core search parameter
GET /MedicationStatement?patient={id}&status=active,completed,stopped,on-hold&category=inpatient,patientspecified
for inpatient active medications for current or most recent hospitalization
GET /MedicationStatement?patient={id}&status=active&category=outpatient,patientspecified
for a current snapshot of outpatient's active medications
This scenario is similar to the Argonaut use case Connectathon 4. Refer to the Argonaut Medications IG for Success Criteria. (Note although this references DSTU2, our focus is on STU3.)
Examples:
http://fhir3.healthintersections.com.au/open/MedicationStatement/?pat=1&status=active
Preconditions:
- Patient does exist on the server previously with medications.
- Server conforms to the US-Core CapabilityStatement-daf-query-responder for Medication, MedicationStatement, MedicationRequest, and Patient profiles
- Client conforms to the US-Core MedicationStatement, MedicationRequest, and Patient profiles
- Server and Client mandatory support of the category element for MedicationStatement and MedicationRequest
Definitions
- Active Medication List – A list of medications that a given patient is currently taking.
- MAR linked to workflow and is medication actually given during hospitalization.
Success Criteria:Server returns a Bundle containing entries for:
- all the patient's active medications
Bonus point:
1. In this scenario, the medication list includes MedicationRequest, MedicationAdministration and MedicationDispense resources and using the cross resource queries to search for a Patients active medication list.
- The medication list includes MedicationRequest, MedicationAdministration and MedicationDispense resources
- Search on these resources with the following common parameters:
- patient
- status
- note: category is not a common search paramenter
With Server Conforming to Pharmacy FHIR Maturity Project MedicationAdministration Profile and MedicationDispense Profile
GET [base]?_type=MedicationStatement,MedicationRequest,MedicationDispense?status=active,completed,stopped,on-hold&patient=[id]&_format=[mime-type]
2. retrieve a historical medication list for a prior hospitalization (for example 3 hospitalizations ago)
Issues and Questions (GitHub issues link)
2. Patient or Provider adding new medication to patient’s (“active”) medication
Action: (Patient consumer or Provider) updates active medications list. Specifically updates (add, revise, deprecate) to MedicationStatement.
Using add
PUT /MedicationStatement/[id] or POST /MedicationStatement
revise
PUT /MedicationStatement/[id]
Examples:
1. adding a new active medication to the patient records
POST http://fhir3.healthintersections.com.au/open/MedicationStatement
Request Body
<?xml version="1.0" encoding="UTF-8"?>
<MedicationStatement xmlns="http://hl7.org/fhir">
<status value="active"/>
<MedicationCodeableConcept>
<coding>
<system value="http://www.nlm.nih.gov/research/umls/rxnorm"/>
<display value="Acetaminophen 500 MG"/>
</coding>
</MedicationCodeableConcept>
<patient>
<reference value="Patient/pat1"/>
<display value="Donald Duck"/>
</patient>
<effectiveDateTime value="2015-01-23"/>
<note>
<text value="Patient indicates they miss the occasional dose"/>
</note>
<category value="patientspecified">
</category>
<dosage>
<sequence value="1"/>
<text value="1-2 tablets once daily at bedtime as needed for restless legs"/>
</dosage>
</MedicationStatement>
2. Changing a status from active to stopped
PUT http://fhir3.healthintersections.com.au/open/MedicationStatement/2
Request Body
<?xml version="1.0" encoding="UTF-8"?>
<MedicationStatement xmlns="http://hl7.org/fhir">
<id value="2"
<status value="stopped"/>
<MedicationCodeableConcept>
<coding>
<system value="http://www.nlm.nih.gov/research/umls/rxnorm"/>
<display value="Acetaminophen 500 MG"/>
</coding>
</MedicationCodeableConcept>
<patient>
<reference value="Patient/pat1"/>
<display value="Donald Duck"/>
</patient>
<effectiveDateTime value="2015-01-23"/>
<note>
<text value="Patient indicates they miss the occasional dose"/>
</note>
<category value="patientspecified">
</category>
<dosage>
<sequence value="1"/>
<text value="1-2 tablets once daily at bedtime as needed for restless legs"/>
</dosage>
</MedicationStatement>
Preconditions:
- Patient does exist on the server previously with medications.
- Server Conforms to the US-Core CapabilityStatement-daf-query-responder for Medication, MedicationStatement, MedicationRequest, and Patient profiles
- Client conforms to the US-Core MedicationStatement, MedicationRequest, and Patient profiles
- Server and Client mandatory support of the category element for MedicationStatement and MedicationRequest
- Client has write access to Server
Success Criteria:
- Client successfully adds new MedicationStatement to Patient's medication list
- Client successfule revises existing MedicationStatement on Patient's medication list
Bonus point:
update MedicationRequest, MedicationAdministration and MedcicationDispense resources
With Server Conforming to Pharmacy FHIR Maturity Project MedicationAdministration Profile and MedicationDispense Profile
Issues and Questions (GitHub issues link)
3. Create a new outpatient Prescription
3.1 Action:
Provider creates new outpatient Prescription using the MedicationRequest resource ( this just a record of the request and need to be made actionable by some Workflow pattern described below.
Using
PUT /MedicationRequest/[id] or POST /MedicationRequest
Examples:
adding a new prescription for the patient
POST http://fhir3.healthintersections.com.au/open/MedicationRequest
Request Body
<?xml version="1.0" encoding="UTF-8"?> <MedicationRequest xmlns="http://hl7.org/fhir"> <status value="active"/> <stage> <coding></coding> </stage> <medicationCodeableConcept> <coding> <system value="http://www.nlm.nih.gov/research/umls/rxnorm"/>
<display value="Acetaminophen 500 MG"/> </coding> </medicationCodeableConcept> <patient> <reference value="Patient/pat1"/> <display value="Donald Duck"/> </patient> <dateWritten value="2015-01-15"/> <prescriber> <reference value="Practitioner/f007"/> <display value="Patrick Pump"/> </prescriber> <category> <coding> <system value="http://hl7.org/fhir/medication-request-category"/>
<display value="Inpatient"/> </coding> </category> <dosageInstruction> <sequence value="1"/> <text value="one to two tablets every 4-6 hours as needed for rib pain"/> </dosageInstruction> </MedicationRequest>
Preconditions:
- Patient does exist on the server previously with medications.
- Server Conforms to the US-Core CapabilityStatement-daf-query-responder for Medication, MedicationStatement, MedicationRequest, and Patient profiles
- Client conforms to the US-Core MedicationStatement, MedicationRequest, and Patient profiles
- Server and Client mandatory support of the category element for MedicationStatement and MedicationRequest
Success Criteria:
- Client successfully create new MedicationRequest
3.2 Action:
Subsequent workflow steps depend on specific pattern agreed upon by busines partners. See a list of possible scenarios here.
For example the new outpatient Prescription is made actionable by using the Task resource to initiate a prescription to a community or inhouse pharmacy.
Note: The request would generate a NCPDP script for community pharmacy or likely a v2 message or inhouse pharmacy.
Bonus point: update MedicationRequest, MedicationAdministration and/or MedicationDispense resources based on new MedicationRequest.
With Server Conforming to Pharmacy FHIR Maturity Project MedicationAdministration Profile and MedicationDispense Profile
Issues and Questions (GitHub issues link)
TestScript(s)
tbd