Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add GT1 Mapping in ReportStream #1614

Open
7 of 30 tasks
brick-green opened this issue Nov 25, 2024 · 9 comments
Open
7 of 30 tasks

Add GT1 Mapping in ReportStream #1614

brick-green opened this issue Nov 25, 2024 · 9 comments

Comments

@brick-green
Copy link

brick-green commented Nov 25, 2024

Story

As a sender of Orders, so that I can send insurance information, I need the GT1 segment to be read on incoming OML messages and output in OML messages.

Pre-conditions

  • Example OMLs are available with GT1 segments present

Acceptance Criteria

  • All fields in the GT1 segment present in the OML are exactly the same on the output file are they are in the input sample file
  • Integration tests have been added for all fields that are mapped in ReportStream

Notes

Tasks

Research

  • Review mapping inventory and confluence pages to find mapping guidelines

Engineering

  • Add mapping to ReportStream
    • HL7 => FHIR
    • FHIR => HL7
  • Add integration tests for mappings

Definition of Done

  • Documentation tasks completed
    • Documentation and diagrams created or updated
      • ADRs (/adr folder)
      • Main README.md
      • Other READMEs in the repo
      • If applicable, update the ReportStream Setup section in README.md
    • Threat model updated
    • API documentation updated
  • Code quality tasks completed
    • Code refactored for clarity and no design/technical debt
    • Adhere to separation of concerns; code is not tightly coupled, especially to 3rd party dependencies
  • Testing tasks completed
    • Load tests passed
    • Additional e2e tests created
    • Additional RS e2e assertions created in the rs-e2e project for any new transformations. Includes improvements to the assertion code required to make the new assertions
  • Build & Deploy tasks completed
    • Build process updated
    • API(s) are versioned
    • Feature toggles created and/or deleted. Document the feature toggle
    • Source code is merged to the main branch

Note: Please remove any DoD items that are not applicable

Research Questions

  • Optional: Any initial questions for research

Decisions

  • Optional: Any decisions we've made while working on this story
@JohnNKing
Copy link
Contributor

Split into 2 or 3 stories?

  1. Inbound HL7 => FHIR
  2. Outbound FHIR = > HL7
  3. Spike for determining FHIR mappings (as these are non-standard)

@brick-green
Copy link
Author

Typically the segment mappings are completed as one ticket for the HL7 to FHIR and FHIR to HL7. The data mapping integration tests will test the round trip from HL7 to FHIR then back to HL7 so it's helpful to do all the mapping in one PR. There could be an opportunity to split out tickets for any new data types that are part of GT1 but not currently mapped.

@pluckyswan pluckyswan self-assigned this Dec 30, 2024
@sfradkin sfradkin added the transformation for CDC mapping label Jan 1, 2025
@pluckyswan pluckyswan removed their assignment Jan 2, 2025
@GilmoreA6 GilmoreA6 self-assigned this Jan 8, 2025
@GilmoreA6
Copy link
Contributor

@GilmoreA6
Copy link
Contributor

GilmoreA6 commented Jan 10, 2025

Added Account resource to RS FHIR R4 mapping model for OML.

After discussion we are going to map all fields in GT1 to a newly created extension https://reportstream.cdc.gov/fhir/StructureDefinition/gt1-account and then also map any fields in accordance with the linked confluence document.

On the FHIR->HL7 side we will then set conditions so that the extension values are used first if available, then if not to use the other mappings. This ensures that we will faithfully return the input value for each field even if it differs from the official guidance

@GilmoreA6
Copy link
Contributor

Mapped GT1-1 -> GT1-20 for HL7-> FHIR onto branch

@GilmoreA6
Copy link
Contributor

exception to mapping strategy made for GT1.13 and GT1.14 to follow IN1 pattern

@GilmoreA6
Copy link
Contributor

Mapped all remaining GT1 fields from HL7-> FHIR GT1 extension. GT1-50 and GT1-54 require new datatypes that are unmapped. Created placeholder datatype mappings for these

@scleary1cs
Copy link
Contributor

@brick-green shared this yesterday:
https://www.hl7inspector.com/

@GilmoreA6
Copy link
Contributor

All GT1 fields have been mapped from HL7->FHIR->HL7 except for GT1.51 and GT1.55 which require new datatypes.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants