source: FOIAVistA/trunk/r/CLINICAL_CASE_REGISTRIES-ROR/ROR10.m@ 1094

Last change on this file since 1094 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 5.6 KB
Line 
1ROR10 ;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
7ALERT ;
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 ;
30CHECKMSG(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 ;
133TASKPRMS(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 ;
162TP(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
Note: See TracBrowser for help on using the repository browser.