[613] | 1 | ROR11 ;HCIOFO/SG - NIGHTLY TASK UTILITIES ; 12/7/05 9:40am
|
---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
|
---|
| 3 | ;
|
---|
| 4 | ; RORLBLST ------------ LIST OF LATEST HL7 MESSAGES
|
---|
| 5 | ;
|
---|
| 6 | ; RORLBLST(
|
---|
| 7 | ; MsgID, Internal Batch ID
|
---|
| 8 | ; "MS") Message Status (see $$MSGSTAT^HLUTIL)
|
---|
| 9 | ; ^01: Status Code
|
---|
| 10 | ; ^02: Status Updated
|
---|
| 11 | ; ^03: Error Message
|
---|
| 12 | ; ^04: Error Type pointer
|
---|
| 13 | ; ^05: Queue Position or Number of Retries
|
---|
| 14 | ; ^06: Open Failed
|
---|
| 15 | ; ^07: ACK Timeout
|
---|
| 16 | ; "RL",
|
---|
| 17 | ; RegIEN) IENS of the message reference in the
|
---|
| 18 | ; registry parameters (sub-file #798.122)
|
---|
| 19 | ;
|
---|
| 20 | ; "N", Created and used by the NOTIFY^ROR11
|
---|
| 21 | ; EMail,
|
---|
| 22 | ; RegName) RegIEN
|
---|
| 23 | ;
|
---|
| 24 | ; "RM",
|
---|
| 25 | ; RegIEN, ""
|
---|
| 26 | ; MsgID) ""
|
---|
| 27 | ;
|
---|
| 28 | Q
|
---|
| 29 | ;
|
---|
| 30 | ;***** ADDS THE HL7 BATCH MESSAGE TO THE LIST
|
---|
| 31 | ;
|
---|
| 32 | ; MSGID Batch HL7 Message Control ID
|
---|
| 33 | ; IENS IENS of the message reference in the reigstry
|
---|
| 34 | ; parameters (sub-file #798.122)
|
---|
| 35 | ; IBID Internal Batch ID
|
---|
| 36 | ; DATE Date/Time of the batch
|
---|
| 37 | ;
|
---|
| 38 | ADDMSG(MSGID,IENS,IBID,DATE) ;
|
---|
| 39 | N REGIEN S REGIEN=$P(IENS,",",2)
|
---|
| 40 | D:'$D(RORLBLST(MSGID))
|
---|
| 41 | . S RORLBLST(MSGID,"MS")=$$MSGSTAT^HLUTIL(MSGID)
|
---|
| 42 | . S RORLBLST(MSGID,"DT")=DATE
|
---|
| 43 | . S RORLBLST(MSGID)=IBID
|
---|
| 44 | S RORLBLST(MSGID,"RL",REGIEN)=IENS
|
---|
| 45 | S RORLBLST("RM",REGIEN,MSGID)=""
|
---|
| 46 | S RORLBLST("RM",REGIEN)=""
|
---|
| 47 | Q
|
---|
| 48 | ;
|
---|
| 49 | ;***** REMOVES THE HL7 BATCH MESSAGE FROM THE LIST
|
---|
| 50 | ;
|
---|
| 51 | ; MSGID Batch HL7 Message Control ID
|
---|
| 52 | ; [.FDA] Reference to the FDA arrays that will be updated
|
---|
| 53 | ; to remove the references to the message
|
---|
| 54 | ;
|
---|
| 55 | DELMSG(MSGID,FDA) ;
|
---|
| 56 | N IENS,REGIEN S REGIEN=""
|
---|
| 57 | F S REGIEN=$O(RORLBLST(MSGID,"RL",REGIEN)) Q:REGIEN="" D
|
---|
| 58 | . S IENS=$P(RORLBLST(MSGID,"RL",REGIEN),U)
|
---|
| 59 | . S:IENS'="" FDA(798.122,IENS,.01)="@"
|
---|
| 60 | . K RORLBLST("RM",REGIEN,MSGID)
|
---|
| 61 | K RORLBLST(MSGID)
|
---|
| 62 | Q
|
---|
| 63 | ;
|
---|
| 64 | ;***** NOTIFIES THE AAC AND LOCAL COORDINATORS
|
---|
| 65 | NOTIFY() ;
|
---|
| 66 | Q:$D(RORLBLST("RM"))<10
|
---|
| 67 | N ALNOR,EMAIL,IENS,MSGID,NOR,PARAMS,REGIEN,REGNAME,RORBUF,RORMSG,RORTXT,RORXML,TMP
|
---|
| 68 | K RORLBLST("N")
|
---|
| 69 | ;
|
---|
| 70 | ;=== Send local alerts and generate the notification list
|
---|
| 71 | S REGIEN=0
|
---|
| 72 | F S REGIEN=$O(RORLBLST("RM",REGIEN)) Q:REGIEN'>0 D
|
---|
| 73 | . K RORBUF,RORMSG,RORTXT S IENS=REGIEN_","
|
---|
| 74 | . ;--- Load the notification parameters
|
---|
| 75 | . D GETS^DIQ(798.1,IENS,".01;13.2;13.3;19.3",,"RORBUF","RORMSG")
|
---|
| 76 | . I $G(DIERR) D DBS^RORERR("RORMSG",-9,,,798.1,IENS) Q
|
---|
| 77 | . ;--- Check if the notification should be sent
|
---|
| 78 | . S ALNOR=+$G(RORBUF(798.1,IENS,13.2)) ; ALERT FREQUENCY
|
---|
| 79 | . S NOR=+$G(RORBUF(798.1,IENS,19.3)) ; HL7 ATTEMPT COUNTER
|
---|
| 80 | . Q:$S(ALNOR'>0:1,1:NOR#ALNOR)
|
---|
| 81 | . ;---
|
---|
| 82 | . S REGNAME=$G(RORBUF(798.1,IENS,.01)) ; Registry Name
|
---|
| 83 | . S EMAIL=$G(RORBUF(798.1,IENS,13.3)) ; Notification E-mail
|
---|
| 84 | . S PARAMS("REGISTRY")=REGNAME
|
---|
| 85 | . S PARAMS("NOR")=NOR
|
---|
| 86 | . ;--- Error message header
|
---|
| 87 | . D BLD^DIALOG(7980000.023,.PARAMS,,"RORTXT","S")
|
---|
| 88 | . ;--- Append the list of unsent HL7 messages
|
---|
| 89 | . S MSGID=""
|
---|
| 90 | . F S MSGID=$O(RORLBLST("RM",REGIEN,MSGID)) Q:MSGID="" D
|
---|
| 91 | . . S MSGSTAT=RORLBLST(MSGID,"MS")
|
---|
| 92 | . . S RORTXT($O(RORTXT(""),-1)+1)=""
|
---|
| 93 | . . D MSG7STS^RORUTL05(MSGID,.RORTXT,,7980000.004,.PARAMS,MSGSTAT)
|
---|
| 94 | . ;--- Error message footer
|
---|
| 95 | . D BLD^DIALOG(7980000.024,.PARAMS,,"RORTXT")
|
---|
| 96 | . ;--- Record the error message
|
---|
| 97 | . D LOG^RORERR(-67,.RORTXT,,NOR)
|
---|
| 98 | . ;--- Notify local staff
|
---|
| 99 | . S TMP=REGNAME_U_NOR
|
---|
| 100 | . D ALERT^RORUTL01(REGNAME,-67,"ALERT^ROR10",TMP,,NOR)
|
---|
| 101 | . ;--- Update the national notification list
|
---|
| 102 | . D:$$CCRNTFY^RORUTL05(REGIEN)
|
---|
| 103 | . . S:EMAIL'="" RORLBLST("N",EMAIL,REGNAME)=REGIEN
|
---|
| 104 | ;
|
---|
| 105 | ;=== Get station name and number
|
---|
| 106 | S TMP=$$SITE^RORUTL03()
|
---|
| 107 | S PARAMS("STNAME")=$P(TMP,U,2)
|
---|
| 108 | S PARAMS("STNUM")=$P(TMP,U)
|
---|
| 109 | ;
|
---|
| 110 | ;=== Generate notification e-mails
|
---|
| 111 | S EMAIL=""
|
---|
| 112 | F S EMAIL=$O(RORLBLST("N",EMAIL)) Q:EMAIL="" D
|
---|
| 113 | . K RORXML
|
---|
| 114 | . ;--- E-mail header
|
---|
| 115 | . D BLD^DIALOG(7980000.025,.PARAMS,,"RORXML","S")
|
---|
| 116 | . ;--- Process affected registries
|
---|
| 117 | . S REGNAME=""
|
---|
| 118 | . F S REGNAME=$O(RORLBLST("N",EMAIL,REGNAME)) Q:REGNAME="" D
|
---|
| 119 | . . S REGIEN=+RORLBLST("N",EMAIL,REGNAME)
|
---|
| 120 | . . S PARAMS("REGISTRY")=REGNAME
|
---|
| 121 | . . S PARAMS("NOR")=NOR
|
---|
| 122 | . . ;--- Append registry section
|
---|
| 123 | . . D NTFXML("<REGISTRY>")
|
---|
| 124 | . . D NTFXML("<NAME>"_REGNAME_"</NAME>")
|
---|
| 125 | . . S TMP=$P($$REGNAME^RORUTL01(REGIEN),U,2)
|
---|
| 126 | . . D NTFXML("<DESCRIPTION>"_TMP_"</DESCRIPTION>")
|
---|
| 127 | . . ;--- Append message list
|
---|
| 128 | . . S MSGID=""
|
---|
| 129 | . . F S MSGID=$O(RORLBLST("RM",REGIEN,MSGID)) Q:MSGID="" D
|
---|
| 130 | . . . S MSGSTAT=RORLBLST(MSGID,"MS")
|
---|
| 131 | . . . D MSG7STS^RORUTL05(MSGID,.RORXML,,7980000.002,.PARAMS,MSGSTAT)
|
---|
| 132 | . . ;--- Close the registry section
|
---|
| 133 | . . D NTFXML("</REGISTRY>")
|
---|
| 134 | . ;--- E-mail footer
|
---|
| 135 | . D BLD^DIALOG(7980000.026,.PARAMS,,"RORXML","S")
|
---|
| 136 | . ;--- Send the e-mail
|
---|
| 137 | . D
|
---|
| 138 | . . N XMCHAN,XMDUZ,XMLOC,XMSUB,XMTEXT,XMY,XMZ
|
---|
| 139 | . . S XMDUZ=.5,XMY(EMAIL)=""
|
---|
| 140 | . . S XMSUB="ROR: HL7 PROBLEM"
|
---|
| 141 | . . S XMTEXT="RORXML("
|
---|
| 142 | . . D ^XMD
|
---|
| 143 | Q
|
---|
| 144 | ;
|
---|
| 145 | NTFXML(STR) ;
|
---|
| 146 | S RORXML($O(RORXML(""),-1)+1)=STR
|
---|
| 147 | Q
|
---|
| 148 | ;
|
---|
| 149 | ;***** UPDATES REGISTRY RECORDS AFTER SUCCESSFUL DATA TRANSMISSION
|
---|
| 150 | ;
|
---|
| 151 | ; BATCHID Internal HL7 batch ID
|
---|
| 152 | ; BATCHDT Date/Time of the batch
|
---|
| 153 | ;
|
---|
| 154 | ; Return values:
|
---|
| 155 | ; <0 Error code
|
---|
| 156 | ; 0 Ok
|
---|
| 157 | ;
|
---|
| 158 | UPDTRR(BATCHID,BATCHDT) ;
|
---|
| 159 | N IEN,IENS,LBI,MSGID,PATIEN,REGIEN,RORBUF,RORFDA,RORMSG,TMP,XREF
|
---|
| 160 | S XREF=$$ROOT^DILFD(798)_"""AM"")"
|
---|
| 161 | S LBI=$L(BATCHID)
|
---|
| 162 | ;===
|
---|
| 163 | S MSGID=BATCHID
|
---|
| 164 | F S MSGID=$O(@XREF@(MSGID)) Q:$E(MSGID,1,LBI)'=BATCHID D
|
---|
| 165 | . S IEN=0
|
---|
| 166 | . F S IEN=$O(@XREF@(MSGID,IEN)) Q:IEN'>0 D
|
---|
| 167 | . . S IENS=IEN_"," K RORBUF,RORFDA,RORMSG
|
---|
| 168 | . . ;=== Load the registry record
|
---|
| 169 | . . S TMP=".01;.02;3;4;4.1;5;5.1;6;9.1;9.2;10"
|
---|
| 170 | . . D GETS^DIQ(798,IENS,TMP,"I","RORBUF","RORMSG")
|
---|
| 171 | . . S PATIEN=$G(RORBUF(798,IENS,.01,"I"))
|
---|
| 172 | . . I $G(DIERR) D DBS^RORERR("RORMSG",-9,,PATIEN,798,IENS) Q
|
---|
| 173 | . . S REGIEN=+$G(RORBUF(798,IENS,.02,"I"))
|
---|
| 174 | . . ;
|
---|
| 175 | . . ;=== Update record state only if the corresponding HL7 message
|
---|
| 176 | . . ;=== was actually generated (check for fake Message ID)
|
---|
| 177 | . . I $P($G(RORBUF(798,IENS,10,"I")),"-",2) S RC=0 D Q:RC
|
---|
| 178 | . . . ;--- Delete a record marked for deletion (only if the deletion
|
---|
| 179 | . . . ;--- date/time is earlier than the last message timestamp)
|
---|
| 180 | . . . I $G(RORBUF(798,IENS,3,"I"))=5 D Q
|
---|
| 181 | . . . . Q:$G(RORBUF(798,IENS,6,"I"))'<BATCHDT
|
---|
| 182 | . . . . N DA,DIK S RC=1
|
---|
| 183 | . . . . S DIK=$$ROOT^DILFD(798),DA=IEN D ^DIK
|
---|
| 184 | . . . . S TMP=$$REGNAME^RORUTL01(REGIEN)
|
---|
| 185 | . . . . D LOG^RORERR(-90,,PATIEN,$P(TMP,U))
|
---|
| 186 | . . . ;--- Reset the UPDATE DEMOGRAPHICS flag if the demographic
|
---|
| 187 | . . . ;--- data was updated before the latest data extraction
|
---|
| 188 | . . . D:$G(RORBUF(798,IENS,4,"I"))
|
---|
| 189 | . . . . S:$G(RORBUF(798,IENS,4.1,"I"))<BATCHDT RORFDA(798,IENS,4)="@"
|
---|
| 190 | . . . ;--- Reset the UPDATE LOCAL REGISTRY DATA flag if the local
|
---|
| 191 | . . . ;--- data was updated before the latest data extraction
|
---|
| 192 | . . . D:$G(RORBUF(798,IENS,5,"I"))
|
---|
| 193 | . . . . S:$G(RORBUF(798,IENS,5.1,"I"))<BATCHDT RORFDA(798,IENS,5)="@"
|
---|
| 194 | . . ;
|
---|
| 195 | . . ;=== Update extraction dates
|
---|
| 196 | . . S TMP=+$G(RORBUF(798,IENS,9.2,"I"))
|
---|
| 197 | . . S:TMP>$G(RORBUF(798,IENS,9.1)) RORFDA(798,IENS,9.1)=TMP
|
---|
| 198 | . . ;=== Clear the message ID
|
---|
| 199 | . . S RORFDA(798,IENS,10)="@"
|
---|
| 200 | . . ;=== Update the registry record (if necessary)
|
---|
| 201 | . . D:$D(RORFDA)>1
|
---|
| 202 | . . . D FILE^DIE(,"RORFDA","RORMSG")
|
---|
| 203 | . . . D:$G(DIERR) DBS^RORERR("RORMSG",-9,,PATIEN,798,IENS)
|
---|
| 204 | ;===
|
---|
| 205 | Q 0
|
---|