| [613] | 1 | ROR10 ;HCIOFO/SG - NIGHTLY TASK UTILITIES ; 11/29/05 4:21pm | 
|---|
|  | 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | Q | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ;***** DISPLAYS THE ALERT ABOUT PROBLEMATIC HL7 MESSAGES | 
|---|
|  | 7 | ALERT ; | 
|---|
|  | 8 | Q:$G(XQADATA)="" | 
|---|
|  | 9 | N I,PARAMS,RORINFO,TMP | 
|---|
|  | 10 | ;--- Get and prepare the parameters | 
|---|
|  | 11 | S PARAMS("REGISTRY")=$P(XQADATA,"^") | 
|---|
|  | 12 | S PARAMS("NOR")=$P(XQADATA,"^",2) | 
|---|
|  | 13 | ;--- Load and format the text | 
|---|
|  | 14 | D BLD^DIALOG(7980000.027,.PARAMS,,"RORINFO","S") | 
|---|
|  | 15 | ;--- Display the text | 
|---|
|  | 16 | S I=""  W !! | 
|---|
|  | 17 | F  S I=$O(RORINFO(I))  Q:I=""  W RORINFO(I),! | 
|---|
|  | 18 | Q | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | ;***** CHECKS THE STATUS OF LAST HL7 MESSAGE(S) | 
|---|
|  | 21 | ; | 
|---|
|  | 22 | ; .REGLST       Reference to a local array containing registry | 
|---|
|  | 23 | ;               names as subscripts and (optionally) registry | 
|---|
|  | 24 | ;               IENs as values. | 
|---|
|  | 25 | ; | 
|---|
|  | 26 | ; Return values: | 
|---|
|  | 27 | ;       <0  Error code | 
|---|
|  | 28 | ;        0  Ok | 
|---|
|  | 29 | ; | 
|---|
|  | 30 | CHECKMSG(REGLST) ; | 
|---|
|  | 31 | N RORLBLST      ; List of latest batch HL7 messages (see ^ROR11) | 
|---|
|  | 32 | ; | 
|---|
|  | 33 | N HDTIEN,IENS,IM,LBCID,MSGDT,MSGSTC,RC,REGIEN,REGNAME,RORBUF,RORFDA,RORMSG,TMP | 
|---|
|  | 34 | S RC=0 | 
|---|
|  | 35 | ; | 
|---|
|  | 36 | ;=== Compile the list of latest batch HL7 messages | 
|---|
|  | 37 | S REGNAME="" | 
|---|
|  | 38 | F  S REGNAME=$O(REGLST(REGNAME))  Q:REGNAME=""  D  Q:RC<0 | 
|---|
|  | 39 | . ;--- Get the registry IEN | 
|---|
|  | 40 | . S REGIEN=+$G(REGLST(REGNAME)) | 
|---|
|  | 41 | . I REGIEN'>0  D  I REGIEN'>0  S RC=+REGIEN  Q | 
|---|
|  | 42 | . . S REGIEN=$$REGIEN^RORUTL02(REGNAME) | 
|---|
|  | 43 | . S $P(REGLST(REGNAME),U)=REGIEN | 
|---|
|  | 44 | . ;--- Get the list of batch HL7 message IDs | 
|---|
|  | 45 | . K RORBUF,RORMSG | 
|---|
|  | 46 | . S IENS=","_REGIEN_"," | 
|---|
|  | 47 | . D LIST^DIC(798.122,IENS,"@;.01;.02;.03I",,,,,"B",,,"RORBUF","RORMSG") | 
|---|
|  | 48 | . I $G(DIERR)  S RC=$$DBS^RORERR("RORMSG",-9,,,798.122,IENS)  Q | 
|---|
|  | 49 | . ;--- Update the list of latest HL7 batch messages | 
|---|
|  | 50 | . S IM="" | 
|---|
|  | 51 | . F  S IM=$O(RORBUF("DILIST","ID",IM))  Q:IM=""  D | 
|---|
|  | 52 | . . S LBCID=RORBUF("DILIST","ID",IM,.01) | 
|---|
|  | 53 | . . S IENS=RORBUF("DILIST",2,IM)_","_REGIEN_"," | 
|---|
|  | 54 | . . S MSGDT=$G(RORBUF("DILIST","ID",IM,.03)) | 
|---|
|  | 55 | . . D ADDMSG^ROR11(LBCID,IENS,$G(RORBUF("DILIST","ID",IM,.02)),MSGDT) | 
|---|
|  | 56 | Q:RC<0 RC | 
|---|
|  | 57 | ; | 
|---|
|  | 58 | ;=== Analyze the list of messages | 
|---|
|  | 59 | S LBCID=0 | 
|---|
|  | 60 | F  S LBCID=$O(RORLBLST(LBCID))  Q:LBCID'>0  D  Q:RC<0 | 
|---|
|  | 61 | . S MSGSTC=+RORLBLST(LBCID,"MS") | 
|---|
|  | 62 | . S MSGDT=RORLBLST(LBCID,"DT") | 
|---|
|  | 63 | . ;--- If the message does not exist (usually, it should), remove | 
|---|
|  | 64 | . ;    the reference(s) but do not update the patients' extraction | 
|---|
|  | 65 | . ;--- dates. Data will be re-extracted and resent (just in case). | 
|---|
|  | 66 | . I 'MSGSTC  D  Q | 
|---|
|  | 67 | . . D DELMSG^ROR11(LBCID,.RORFDA) | 
|---|
|  | 68 | . . D ERROR^RORERR(-49,,,,LBCID) | 
|---|
|  | 69 | . ;--- Unfortunately, the 'successfully completed' status (3) is | 
|---|
|  | 70 | . ;    returned for cancelled messages as well (and possibly in | 
|---|
|  | 71 | . ;    some other situations). Update the patients' extraction | 
|---|
|  | 72 | . ;    dates only if there is no error message in the status | 
|---|
|  | 73 | . ;--- string. Then remove the message reference(s). | 
|---|
|  | 74 | . I MSGSTC=3  D  Q | 
|---|
|  | 75 | . . S TMP=$P(RORLBLST(LBCID,"MS"),U,3) | 
|---|
|  | 76 | . . S:TMP="" TMP=$$UPDTRR^ROR11($P(RORLBLST(LBCID),U),MSGDT) | 
|---|
|  | 77 | . . D DELMSG^ROR11(LBCID,.RORFDA) | 
|---|
|  | 78 | . ;--- If the message is being processed/transmitted, | 
|---|
|  | 79 | . ;--- then keep the reference(s) in the list. | 
|---|
|  | 80 | . I (MSGSTC=1.5)!(MSGSTC=1.7)  D  Q | 
|---|
|  | 81 | . . D ERROR^RORERR(-73,,,,LBCID) | 
|---|
|  | 82 | . ;--- Otherwise (the message has not been sent), keep the | 
|---|
|  | 83 | . ;--- reference(s) and requeue the message (just in case). | 
|---|
|  | 84 | . S TMP=+$$MSGACT^HLUTIL(LBCID,2) | 
|---|
|  | 85 | . D ERROR^RORERR($S(TMP:-93,1:-92),,,,LBCID) | 
|---|
|  | 86 | Q:RC<0 RC | 
|---|
|  | 87 | ; | 
|---|
|  | 88 | S REGNAME="" | 
|---|
|  | 89 | F  S REGNAME=$O(REGLST(REGNAME))  Q:REGNAME=""  D | 
|---|
|  | 90 | . ;--- Get the registry IEN | 
|---|
|  | 91 | . S REGIEN=+$G(REGLST(REGNAME))  Q:REGIEN'>0 | 
|---|
|  | 92 | . S IENS=REGIEN_"," | 
|---|
|  | 93 | . ;--- Check if all registry messages have been sent | 
|---|
|  | 94 | . I $D(RORLBLST("RM",REGIEN))<10  D:$D(RORLBLST("RM",REGIEN))  Q | 
|---|
|  | 95 | . . K RORLBLST("RM",REGIEN) | 
|---|
|  | 96 | . . ;--- Clear the HL7 ATTEMPT COUNTER field | 
|---|
|  | 97 | . . S RORFDA(798.1,IENS,19.3)="@" | 
|---|
|  | 98 | . . ;--- Check for an automatic backpull definition | 
|---|
|  | 99 | . . S HDTIEN=$$GET1^DIQ(798.1,IENS,21.01,"I",,"RORMSG") | 
|---|
|  | 100 | . . I $G(DIERR)  D DBS^RORERR("RORMSG",-9,,,798.1,IENS)  Q | 
|---|
|  | 101 | . . D:HDTIEN>0 | 
|---|
|  | 102 | . . . ;--- Reset the automatic backpull mode | 
|---|
|  | 103 | . . . S RORFDA(798.1,IENS,21.01)="@" | 
|---|
|  | 104 | . . . ;--- Complete the automatic backpull | 
|---|
|  | 105 | . . . S TMP=$$COMPLETE^RORHDT06(HDTIEN,REGNAME) | 
|---|
|  | 106 | . ;--- Increment the HL7 ATTEMPT COUNTER for registries with unsent | 
|---|
|  | 107 | . ;--- message(s) and exclude those registries from data extraction. | 
|---|
|  | 108 | . S TMP=$$GET1^DIQ(798.1,IENS,19.3,,,"RORMSG") | 
|---|
|  | 109 | . D:$G(DIERR) DBS^RORERR("RORMSG",-9,,,798.1,IENS) | 
|---|
|  | 110 | . S RORFDA(798.1,IENS,19.3)=TMP+1 | 
|---|
|  | 111 | . K REGLST(REGNAME) | 
|---|
|  | 112 | ; | 
|---|
|  | 113 | ;=== Update the registry parameters if necessary | 
|---|
|  | 114 | D:$D(RORFDA)>1 | 
|---|
|  | 115 | . D FILE^DIE(,"RORFDA","RORMSG") | 
|---|
|  | 116 | . D:$G(DIERR) DBS^RORERR("RORMSG",-9,,,798.1) | 
|---|
|  | 117 | ; | 
|---|
|  | 118 | ;=== Notify the AAC and local coordinators if necessary | 
|---|
|  | 119 | D:$D(RORLBLST("RM"))>1 NOTIFY^ROR11() | 
|---|
|  | 120 | ; | 
|---|
|  | 121 | ;=== Success | 
|---|
|  | 122 | Q 0 | 
|---|
|  | 123 | ; | 
|---|
|  | 124 | ;***** PROCESSES THE TASK PARAMETERS | 
|---|
|  | 125 | ; | 
|---|
|  | 126 | ; .REGLST       Reference to a local variable where the list of | 
|---|
|  | 127 | ;               registry names is returned to | 
|---|
|  | 128 | ; | 
|---|
|  | 129 | ; Return values: | 
|---|
|  | 130 | ;       <0  Error code | 
|---|
|  | 131 | ;        0  Ok | 
|---|
|  | 132 | ; | 
|---|
|  | 133 | TASKPRMS(REGLST) ; | 
|---|
|  | 134 | N %DT,DTOUT,INFO,REGNAME,TMP,X,Y | 
|---|
|  | 135 | ;--- Log the task parameters | 
|---|
|  | 136 | D TP(.INFO,"ZTQPARAM") | 
|---|
|  | 137 | D TP(.INFO,"RORFLSET") | 
|---|
|  | 138 | D TP(.INFO,"RORFLCLR") | 
|---|
|  | 139 | D TP(.INFO,"RORMNTSK") | 
|---|
|  | 140 | D TP(.INFO,"RORSUSP") | 
|---|
|  | 141 | D LOG^RORLOG(,"Task Parameters",,.INFO) | 
|---|
|  | 142 | ;--- Check the task parameters | 
|---|
|  | 143 | I ZTQPARAM=""  D  Q RC | 
|---|
|  | 144 | . D TEXT^RORTXT(7980000.001,.INFO) | 
|---|
|  | 145 | . S RC=$$ERROR^RORERR(-88,,.INFO,,"TASK PARAMETERS") | 
|---|
|  | 146 | ;--- Maximum number of subtasks | 
|---|
|  | 147 | S RORMNTSK=$S(RORMNTSK'="":$TR(RORMNTSK,"-","^"),1:"2^3^AUTO") | 
|---|
|  | 148 | ;--- Suspension parameters | 
|---|
|  | 149 | D:RORSUSP'="" | 
|---|
|  | 150 | . S TMP=RORSUSP,RORSUSP="" | 
|---|
|  | 151 | . F I=1,2  D  S:$G(Y)>0 $P(RORSUSP,"^",I)=Y#1 | 
|---|
|  | 152 | . . S X=$P(TMP,"-",I),%DT="R"  D ^%DT | 
|---|
|  | 153 | ;--- Extract registry names from task parameters | 
|---|
|  | 154 | F I=1:1  S REGNAME=$P(ZTQPARAM,",",I)  Q:REGNAME=""  D | 
|---|
|  | 155 | . S REGNAME=$$TRIM^XLFSTR(REGNAME) | 
|---|
|  | 156 | . S:REGNAME'="" REGLST(REGNAME)="" | 
|---|
|  | 157 | ;--- Flags | 
|---|
|  | 158 | S RORFLCLR=$$UP^XLFSTR(RORFLCLR) | 
|---|
|  | 159 | S RORFLSET=$$UP^XLFSTR(RORFLSET) | 
|---|
|  | 160 | Q 0 | 
|---|
|  | 161 | ; | 
|---|
|  | 162 | TP(INFO,NAME) ; | 
|---|
|  | 163 | S @NAME=$$TRIM^XLFSTR($G(@NAME))  Q:@NAME="" | 
|---|
|  | 164 | S INFO($O(INFO(""),-1)+1)=$$LJ^XLFSTR(NAME,8)_" = """_@NAME_"""" | 
|---|
|  | 165 | Q | 
|---|