001package ca.cdr.api.pub.hl7v2.out; 002 003/*- 004 * #%L 005 * Smile CDR - CDR 006 * %% 007 * Copyright (C) 2016 - 2025 Smile CDR, Inc. 008 * %% 009 * All rights reserved. 010 * #L% 011 */ 012 013import ca.uhn.hl7v2.HL7Exception; 014import ca.uhn.hl7v2.model.Message; 015import ca.uhn.hl7v2.model.v25.message.*; 016import ca.uhn.hl7v2.model.v25.segment.*; 017import jakarta.annotation.Nonnull; 018import jakarta.annotation.Nullable; 019import org.hl7.fhir.instance.model.api.IBaseResource; 020import org.hl7.fhir.r4.model.*; 021 022/** 023 * This service is used to generate and populate HL7 v2.x outbound (from Smile CDR) messages using 024 * information from FHIR resources as the source of data. 025 * <p> 026 * To create a new HL7 v2.x message to transmit, the first call should be to 027 * {@link #newTarget(String, String, Class)}. You can then use methods such as 028 * {@link #populateMessageAdtA01FromEncounter(IBaseResource, MappingTarget, OutboundMappingInstructions)} 029 * to populate the entire message according to Smile CDR's mapping rules, or use 030 * individual segment methods such as {@link #populateSegmentPidFromPatient(Patient, Encounter, PID, MappingTarget, OutboundMappingInstructions)} 031 * to populate individual segments. You can also simply populate the message yourself. 032 * </p> 033 */ 034public interface IHl7V2OutboundMapperSvc { 035 036 /** 037 * Create a new {@link MappingTarget} with a target {@link Message} instance that is appropriate for the 038 * given {@literal theMessageCode} and {@literal theMessageTrigger} values. The MSH segment in the message 039 * is populated with initial values (which may subsequently be modified if needed), but no other segments 040 * are populated. 041 * 042 * @param theMessageCode The message code, e.g. <code>ADT</code> 043 * @param theMessageTrigger The message trigger, e.h. <code>A01</code> 044 * @param theStructureType The HAPI-HL7v2 type class corresponding to the given code and trigger. Note that these 045 * will often agree (e.g. Code/Type of "ADT"/"A01" should use a structure type of 046 * {@link ADT_A01 ADT_A01.class}) but there are also many cases in the HL7 v2.x 047 * specification where a structure type gets used for multiple triggers (e.g. Code/Type of 048 * "ADT"/"A31" uses the structure type of {@link ADT_A05 ADT_A05.class}). At this time, an 049 * HL7 v2.5 structure class must be used. 050 * @throws IllegalArgumentException If {@literal theStructureType} is inappropriate for the given 051 * {@literal theMessageCode} and {@literal theMessageTrigger} values. 052 */ 053 <T extends Message> MappingTarget<T> newTarget( 054 @Nonnull String theMessageCode, @Nonnull String theMessageTrigger, @Nonnull Class<T> theStructureType) 055 throws IllegalArgumentException; 056 057 /** 058 * Populate a complete DFT_P03 structure using a ChargeItem resource as the focal resource. This can be 059 * used to create messages of type DFT^P03. 060 * <p> 061 * This method attempts to populate the entire message structure using values from the focal 062 * resource as well as from other resources that are referenced directly or indirectly from the 063 * focal resource. 064 * </p> 065 * 066 * @param theMappingTarget Should contain message of type {@link DFT_P03} 067 */ 068 void populateMessageDftP03FromChargeItem( 069 @Nonnull IBaseResource theFocalChargeItem, 070 @Nonnull MappingTarget<DFT_P03> theMappingTarget, 071 OutboundMappingInstructions theOutboundMappingInstructions); 072 073 /** 074 * Populate a complete ORU_R01 structure using a DiagnosticReport resource as the focal resource. This can be 075 * used to create messages of type ORU^R01 076 * <p> 077 * This method attempts to populate the entire message structure using values from the focal 078 * resource as well as from other resources that are referenced directly or indirectly from the 079 * focal resource. 080 * </p> 081 * 082 * @param theMappingTarget Should contain message of type {@link ORU_R01} 083 */ 084 void populateMessageOruR01FromDiagnosticReport( 085 @Nonnull IBaseResource theFocalDiagnosticReport, 086 @Nonnull MappingTarget<ORU_R01> theMappingTarget, 087 OutboundMappingInstructions theOutboundMappingInstructions); 088 089 /** 090 * Populate a complete ADT_A01 structure using an Encounter resource as the focal resource. This can be 091 * used to create messages of type ADT^A01, ADT^A04 092 * <p> 093 * This method attempts to populate the entire message structure using values from the focal 094 * resource as well as from other resources that are referenced directly or indirectly from the 095 * focal resource. 096 * </p> 097 * 098 * @param theMappingTarget Should contain message of type {@link ADT_A01} 099 */ 100 void populateMessageAdtA01FromEncounter( 101 @Nonnull IBaseResource theFocalEncounter, 102 @Nonnull MappingTarget<ADT_A01> theMappingTarget, 103 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 104 throws HL7Exception; 105 106 /** 107 * Populate a complete ADT_A02 structure using an Encounter resource as the focal resource. This can be 108 * used to create messages of type ADT^A02 109 * <p> 110 * This method attempts to populate the entire message structure using values from the focal 111 * resource as well as from other resources that are referenced directly or indirectly from the 112 * focal resource. 113 * </p> 114 * 115 * @param theMappingTarget Should contain message of type {@link ADT_A02} 116 */ 117 void populateMessageAdtA02FromEncounter( 118 @Nonnull IBaseResource theFocalEncounter, 119 @Nonnull MappingTarget<ADT_A02> theMappingTarget, 120 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 121 throws HL7Exception; 122 123 /** 124 * Populate a complete ADT_A03 structure using an Encounter resource as the focal resource. This can be 125 * used to create messages of type ADT^A03 126 * <p> 127 * This method attempts to populate the entire message structure using values from the focal 128 * resource as well as from other resources that are referenced directly or indirectly from the 129 * focal resource. 130 * </p> 131 * 132 * @param theMappingTarget Should contain message of type {@link ADT_A03} 133 */ 134 void populateMessageAdtA03FromEncounter( 135 @Nonnull IBaseResource theFocalEncounter, 136 @Nonnull MappingTarget<ADT_A03> theMappingTarget, 137 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 138 throws HL7Exception; 139 140 /** 141 * Populate a complete ADT_A05 structure using a Patient resource as the focal resource. This can be 142 * used to create messages of type ADT^A28, ADT^A31 143 * <p> 144 * This method attempts to populate the entire message structure using values from the focal 145 * resource as well as from other resources that are referenced directly or indirectly from the 146 * focal resource. 147 * </p> 148 * 149 * @param theFocalPatient A Patient resource to use as the focal resource 150 * @param theMappingTarget Should contain message of type {@link ADT_A05} 151 */ 152 void populateMessageAdtA05FromPatient( 153 @Nonnull IBaseResource theFocalPatient, 154 @Nonnull MappingTarget<ADT_A05> theMappingTarget, 155 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 156 157 /** 158 * Populate a complete ADT_A05 structure using an Encounter resource as the focal resource. This can be 159 * used to create messages of type ADT^A05, ADT^A08 160 * <p> 161 * This method attempts to populate the entire message structure using values from the focal 162 * resource as well as from other resources that are referenced directly or indirectly from the 163 * focal resource. 164 * </p> 165 * 166 * @param theFocalEncounter An Encounter resource to use as the focal resource 167 * @param theMappingTarget Should contain message of type {@link ADT_A05} 168 */ 169 void populateMessageAdtA05FromEncounter( 170 @Nonnull IBaseResource theFocalEncounter, 171 @Nonnull MappingTarget<ADT_A05> theMappingTarget, 172 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 173 throws HL7Exception; 174 175 /** 176 * Populate a complete OMG_O19 structure using a ServiceRequest resource (R4+) or a ProcedureRequest resource (DSTU3) 177 * as the focal resource. This can be used to create messages of type OMG^O19. 178 * <p> 179 * This method attempts to populate the entire message structure using values from the focal 180 * resource as well as from other resources that are referenced directly or indirectly from the 181 * focal resource. 182 * </p> 183 * 184 * @param theMappingTarget Should contain message of type {@link OMG_O19} 185 */ 186 void populateMessageOmgO19FromServiceRequest( 187 @Nonnull IBaseResource theFocalServiceRequest, 188 @Nonnull MappingTarget<OMG_O19> theMappingTarget, 189 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 190 throws HL7Exception; 191 192 /** 193 * Populate a complete ORM_O01 structure using a ServiceRequest resource (R4+) or a ProcedureRequest resource (DSTU3) 194 * as the focal resource. This can be used to create messages of type ORM^O01. 195 * <p> 196 * This method attempts to populate the entire message structure using values from the focal 197 * resource as well as from other resources that are referenced directly or indirectly from the 198 * focal resource. 199 * </p> 200 * 201 * @param theMappingTarget Should contain message of type {@link ORM_O01} 202 */ 203 void populateMessageOrmO01FromServiceRequest( 204 @Nonnull IBaseResource theFocalServiceRequest, 205 @Nonnull MappingTarget<ORM_O01> theMappingTarget, 206 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions) 207 throws HL7Exception; 208 209 /** 210 * Populate a complete ORU_R01 structure using a ServiceRequest resource (R4+) or a ProcedureRequest resource (DSTU3) 211 * as the focal resource. This can be used to create messages of type ORU^R01. 212 * <p> 213 * This method attempts to populate the entire message structure using values from the focal 214 * resource as well as from other resources that are referenced directly or indirectly from the 215 * focal resource. 216 * </p> 217 * 218 * @param theMappingTarget Should contain message of type {@link ORU_R01} 219 */ 220 void populateMessageOruR01FromServiceRequest( 221 @Nonnull IBaseResource theFocalServiceRequest, 222 @Nonnull MappingTarget<ORU_R01> theMappingTarget, 223 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 224 225 /** 226 * Populates an ROL segment using a single {@literal Encounter.participant} instance. 227 * Because {@literal Encounter.participant} is a repeating field, an index must also 228 * be passed in. 229 * 230 * @param theEncounter The source Encounter to draw values from. 231 * @param theEncounterParticipantIndex The index of the {@literal Encounter.participant} repetition to draw values from (0-indexed). 232 * @param theRol The ROL segment to populate. 233 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 234 * a part of the mapping. 235 */ 236 void populateSegmentRolFromEncounterParticipant( 237 @Nonnull Encounter theEncounter, 238 int theEncounterParticipantIndex, 239 @Nonnull ROL theRol, 240 @Nonnull MappingTarget<?> theMappingTarget, 241 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 242 243 /** 244 * Populates an AL1 segment using values from an AllergyIntolerance resource instance. 245 * 246 * @param theAllergyIntolerance The source Coverage to draw values from. 247 * @param theSetId The set ID to populate in AL1-1, or {@literal null}. 248 * @param theAl1 The AL1 segment to populate 249 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 250 * a part of the mapping. 251 */ 252 void populateSegmentAl1FromAllergyIntolerance( 253 @Nonnull AllergyIntolerance theAllergyIntolerance, 254 @Nullable Integer theSetId, 255 @Nonnull AL1 theAl1, 256 @Nonnull MappingTarget<?> theMappingTarget, 257 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 258 259 /** 260 * Populates a pair of IN1 and IN2 segments using values from a Coverage resource instance. 261 * 262 * @param theCoverage The source Coverage to draw values from. 263 * @param theIn1 The IN1 segment to populate 264 * @param theIn2 The IN2 segment to populate 265 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 266 * a part of the mapping. 267 */ 268 void populateSegmentIn1In2FromInsurance( 269 Coverage theCoverage, 270 IN1 theIn1, 271 IN2 theIn2, 272 MappingTarget<?> theMappingTarget, 273 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 274 275 /** 276 * Populates a PR1 segment using values from a Procedure resource instance. 277 * 278 * @param theProcedure The source Procedure to draw values from. 279 * @param thePr1 The PR1 segment to populate 280 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 281 * a part of the mapping. 282 */ 283 void populateSegmentPr1FromProcedure( 284 Procedure theProcedure, 285 PR1 thePr1, 286 MappingTarget<?> theMappingTarget, 287 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 288 289 /** 290 * Populates an NK1 segment using a single {@literal Patient.contact} instance. 291 * Because {@literal Patient.context} is a repeating field, an index must also 292 * be passed in. 293 * 294 * @param theEncounter The source Encounter to draw values from. 295 * @param theEncounterConditionIndex The index of the {@literal Encounter.condition} repetition to draw values from (0-indexed). 296 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 297 * a part of the mapping. 298 * @param theDg1 The DG1 segment to populate. 299 */ 300 void populateSegmentDg1FromEncounterCondition( 301 Encounter theEncounter, 302 int theEncounterConditionIndex, 303 DG1 theDg1, 304 MappingTarget<?> theMappingTarget, 305 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 306 307 /** 308 * Populates an NK1 segment using a single {@literal Patient.contact} instance. 309 * Because {@literal Patient.context} is a repeating field, an index must also 310 * be passed in. 311 * 312 * @param thePatient The source Patient to draw values from. 313 * @param thePatientContactIndex The index of the {@literal Patient.contact} repetition to draw values from (0-indexed). 314 * @param theNk1 The NK1 segment to populate. 315 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 316 * a part of the mapping. 317 */ 318 void populateSegmentNk1FromPatientContact( 319 @Nonnull Patient thePatient, 320 int thePatientContactIndex, 321 @Nonnull NK1 theNk1, 322 @Nonnull MappingTarget<?> theMappingTarget, 323 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 324 325 /** 326 * Populates a PID segment using information from a Patient resource and optionally an Encounter resource. 327 * 328 * @param theSubject The subject patient. 329 * @param theEncounterOrNull The focal encounter, or {@literal null}. 330 * @param thePid The PID segment to populate. 331 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 332 * a part of the mapping. 333 */ 334 void populateSegmentPidFromPatient( 335 @Nonnull Patient theSubject, 336 @Nullable Encounter theEncounterOrNull, 337 @Nonnull PID thePid, 338 @Nonnull MappingTarget<?> theMappingTarget, 339 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 340 341 /** 342 * Populates a PD1 segment using information from a Patient resource. 343 * 344 * @param theSubject The subject patient. 345 * @param thePd1 The PD1 segment to populate. 346 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 347 * a part of the mapping. 348 */ 349 void populateSegmentPd1FromPatient( 350 @Nonnull Patient theSubject, 351 @Nonnull PD1 thePd1, 352 @Nonnull MappingTarget<?> theMappingTarget, 353 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 354 355 /** 356 * Populates a PV1 segment using information from an Encounter resource. 357 * 358 * @param theEncounter The encounter resource. 359 * @param thePv1 The PV1 segment to populate. 360 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 361 * a part of the mapping. 362 */ 363 void populateSegmentPv1FromEncounter( 364 @Nonnull Encounter theEncounter, 365 @Nonnull PV1 thePv1, 366 @Nonnull MappingTarget<?> theMappingTarget, 367 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 368 369 /** 370 * Populates a PV2 segment using information from an Encounter resource. 371 * 372 * @param theEncounter The source Encounter to draw values from. 373 * @param thePv2 The PV2 segment to populate. 374 * @param theMappingTarget The target object. This is only used to store any warnings or errors generated as 375 * a part of the mapping. 376 */ 377 void populateSegmentPv2FromEncounter( 378 @Nonnull Encounter theEncounter, 379 @Nonnull PV2 thePv2, 380 @Nonnull MappingTarget<?> theMappingTarget, 381 @Nonnull OutboundMappingInstructions theOutboundMappingInstructions); 382}