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

Update the API Guide with Code mapping template & instructions #16850

Merged
merged 7 commits into from
Dec 24, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file not shown.
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,6 @@ import site from "../../site.json";
</Card>
</CardGroup>


<p>Our API guide and documentation is also available as a <A href={site.assets.programmersGuidePdf.path} trackClick={{name: "ReportStream API"}} download>downloadable PDF</A>.</p>

***
<br/>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,14 @@ meta:
altText: "A collection of lines extend out from a central point. Each line ends in a circle of square, some green and some white."
---

import Step1 from "./Step1.mdx";
import Step2 from "./Step2.mdx";
import Step3 from "./Step3.mdx";
import Step4 from "./Step4.mdx";
import Step2_1 from "./Step2_1.mdx";
import Step2_2 from "./Step2_2.mdx";
import Step2_3 from "./Step2_3.mdx";
import Step2_4 from "./Step2_4.mdx";
import Step3_1 from "./Step3_1.mdx";
import Step3_2 from "./Step3_2.mdx";
import Step3_3 from "./Step3_3.mdx";
import Step3_4 from "./Step3_4.mdx";
import Sidenav from "../Sidenav.mdx";
import site from "../../../site.json";

Expand All @@ -25,7 +29,7 @@ import site from "../../../site.json";
Examples in this guide use curl commands for simplicity with the assumption you’ll be coding these calls into your sending system.
You can also use a program like Postman to test submissions.

<p className="text-base">**Last updated:** 11/4/24</p>
<p className="text-base">**Last updated:** 12/17/24</p>

***

Expand All @@ -42,10 +46,41 @@ to review <A href={site.forms.contactUs.url}>upon request</A>.

When you’ve formatted your fake (non-PII) data file, test your data model using the
<A href={site.external.nistValidationSuite.url}>NIST Electronic Lab Reporting (ELR) Validation Suite</A>.
(Note: If you’re testing OTC data, use the <A href={site.external.nistGeneralValidationTool.url}>NIST HL7 General Validation Tool</A> and
select RADx MARS HL7v2 from the tool scope dropdown. Navigate to the Context-free tab and select the Onboarding profile group).
Note: If you’re testing OTC data, use the <A href={site.external.nistGeneralValidationTool.url}>NIST HL7 General Validation Tool</A> and
select **RADx MARS HL7v2** from the **Tool Scopes** dropdown. Navigate to the **Context-free** tab and select the **Onboarding** profile group.
Correct any errors you receive.

<h2 className="rs-numbered">Map your codes</h2>

We will ensure that all potential codes you might send to ReportStream are mapped in our system as part of your onboarding. First, format your result and organism codes in a CSV file using our <A href={site.assets.codeMapTemplate.path}>template</A>. Then, send the completed CSV to your onboarding engineer or <A href={site.orgs.RS.email}>[email protected]</A>. We will review your codes and provide next steps to continue your onboarding.

<Accordion bordered multiselectable items={[
{
headingLevel: "h3",
title: "Step 2.1: Set up your file",
content: <Step2_1 />,
id: "2_1"
},
{
headingLevel: "h3",
title: "Step 2.2: Input all result codes",
content: <Step2_2 />,
id: "2_2"
},
{
headingLevel: "h3",
title: "Step 2.3: Input all organism codes (if applicable)",
content: <Step2_3 />,
id: "2_3"
},
{
headingLevel: "h3",
title: "Step 2.4: Upload your file",
content: <Step2_4 />,
id: "2_4"
},
]} />

<h2 className="rs-numbered">Set up authentication and test your API connection</h2>

