/
Stanlab2x Specifications

Stanlab2x Specifications

Here you will find information on the Danish Regions use of Stanlab 2x API for Laboratory requisition and reporting. The information is relevant for laboratories implementing Stanlab 2x for use in Danish regions.

For generel information about inplementing Stanlab, see https://github.com/danmarksmiljoeportal/stanlab

and the swagger definitions on https://stanlab-api.miljoeportal.dk/openapi/

date

changes

by

date

changes

by

2024-05-08

includes description of what results must be included when laboratory submits analysisresults

Tom Birch Hansen

 

 

 

 

 

 

Submit/Pull requisitions:

https://stanlab-api.miljoeportal.dk/openapi/#operation/SubmitRequisition :

One requisition contains info for only one sample.

Field

Information

Examples

Field

Information

Examples

Contact:

The contact information for the person who is responsible for the requisition. Will in many cases be the same as the reqestor.
Useful for the laboratory if there are unanswered questions about the requisition/sample.

The order-confirmation by the laboratory should be sent to this contact.

 

SamplingContact

Contact info of the person who undertook the sampling.

 

OrderReference

Our reference to be used on the invoice. Will contain our ‘lokalitetsnummer' and ‘lokalitetsnavn’ and possible also the consultants own case-number. The lab must use this field-value for accumulating multiple requisitions/orders to a single invoice, and for placing this information on the electronic invoice.

711-1112 Østergade 11 (sag 23233)

OrderLineReference

info to go on the invoice for the individual requisition.

B1 2,0-4,0 m.u.t.

B2 (dgu 22.1234) indtag 1

Personreference

personreference to go on the electronic invoice.

this field is only relevant if the billingaccount does not contain individual persons (see billingaccounts).

When the Vanda system is used, this field is never filled. In stead the person is defined in the billingaccount.

 

tomhan@rm.dk

tomhan

 

Contracts

Contains info on the billing accounts and available packages and package-parameters.

https://stanlab-api.miljoeportal.dk/openapi/#tag/Contract

Field

Information

Example

Field

Information

Example

BillingAccount

contains info in the billing account (EAN number reference, and possible person-reference).

The ‘reference’ is the laboratorys reference to the billingaccount.

 

There are two possible implementations of this:

  1. One billing account for each region (where the individual person-reference is found in personreference field), or

  2. One billing account for each person in each region.

When the Vanda system is used for requisition, the option 2 must be used, as ‘Vanda' does not fill in personreference value.

 

The ‘name’ field is used by the requisition-system to select the right account, therefore it must contain a precise and readable value.e

 

{
"name": "Tom Hansen",
"reference": "XYZ_DK_BA-53",
"description": "CVR-P 99990925 EAN 9998002763525"
}

Packages - name

This field is used by the requisition-system to select the right packages. Therefore it must have an easily readable value.

The value should not be more than 60 characters long. Any characters beyond 60 characters are unlikely to be visible in the UI.

The value should preferable also contain the labs packagenumber in parenteses.

(ABC123) BTEXN og chl. opl. midler m. nedbr.

 

Sample status

The laboratory must report the status of the requisition as the order is processed at the laboratory.

This is achieved using the following four post-calls, where the id is the requisition-id :

https://stanlab-api.miljoeportal.dk/openapi/#operation/ConfirmRequisition (where the laboratoryTestReference is labs internal unique id for the requisition (not sampleId)

https://stanlab-api.miljoeportal.dk/openapi/#operation/NotifySampleRegistered (when the sample is recieved by the lab)

https://stanlab-api.miljoeportal.dk/openapi/#operation/NotifyAnalysisStarted

https://stanlab-api.miljoeportal.dk/openapi/#operation/NotifyAnalysisFinished

There is currently no way to report that the sample is too old for analysis or that is has been discarded.

Submit laboratory results

https://stanlab-api.miljoeportal.dk/openapi/#operation/SubmitLaboratoryTest

Important!

