[628] | 1 | RGFIPM1 ;ALB/CJM-PROCESS FACILITY INTEGRATION MESSAGE ;08/27/99
|
---|
| 2 | ;;1.0;CLINICAL INFO RESOURCE NETWORK;**5,9**;30 Apr 99
|
---|
| 3 | ;
|
---|
| 4 | RECEIVE ;
|
---|
| 5 | ;Description: Process the Facility Integration Message
|
---|
| 6 | ;
|
---|
| 7 | ;Input:
|
---|
| 8 | ; HL7 variables must be defined
|
---|
| 9 | ;Output: none
|
---|
| 10 | ;Variables:
|
---|
| 11 | ; LEGACY - station # of legacy site
|
---|
| 12 | ; PRIMARY - station # of primary site
|
---|
| 13 | ; ICN - patient ICN from message
|
---|
| 14 | ; CHECKSUM - ICN checksum from message
|
---|
| 15 | ; CMOR - station # of CMOR
|
---|
| 16 | ; CMORIEN - ien of CMOR in Institution file
|
---|
| 17 | ; HERE - ien in Institution file of site this routine is executing on
|
---|
| 18 | ; HERE("STATION#") - station number of this site
|
---|
| 19 | ; FROM - station # of sending site
|
---|
| 20 | ; DFN - ien from the patient file
|
---|
| 21 | ; HLERR - error encountered
|
---|
| 22 | ; LCHKSUM - local checksum
|
---|
| 23 | ;
|
---|
| 24 | N CMOR,CMORIEN,LEGACY,PRIMARY,ICN,FROM,HERE,DFN,CHECKSUM,LCHKSUM
|
---|
| 25 | K HLERR
|
---|
| 26 | D
|
---|
| 27 | .I '$$PARSE(0,.LEGACY,.PRIMARY,.ICN,.CHECKSUM,.FROM,.HLERR) Q
|
---|
| 28 | .S HERE=$$SITE^VASITE(),HERE("STATION#")=$P(HERE,"^",3),HERE=+HERE
|
---|
| 29 | .S DFN=$$DFN^RGFIU(ICN)
|
---|
| 30 | .I ('DFN)!('$D(^DPT(+DFN))) D Q
|
---|
| 31 | ..S HLERR=$$ERROR("PATIENT LOOKUP BASED ON ICN FAILED",228,ICN)
|
---|
| 32 | .;
|
---|
| 33 | .S LCHKSUM=$P($$GETICN^MPIF001(DFN),"V",2)
|
---|
| 34 | .I (+CHECKSUM)'=(+LCHKSUM) D Q
|
---|
| 35 | ..;If this is a local problem notify the local site
|
---|
| 36 | ..I (+LCHKSUM)'=(+$$CHECKDG^MPIFSPC(ICN)) D
|
---|
| 37 | ...S HLERR=$$ERROR("LOCAL DATABASE HAS INCORRECT ICN CHECKSUM",1,ICN)
|
---|
| 38 | ...D EXC^RGFIU(1,$P(HLERR,"^",2),DFN)
|
---|
| 39 | ..E D
|
---|
| 40 | ...S HLERR=$$ERROR("SENT INCORRECT ICN CHECKSUM",1,ICN)
|
---|
| 41 | .;
|
---|
| 42 | .S CMORIEN=$P($$MPINODE^RGFIU(DFN),"^",3)
|
---|
| 43 | .S CMOR=$$STATNUM^RGFIU(CMORIEN)
|
---|
| 44 | .;
|
---|
| 45 | .;Notify site if there is no station number for CMOR
|
---|
| 46 | .I 'CMOR D EXC^RGFIU(221,"ERROR ENCOUNTERED WHILE PROCESSING FACILITY INTEGRATION MESSAGE",DFN)
|
---|
| 47 | .;
|
---|
| 48 | .;If this is the legacy site it does not need to process this message
|
---|
| 49 | .Q:(HERE("STATION#")=LEGACY)
|
---|
| 50 | .;
|
---|
| 51 | .;If this site is the CMOR, it should only be receiving this message
|
---|
| 52 | .;from the legacy site
|
---|
| 53 | .I (CMORIEN=HERE),(FROM'=LEGACY) D Q
|
---|
| 54 | ..S HLERR=$$ERROR("SITE INTEGRATION MSG TO CMOR NOT FROM LEGACY SITE",230,ICN)
|
---|
| 55 | .;
|
---|
| 56 | .;If this site is not the CMOR, the message must be from the CMOR
|
---|
| 57 | .I CMORIEN,HERE'=CMORIEN,FROM'=CMOR D Q
|
---|
| 58 | ..S HLERR=$$ERROR("SITE INTEGRATION MSG NOT FROM CMOR, CMOR IS "_CMOR,226,ICN)
|
---|
| 59 | .;
|
---|
| 60 | .;update database
|
---|
| 61 | .I '$$XCHANGE^RGFIPM(DFN,LEGACY,PRIMARY) ;local exceptins are logged by $$XCHANGE if errors are encountered
|
---|
| 62 | .;
|
---|
| 63 | .;at this point the receiving application has decided that it can accept the message. An AA will be returned to the sender.
|
---|
| 64 | .;
|
---|
| 65 | .I '$D(HLERR),$G(HL("APAT"))="AL" D ACK(FROM,.HLERR)
|
---|
| 66 | .;
|
---|
| 67 | .;if this is the CMOR, notify subscribers & MPI of the site integration
|
---|
| 68 | .I CMORIEN=HERE,'$$SEND^RGFIBM(DFN,LEGACY,PRIMARY) ;local exceptions are logged by $$SEND if errors are encountered
|
---|
| 69 | ;
|
---|
| 70 | I $D(HLERR),$G(HL("APAT"))="AL" D ACK(FROM,.HLERR)
|
---|
| 71 | D:$G(RGLOG) STOP^RGHLLOG(1)
|
---|
| 72 | Q
|
---|
| 73 | ;
|
---|
| 74 | ACK(FROM,HLERR) ;
|
---|
| 75 | ;Description: Send an acknowledment
|
---|
| 76 | ;
|
---|
| 77 | ;Input:
|
---|
| 78 | ; FROM - station number of site that sent the original message
|
---|
| 79 | ; HLERR - error to be returned in format <exception code>^<error text>
|
---|
| 80 | ; HL7 variables - assumed defined
|
---|
| 81 | ;
|
---|
| 82 | N RESULT,HLA,FS,CS,HLL,TOLINK
|
---|
| 83 | S TOLINK=$$GETLINK^RGFIU($$LKUP^XUAF4(FROM))
|
---|
| 84 | S HLL("LINKS",1)="RG FACILITY INTEGRATION CLIENT^"_TOLINK
|
---|
| 85 | S FS=HL("FS"),CS=$E(HL("ECH"),1)
|
---|
| 86 | I $D(HLERR) D
|
---|
| 87 | .;return NAK
|
---|
| 88 | .S HLA("HLA",1)="MSA"_FS_"ER"_FS_HL("MID")_FS_$P($G(HLERR),";;",2)_FS_FS_FS_CS_CS_CS_$P($G(HLERR),";;")
|
---|
| 89 | E D
|
---|
| 90 | .;return ACK
|
---|
| 91 | .S HLA("HLA",1)="MSA"_FS_"AA"_FS_HL("MID")
|
---|
| 92 | D GENACK^HLMA1(HL("EID"),HLMTIENS,HL("EIDS"),"LM",1,.RESULT)
|
---|
| 93 | Q
|
---|
| 94 | ;
|
---|
| 95 | PARSE(SKIPMSH,LEGACY,PRIMARY,ICN,CHECKSUM,FROM,HLERR) ;
|
---|
| 96 | ;Description: Parses the message and returns parameters.
|
---|
| 97 | ;Input:
|
---|
| 98 | ; SKIPMSH - (optional) if set to 1, means that the MSH segment is
|
---|
| 99 | ; not expected to exist. This is the case when the
|
---|
| 100 | ; routing logic is called.
|
---|
| 101 | ; HL7 variables must be defined (assumed)
|
---|
| 102 | ;Output:
|
---|
| 103 | ; Function Value: 1 on success, 0 on failure
|
---|
| 104 | ; LEGACY - station # of legacy site (pass by reference)
|
---|
| 105 | ; PRIMARY - station # of primary site (pass by reference)
|
---|
| 106 | ; ICN - ICN of patient (pass by reference)
|
---|
| 107 | ; CHECKSUM - ICN checksum (pass by reference)
|
---|
| 108 | ; FROM - station # of sendign site (pass by reference)
|
---|
| 109 | ; HLERR - returns a message if an error is encountered (pass by reference)
|
---|
| 110 | ;
|
---|
| 111 | ;Variables:
|
---|
| 112 | ; FS - field seperator
|
---|
| 113 | ; CS - component seperator
|
---|
| 114 | ; ERRFLAG - initially set to 1, set to 0 if message passes all checks
|
---|
| 115 | ;
|
---|
| 116 | N FS,CS,ERRFLAG
|
---|
| 117 | S FS=HL("FS")
|
---|
| 118 | S CS=$E(HL("ECH"),1)
|
---|
| 119 | S ERRFLAG=1
|
---|
| 120 | S (LEGACY,PRIMARY,ICN,CHECKSUM,FROM)=""
|
---|
| 121 | K HLERR
|
---|
| 122 | ;
|
---|
| 123 | D
|
---|
| 124 | .D:'$G(SKIPMSH) Q:$D(HLERR)
|
---|
| 125 | ..X HLNEXT I (HLQUIT'>0) S HLERR=$$SEGERROR("MSH") Q
|
---|
| 126 | ..I $P(HLNODE,FS)'["MSH" S HLERR=$$SEGERROR("MSH") Q
|
---|
| 127 | ..S FROM=$P($P(HLNODE,FS,4),CS)
|
---|
| 128 | ..I 'FROM S HLERR=$$ERROR("MISSING STATION NUMBER IN MSH SEGMENT FOR SENDING SITE",11) Q
|
---|
| 129 | .;
|
---|
| 130 | .X HLNEXT I (HLQUIT'>0) S HLERR=$$SEGERROR("EVN") Q
|
---|
| 131 | .I $P(HLNODE,FS)'["EVN" D Q:$D(HLERR)
|
---|
| 132 | ..I $G(SKIPMSH) X HLNEXT
|
---|
| 133 | ..I $P(HLNODE,FS)'["EVN" S HLERR=$$SEGERROR("EVN") Q
|
---|
| 134 | .I $P(HLNODE,FS,5)'=51 S HLERR=$$ERROR("EVENT REASON CODE NOT 51",9) Q
|
---|
| 135 | .;
|
---|
| 136 | .X HLNEXT I (HLQUIT'>0) S HLERR=$$SEGERROR("PID") Q
|
---|
| 137 | .I $P(HLNODE,FS)'["PID" S HLERR=$$SEGERROR("PID") Q
|
---|
| 138 | .S ICN=$P($P(HLNODE,FS,3),"V")
|
---|
| 139 | .I 'ICN D Q
|
---|
| 140 | ..S HLERR=$$ERROR("MISSING ICN IN PID SEGMENT",10)
|
---|
| 141 | .S CHECKSUM=$P($P(HLNODE,FS,3),"V",2)
|
---|
| 142 | .;
|
---|
| 143 | .X HLNEXT I (HLQUIT'>0) S HLERR=$$SEGERROR("PV1",ICN) Q
|
---|
| 144 | .I $P(HLNODE,FS)'["PV1" S HLERR=$$SEGERROR("PV1",ICN) Q
|
---|
| 145 | .;
|
---|
| 146 | .X HLNEXT I (HLQUIT'>0) S HLERR=$$SEGERROR("NTE",ICN) Q
|
---|
| 147 | .I $P(HLNODE,FS)'["NTE" S HLERR=$$SEGERROR("NTE",ICN) Q
|
---|
| 148 | .S LEGACY=$P($P(HLNODE,FS,4),CS)
|
---|
| 149 | .I 'LEGACY S HLERR=$$ERROR("MISSING LEGACY STATION # IN NTE SEGMENT",8,ICN) Q
|
---|
| 150 | .S PRIMARY=$P($P(HLNODE,FS,4),CS,2)
|
---|
| 151 | .I 'PRIMARY S HLERR=$$ERROR("MISSING PRIMARY STATION # IN NTE SEGMENT",8,ICN) Q
|
---|
| 152 | .S ERRFLAG=0
|
---|
| 153 | Q 'ERRFLAG
|
---|
| 154 | ;
|
---|
| 155 | ERROR(ERRMSG,CODE,ICN) ;
|
---|
| 156 | ;Description: formats ERRMSG in format <exception type>;;<error text>
|
---|
| 157 | ;Input:
|
---|
| 158 | ; ERRMSG - text to incorporate into message
|
---|
| 159 | ; CODE - Exception Type
|
---|
| 160 | ; ICN - patient ICN
|
---|
| 161 | ;
|
---|
| 162 | ;
|
---|
| 163 | Q $G(CODE)_";;"_" From Station:"_$P($$SITE^VASITE(),"^",3)_" ICN:"_$G(ICN)_" Code:"_$G(CODE)_" Msg:"_$G(ERRMSG)
|
---|
| 164 | ;
|
---|
| 165 | ;
|
---|
| 166 | SEGERROR(SEGMENT,ICN) ;
|
---|
| 167 | ;Description: formats error if expected segment not there
|
---|
| 168 | S ERRMSG="MISSING SEGMENT: "_SEGMENT
|
---|
| 169 | Q $$ERROR(ERRMSG,7,$G(ICN))
|
---|