After you have finalized the formatting of your data, the ReportStream team will begin onboarding you to our staging environment.
Expand All @@ -68,27 +103,27 @@ The data submitted are sent as the payload of the POST, as is, with no changes.
<Accordion bordered multiselectable items={[
{
headingLevel: "h3",
title: "Step 1: Prior to submission, send your public key to ReportStream.",
content: <Step1 />,
id: 1
title: "Step 3.1: Prior to submission, send your public key to ReportStream.",
content: <Step3_1 />,
id: "3_1"
},
{
headingLevel: "h3",
title: "Step 2: At the time of submission, generate a signed JWT using your private key",
content: <Step2 />,
id: 2
title: "Step 3.2: At the time of submission, generate a signed JWT using your private key",
content: <Step3_2 />,
id: "3_2"
},
{
headingLevel: "h3",
title: "Step 3: Send the signed JWT to ReportStream to get a temporary bearer token",
content: <Step3 />,
id: 3
title: "Step 3.3: Send the signed JWT to ReportStream to get a temporary bearer token",
content: <Step3_3 />,
id: "3_3"
},
{
headingLevel: "h3",
title: "Step 4: Submit data to ReportStream using the bearer token",
content: <Step4 />,
id: 4
title: "Step 3.4: Submit data to ReportStream using the bearer token",
content: <Step3_4 />,
id: "3_4"
},
]} />

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
---
tableContent: [
[
{
columnKey: "Code",
columnHeader: "Code",
content: "97099-6",
},
{
columnKey: "Name",
columnHeader: "Name",
content: "Influenza virus A and B and SARS-CoV-2 (COVID-19) Ag panel - Upper respiratory specimen by Rapid immunoassay",
},
{
columnKey: "CodingSystem",
columnHeader: "Coding system",
content:
"LOINC",
},
],
[
{
columnKey: "Code",
columnHeader: "Code",
content: "123456",
},
{
columnKey: "Name",
columnHeader: "Name",
content: "LDT Flu Test",
},
{
columnKey: "CodingSystem",
columnHeader: "Coding system",
content:
"LOCAL",
},
],
[
{
columnKey: "Code",
columnHeader: "Code",
content: "47457-7",
},
{
columnKey: "Name",
columnHeader: "Name",
content: "Influenza virus A H8 Ab [Titer] in Serum",
},
{
columnKey: "CodingSystem",
columnHeader: "Coding system",
content:
"LOINC",
},
],
[
{
columnKey: "Code",
columnHeader: "Code",
content: "115329001",
},
{
columnKey: "Name",
columnHeader: "Name",
content: "Methicillin resistant Staphylococcus aureus",
},
{
columnKey: "CodingSystem",
columnHeader: "Coding system",
content: "SNOMEDCT",
},
],
]
---

import { Table } from "../../../../shared";
import site from "../../../site.json";


Download our <A href={site.assets.codeMapTemplate.path}>template</A> that provides detailed instructions and correctly formatted columns.

If you do not want to use the template, you can also create your own file. The CSV file should only contain three columns labeled: Code, Name, and Coding system as shown in the example below.

<Table borderless rowData={frontmatter.tableContent} />
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
Enter all result codes your organization will use to send data through ReportStream.

In column A (**Code**): Enter the coded value for all performed test results. This should be the value sent in `OBX-3.1` in an HL7 Message or `Bundle.entry.resource.ofType(Observation).code.coding.code` of a FHIR Observation resource.

In column B (**Name**): Enter the textual description of the code in column A. If the value in column A is a LOINC code, use the LOINC Long Common Name. If the value in column A is a local code, use a descriptive result name.

In column C (**Coding system**): Enter `LOINC` if the value in column A is a LOINC code. Enter `LOCAL` if the value is a local code.
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
Input all codes for organisms that your organization will send through ReportStream. If you are not sending any reportable microbiological culture results, you can move on to Step 2.4.

In column A (**Code**): Enter the coded value for all potential reportable organisms. This should be the value sent in `OBX-5.1` in an HL7 Message or `Bundle.entry.resource.ofType(Observation).value CodableConcept.cod` of a FHIR Observation resource.

In column B (**Name**): Enter the textual description of the code in column A. If the value in column A is a SNOMED code, use the SNOMED description. If the value in column A is a local code, use a descriptive result name.

In column C (**Coding system**): Enter `SNOMEDCT` if the value in column A is a SNOMED code. Enter `LOCAL` if the value is a local code.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import site from "../../../site.json";

After completing the mapping file, export the column headers and filled rows as a CSV file. Send the generated CSV your onboarding engineer or <A href={site.orgs.RS.email}>[email protected]</A>. We will review your codes and provide next steps to continue your onboarding.
3 changes: 3 additions & 0 deletions frontend-react/src/content/site.json
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,9 @@
},
"onePager": {
"path": "/assets/pdf/ReportStream_Onepager_20240605.pdf"
},
"codeMapTemplate": {
"path": "/assets/xlsm/20241204_ReportStream-Mapping-Template.xlsm"
}
},
"external": {
Expand Down
Loading