When submitting results, the ‘reference' must be a unique identifer for the requisition. The ‘reference’ IS NOT the samples idefication number. For instance, if multiple requisitions have been sent for the same sample, the reference-number will be different for each requisition.

 

The laboratory results submitted must only contain the results for what was orderen in the requisition. For example; When first a user request PID analysis and later a user requests BTEX analysis on the same sample, the the laboratory must give the PID result for the response of the first requisition (usinge the labs reference for the first requisition), and the BTEX results as response of the second requistion (using the labs reference for the second requisition).

The submit laboratory test resultat (and delete laboratory results) may be rejected by the endpoint system (GeoGIS/Vanda) if the sample has been fully accepted (by a user or system).

 

For the individual analysis (array) the laboratory performing the individual analysis can be specified as text. Preferably with added parentheses with laboratory number from the Stancode codelist 1025 found at https://dce.au.dk/overvaagning/stancode/stancodelister for instance: Laboratory : “AnalysisLab AB (123)“

Get Sample

To get information like sampledate, sampled by, sample site name, field measurements ect, the get-sample must be used:

https://stanlab-api.miljoeportal.dk/openapi/#operation/GetSample

field

info

examples

field

info

examples

label

the label used for the sample by the requisition system. The default text is the samplesitename including DGU nummer, intakeno and depth.

B1-1 (88.1232)

B2 (2,0-2,1 m.u.t.)

IL5

IL5(2)

OBL1 (0,2 m.u.t)

observation-facility-name

a destriptive name of the specific samplesite (for instance a borehole intake or soil sample site)

B1-1 (88.1232)

B2

PL5

OBL1

 

observations

can contain observational info on a sample (for instance colour). Currently we are not implementing this in GeoGIS

 

measurements

contains field measurements for the sample like pH, air-volumen, redox ect. All codevalues are Stancode values.

"measurements": [
{
"parameter": 13,
"unit": 0,
"method": 0,
"accredited": false,
"time": "2019-01-29T12:20:00+01:00",
"attribute": 0,
"value": 8.0,
"performer": "JDB"
}
],

location

751-23232

The site-locationnumber (projectno) from GeoGIS.

For the Vanda system this field will be empty.

For the Vanda system, the ‘get-sample’ is very limited in what is exposed. No observations, measurements, sampler or label is supplied.

Requestor

Information on the requestor (rekvirent) isn’t currently availabe in the get-sample call.

You can get the requestor’s name (but not phone or email) by using a graphQL call:

{requisitions (sampleId:"94599a76-d2f3-4f20-8432-b2743670a949"){requisitionId,sample{sampleId}user{name}} }

Other

The following api calls are not implementet for the regions systems (GeoGIS and Vanda):

  • submit sample

  • delete sample

Order confirmation emails

For the lab to send order confirmation, use the following api calls:

email to sent orderconfirmation to:

requisition: Contact>email

sample overall location info :

requisition: orderReference

Sampleinfo for the sample:

requisition: orderReferenceLine

Sampledate:

get sample: sampling>samplingEnded

Packages:

requisition>packages

Invoicing:

invoicing should be bundled pr location pr ? weeks. This can be done by bundling by the value of the requisition>‘orderReference’ field.

The invoicing billing account can be found on the requisition>billingaccount

The invoicing person-reference can be found in the requisition>personreference field, or alternatively indirectly by a person specific billing-account.

The values from orderReference should go on the header of the invoice, and requisition>orderReferenceLine should go on the individual sample-requisitions.

Sampledata can be found from get sample: sampling>samplingEnded

Sampler-info: requisition>samplingcontact

PDF/Excel analysisreport:

(not relevant for Vanda)

Field measurements from get-sample>FieldMeasurements

Sampler: requisition>samplingContact>name

Samplingdate:get-sample>samplingEnded

Samplelocation: sample->location

Samplesite (pointno, DGU, intake, depth ect): sample->observationfacility>Name

Sampleno/label: sample>label

Submit to: requisition>contact>Email

 

Related content