| 1 | C0PTEST   ; ERX/GPL - eRx Refill utilities ; 3/19/10 11:53am | 
|---|
| 2 | ;;0.1;C0P;nopatch;noreleasedate;Build 26 | 
|---|
| 3 | ;Copyright 2009,2010 George Lilly.  Licensed under the terms of the GNU | 
|---|
| 4 | ;General Public License See attached copy of the License. | 
|---|
| 5 | ; | 
|---|
| 6 | ;This program is free software; you can redistribute it and/or modify | 
|---|
| 7 | ;it under the terms of the GNU General Public License as published by | 
|---|
| 8 | ;the Free Software Foundation; either version 2 of the License, or | 
|---|
| 9 | ;(at your option) any later version. | 
|---|
| 10 | ; | 
|---|
| 11 | ;This program is distributed in the hope that it will be useful, | 
|---|
| 12 | ;but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 13 | ;MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 14 | ;GNU General Public License for more details. | 
|---|
| 15 | ; | 
|---|
| 16 | ;You should have received a copy of the GNU General Public License along | 
|---|
| 17 | ;with this program; if not, write to the Free Software Foundation, Inc., | 
|---|
| 18 | ;51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | 
|---|
| 19 | ; | 
|---|
| 20 | Q | 
|---|
| 21 | ; | 
|---|
| 22 | TESTMEDS        ; PRINT OUT MEDICATIONS FOR INPATIENTS WITH MEDS BUT NO INPATIENT | 
|---|
| 23 | ; MEDS | 
|---|
| 24 | S ZI="" | 
|---|
| 25 | D BUILD^C0QPRML | 
|---|
| 26 | S GNEW=$NA(C0QLIST("NoMedOrders")) | 
|---|
| 27 | S GOLD=$NA(C0QLIST("HasMed")) | 
|---|
| 28 | K G | 
|---|
| 29 | D UNITY^C0QSET("G",GNEW,GOLD) | 
|---|
| 30 | F  S ZI=$O(G(1,ZI)) Q:ZI=""  D  ; FOR EACH PATIENT IN BOTH LISTS | 
|---|
| 31 | . K GG | 
|---|
| 32 | . D COVER^ORWPS(.GG,ZI) ; GET MED LIST | 
|---|
| 33 | . W !,"PATIENT: ",ZI,! | 
|---|
| 34 | . ZWR GG | 
|---|
| 35 | Q | 
|---|
| 36 | ; | 
|---|
| 37 | TESTREQ(ZDUZ,ZDFN)      ; TEST REFILL REQUEST | 
|---|
| 38 | I '$D(ZDFN) S ZDFN="" | 
|---|
| 39 | D REFREQ("ZG",ZDUZ,ZDFN) | 
|---|
| 40 | W ! | 
|---|
| 41 | ZWR C0PRXML | 
|---|
| 42 | Q | 
|---|
| 43 | ; | 
|---|
| 44 | REFREQ(GRTN,IDUZ,IDFN)  ; MAKE A WEB SERVICE CALL TO GENERATE A REFIL REQUEST | 
|---|
| 45 | ; | 
|---|
| 46 | N GPL,C0PFARY,GVOR | 
|---|
| 47 | D ENCREQ("GPL",IDUZ,IDFN) | 
|---|
| 48 | S GVOR("XMLIN")=GPL | 
|---|
| 49 | S GVOR("ORIG-FILL-DATE")="" | 
|---|
| 50 | S GVOR("CREATE-MED-YN")="0" | 
|---|
| 51 | ;D EN^C0PMAIN("GG","GURL",IDUZ,IDFN,"GENREFILL","GVOR") | 
|---|
| 52 | D INITXPF^C0PWS2("C0PFARY") | 
|---|
| 53 | D SOAP^C0PWS2("GRTN","GENREFILL",IDUZ,IDFN,"GVOR") | 
|---|
| 54 | ;D SOAP^C0CSOAP("GRTN","GENREFILL",,,"GG","C0PFARY") ; | 
|---|
| 55 | Q | 
|---|
| 56 | ; | 
|---|
| 57 | GG1     ; IDENTIFY ORPHAN NODES IN ^PS(55,DFN,"NVA", | 
|---|
| 58 | S ZI="" S BAD="" S ZN=0 | 
|---|
| 59 | F  S ZI=$O(^PS(55,ZI)) Q:ZI=""  D  ; | 
|---|
| 60 | . S ZJ="" | 
|---|
| 61 | . F  S ZJ=$O(^PS(55,ZI,"NVA",ZJ)) Q:ZJ=""  D  ; FOR EACH NVA DRUG | 
|---|
| 62 | . . I $D(^PS(55,ZI,"NVA",ZJ,1,7,0)) D  ; IF THE CODES NODE EXISTS | 
|---|
| 63 | . . . I '$D(^PS(55,ZI,"NVA",ZJ,1,0)) D  ; I NO ZERO NODE | 
|---|
| 64 | . . . . S BAD(ZI,ZJ)="" | 
|---|
| 65 | . . . . S ZN=ZN+1 | 
|---|
| 66 | K ^G | 
|---|
| 67 | M ^G("BAD")=BAD | 
|---|
| 68 | ZWR BAD | 
|---|
| 69 | W !,"BAD COUNT: ",ZN | 
|---|
| 70 | Q | 
|---|
| 71 | ; | 
|---|
| 72 | GG2     ; DISPLAY THE BAD NODES | 
|---|
| 73 | S ZI="" | 
|---|
| 74 | F  S ZI=$O(^G("BAD",ZI)) Q:ZI=""  D  ; | 
|---|
| 75 | . S ZJ="" | 
|---|
| 76 | . F  S ZJ=$O(^G("BAD",ZI,ZJ)) Q:ZJ=""  D  ; | 
|---|
| 77 | . . W !,^PS(55,ZI,"NVA",ZJ,1,7,0) | 
|---|
| 78 | . . I $D(^PS(55,ZI,"NVA",ZJ,1,0)) W !,"ERROR, DRUG EXISTS!" | 
|---|
| 79 | Q | 
|---|
| 80 | ; | 
|---|
| 81 | GGKILL  ; KILL THE BAD NODES | 
|---|
| 82 | S ZI="" | 
|---|
| 83 | F  S ZI=$O(^G("BAD",ZI)) Q:ZI=""  D  ; | 
|---|
| 84 | . S ZJ="" | 
|---|
| 85 | . F  S ZJ=$O(^G("BAD",ZI,ZJ)) Q:ZJ=""  D  ; | 
|---|
| 86 | . . W !,^PS(55,ZI,"NVA",ZJ,1,7,0) | 
|---|
| 87 | . . I $D(^PS(55,ZI,"NVA",ZJ,1,0)) D  Q  ; | 
|---|
| 88 | . . . W !,"    ERROR, DRUG EXISTS!" | 
|---|
| 89 | . . . W !,"    NODE NOT KILLED, PLEASE REVIEW" | 
|---|
| 90 | . . K ^PS(55,ZI,"NVA",ZJ,1,7,0) | 
|---|
| 91 | . . W !,"     BAD NODE KILLED" | 
|---|
| 92 | Q | 
|---|
| 93 | ; | 
|---|
| 94 | GTEST   ; TESTING RENEWAL PROCESSING | 
|---|
| 95 | K G | 
|---|
| 96 | D SOAP^C0PWS2("G","REFILLS",135,961) | 
|---|
| 97 | S ZI="" | 
|---|
| 98 | F  S ZI=$O(G(ZI)) Q:ZI=""  D  ; | 
|---|
| 99 | . S ZG=G(ZI,"RenewalRequestGuid") | 
|---|
| 100 | . I ZG="" W !,"ERROR NULL GUID" | 
|---|
| 101 | . S ZT=$O(^TMP("C0E","INDEX",ZG,"")) | 
|---|
| 102 | . I ZT'="" D  ; HAVE A TOKEN | 
|---|
| 103 | . . S ZM1=G(ZI,"DrugInfo") | 
|---|
| 104 | . . S ZM2=^TMP("C0E","TOKEN",ZT,"renewalToken") | 
|---|
| 105 | . . S ZM3=^TMP("C0E","TOKEN",ZT,"medication") | 
|---|
| 106 | . . W !,!,"GUID:",ZG,!," TOKEN: ",ZT | 
|---|
| 107 | . . W !,"DRUG1: ",ZM1,!," DRUG2: ",ZM2,!," DRUG3: ",ZM3 | 
|---|
| 108 | . . ;ZWR ^TMP("C0E","TOKEN",ZT,*) | 
|---|
| 109 | Q | 
|---|
| 110 | ; | 
|---|
| 111 | GTEST2  ; SECOND TEST - FINDING INCONSISTANCIES IN RENEWAL ALERTS | 
|---|
| 112 | S ZI="" | 
|---|
| 113 | S ZN=0 | 
|---|
| 114 | S ZTMP=$NA(^TMP("C0E","TOKEN")) | 
|---|
| 115 | F  S ZI=$O(@ZTMP@(ZI)) Q:ZI=""  D  ; FOR EACH TOKEN | 
|---|
| 116 | . I @ZTMP@(ZI,"C0PRenewalName")["request for" D  ; MED WHERE NAME SHOULD BE | 
|---|
| 117 | . . W !,!,"TOKEN:",ZI | 
|---|
| 118 | . . W !,"GUID:",@ZTMP@(ZI,"C0PGuid") | 
|---|
| 119 | . . W !,@ZTMP@(ZI,"C0PRenewalName") | 
|---|
| 120 | . . W !,@ZTMP@(ZI,"medication") | 
|---|
| 121 | . . W !,@ZTMP@(ZI,"renewalToken") | 
|---|
| 122 | . . S ISTR=@ZTMP@(ZI,"renewalToken") | 
|---|
| 123 | . . S IDUZ=@ZTMP@(ZI,"IDUZ") | 
|---|
| 124 | . . S ZALRT=$P(ISTR,";",3) ; RENEWAL TOKEN | 
|---|
| 125 | . . S ^G2(IDUZ,ZALRT,ISTR)="" | 
|---|
| 126 | . . S ZN=ZN+1 | 
|---|
| 127 | W !,!,"NUMBER OF TOKENS:",ZN | 
|---|
| 128 | Q | 
|---|
| 129 | ; | 
|---|
| 130 | GTEST3  ; USE ^G2 TO TRY AND FIND THE ALERTS | 
|---|
| 131 | ; | 
|---|
| 132 | S ZDUZ="" | 
|---|
| 133 | F  S ZDUZ=$O(^G2(ZDUZ)) Q:ZDUZ=""  D  ; | 
|---|
| 134 | . S ZALRT="" | 
|---|
| 135 | . F  S ZALRT=$O(^G2(ZDUZ,ZALRT)) Q:ZALRT=""  D  ; | 
|---|
| 136 | . . W !,!,ZALRT | 
|---|
| 137 | . . W !,$G(^XTV(8992,ZDUZ,"XQA",ZALRT,0)) | 
|---|
| 138 | . . S NXTALRT=$O(^XTV(8992,ZDUZ,"XQA",ZALRT)) ; NEXT ALERT | 
|---|
| 139 | . . W !,"NEXT:",NXTALRT | 
|---|
| 140 | . . I NXTALRT'="" W !,$G(^XTV(8992,ZDUZ,"XQA",NXTALRT,0)) | 
|---|
| 141 | Q | 
|---|
| 142 | ; | 
|---|
| 143 | GINDEX  ; INDEX THE ^TMP("C0E","TOKEN") ARRAY BY GUID | 
|---|
| 144 | S ZI="" | 
|---|
| 145 | S ZN=0 | 
|---|
| 146 | F  S ZI=$O(^TMP("C0E","TOKEN",ZI)) Q:ZI=""  D  ; | 
|---|
| 147 | . S ZG=^TMP("C0E","TOKEN",ZI,"C0PGuid") | 
|---|
| 148 | . S ^TMP("C0E","INDEX",ZG,ZI)="" | 
|---|
| 149 | . S ZN=ZN+1 | 
|---|
| 150 | W !,"NUMBER OF TOKENS: ",ZN | 
|---|
| 151 | Q | 
|---|
| 152 | ; | 
|---|
| 153 | ENCREQ(ZRTN,ZDUZ,ZDFN)  ; ENCODE AN NCSCRIPT RENEWAL REQUEST | 
|---|
| 154 | ; | 
|---|
| 155 | D GENTEST("GPL","GURL",ZDUZ,ZDFN,1) | 
|---|
| 156 | ;S ZI="" | 
|---|
| 157 | ;S GPL(1)="RxInput="_GPL(1) | 
|---|
| 158 | S ZI=0 ; | 
|---|
| 159 | ;F  S ZI=$O(GPL(ZI)) Q:ZI=""  D  ; MAKE IT XML SAFE | 
|---|
| 160 | ;. S GPL(ZI)=$$SYMENC^MXMLUTL(GPL(ZI)) | 
|---|
| 161 | ;. W !,GPL(ZI) | 
|---|
| 162 | S ZI=0 | 
|---|
| 163 | S G="" | 
|---|
| 164 | K GPL(0) ; GET RID OF LINE COUNT | 
|---|
| 165 | F  S ZI=$O(GPL(ZI)) Q:ZI=""  D  ; | 
|---|
| 166 | . S G=G_GPL(ZI) | 
|---|
| 167 | S @ZRTN=$$ENCODE^RGUTUU(G) | 
|---|
| 168 | ;S @ZRTN=G | 
|---|
| 169 | Q | 
|---|
| 170 | ; | 
|---|
| 171 | CERTTEST        ; GENERATE XML FILES FOR NEWCROP CERTIFICATION | 
|---|
| 172 | ; | 
|---|
| 173 | N ZII | 
|---|
| 174 | S ZDFN=18 ; TEST PATIENT TO USE | 
|---|
| 175 | F ZII=154,155,156,157 D  ; IENS OF SUBSCRIBER PROFILES | 
|---|
| 176 | . D CERTONE(ZII,ZDFN) | 
|---|
| 177 | Q | 
|---|
| 178 | ; | 
|---|
| 179 | CERTONE(ZI,ZDFN)        ; GENERATE ONE XML FILE | 
|---|
| 180 | N ZN | 
|---|
| 181 | D EN^C0PMAIN("C0PG1","G2",ZI,ZDFN) ; GET THE NCSCRIPT | 
|---|
| 182 | S ZN=$P($P(^VA(200,ZI,0),U,1),",",2) ; GIVEN NAME OF USER | 
|---|
| 183 | ; ON OUR SYSTEM THESE ARE ERX,DOCTOR ERX,MID-LEVEL ERX,NURSE AND ERX,MANAGER | 
|---|
| 184 | S ZN=ZN_".xml" ; APPEND .xml extension | 
|---|
| 185 | K C0PG1(0) | 
|---|
| 186 | S ZDIR=^TMP("C0CCCR","ODIR") | 
|---|
| 187 | W !,$$OUTPUT^C0CXPATH("C0PG1(1)",ZN,ZDIR) | 
|---|
| 188 | Q | 
|---|
| 189 | ; | 
|---|
| 190 | GENTEST(RTNXML,RTNURL,ZDUZ,ZDFN,ZFILE)  ; GENERATE A TEST | 
|---|
| 191 | ; CLICK-THROUGH HTLM FILE FOR | 
|---|
| 192 | ; GENERATING REFILL REQUESTS , XML IS RETURNED IN RTN,PASSED BY NAME | 
|---|
| 193 | ; IF ZFILE IS 1, THE FILE IS WRITTEN TO HOST FILE | 
|---|
| 194 | D EN^C0PMAIN("C0PG1","G2",ZDUZ,ZDFN) ; GET THE NCSCRIPT | 
|---|
| 195 | ;D GETMEDS("G6",ZDFN) ;GET MEDICATIONS | 
|---|
| 196 | ;D QUERY^C0CXPATH("G6","//NewPrescription[1]","G7") ;JUST THE FIRST ONE | 
|---|
| 197 | ;D INSERT^C0CXPATH("C0PG1","G7","//NCScript") | 
|---|
| 198 | K C0PG1(0) | 
|---|
| 199 | M @RTNXML=C0PG1 ; | 
|---|
| 200 | S ZDIR=^TMP("C0CCCR","ODIR") | 
|---|
| 201 | I $G(ZFILE)=1 W $$OUTPUT^C0CXPATH("C0PG1(1)","REFILL-"_ZDFN_".xml",ZDIR) | 
|---|
| 202 | Q | 
|---|
| 203 | ; | 
|---|
| 204 | GETMEDS(OUTARY,ZDFN)    ; GET THE PATIENT'S MEDS AND PUT INTO XML | 
|---|
| 205 | ; | 
|---|
| 206 | N ZG,ZG2,ZB,ZN | 
|---|
| 207 | S DEBUG=0 | 
|---|
| 208 | D GETTEMP^C0PWS2("ZG","OUTMEDS") ;GET THE MEDICATIONS TEMPLATE | 
|---|
| 209 | D SOAP^C0PWS2("ZG2","GETMEDS",$$PRIMARY^C0PMAIN(),ZDFN) ; GET MEDS | 
|---|
| 210 | I '$D(ZG2) Q  ; SHOULDN'T HAPPEN | 
|---|
| 211 | I ZG2(1,"Status")'="OK" D  Q  ; BAD RETURN FROM WEB SERVER | 
|---|
| 212 | . W $G(ZG2(1,"Message")),! | 
|---|
| 213 | N ZI S ZI="" | 
|---|
| 214 | S ZN=$NA(^TMP("C0PREFIL",$J)) | 
|---|
| 215 | K @ZN | 
|---|
| 216 | F  S ZI=$O(ZG2(ZI)) Q:ZI=""  D  ; FOR EACH MED | 
|---|
| 217 | . N ZV | 
|---|
| 218 | . S ZV=$NA(@ZN@("DATA",ZI)) | 
|---|
| 219 | . S ZX=$NA(@ZN@("XML",ZI)) | 
|---|
| 220 | . S @ZV@("dispenseNumber")=$G(ZG2(ZI,"Dispense")) | 
|---|
| 221 | . S @ZV@("dosage")="Take "_$G(ZG2(ZI,"DosageNumberDescription"))_" "_$G(ZG2(ZI,"Route"))_" "_$G(ZG2(ZI,"DosageFrequencyDescription")) | 
|---|
| 222 | . S @ZV@("drugIdentifier")=ZG2(ZI,"DrugID") | 
|---|
| 223 | . S @ZV@("drugIdentifierType")="FDB" | 
|---|
| 224 | . S @ZV@("pharmacistMessage")="No childproof caps please" | 
|---|
| 225 | . S @ZV@("pharmacyIdentifier")=1231212 | 
|---|
| 226 | . S @ZV@("refillCount")=ZG2(ZI,"Refills") | 
|---|
| 227 | . S @ZV@("substitution")="SubstitutionAllowed" | 
|---|
| 228 | . D MAP^C0CXPATH("ZG",ZV,ZX) | 
|---|
| 229 | . D QUEUE^C0CXPATH("ZB",ZX,2,$O(@ZX@(""),-1)) | 
|---|
| 230 | D BUILD^C0CXPATH("ZB",OUTARY) | 
|---|
| 231 | K @ZN ;CLEAN UP | 
|---|
| 232 | Q | 
|---|
| 233 | ; | 
|---|
| 234 | ;B | 
|---|
| 235 | ; | 
|---|
| 236 | ;D GET^C0PCUR(.ZG2,ZDFN) ; GET THE MEDS FOR THIS PATIENT | 
|---|
| 237 | ;D EXTRACT^C0CALERT("ZG",ZDFN,"ZG2","ALGYCBK^C0PALGY3(ALTVMAP,A1)") | 
|---|
| 238 | S ZN=$O(ZR(""),-1) ;NUMBER OF LINES IN OUTPUT | 
|---|
| 239 | D QUEUE^C0CXPATH("ZB","ZG2",2,ZN-1) | 
|---|
| 240 | D BUILD^C0CXPATH("ZB",OUTARY) | 
|---|
| 241 | Q | 
|---|
| 242 | ; | 
|---|
| 243 | RGUIDS(ZARY,ZDUZ)       ; RETURNS AN ARRAY OF ALL REFILL REQUEST GUIDS FOR | 
|---|
| 244 | ; DUZ ZDUZ. ZARY IS PASSED BY NAME | 
|---|
| 245 | ; FORMAT IS @ZARY@("GUID")=IEN | 
|---|
| 246 | ; THIS ROUTINE IS REUSED FOR THE STATUS ROUTINE - INCOMPLETE ORDERS | 
|---|
| 247 | N ZI,ZJ,ZK,ZL,ZM,ZN | 
|---|
| 248 | S ZI=0 | 
|---|
| 249 | ;F  S ZI=$O(^XTV(8992.1,"R",ZDUZ,ZI)) Q:ZI=""  D  ; ALL ALERT FOR DUZ | 
|---|
| 250 | F  S ZI=$O(^XTV(8992,ZDUZ,"XQA",ZI)) Q:ZI=""  D  ; USE XQA MULTIPLE | 
|---|
| 251 | . S ZL=^XTV(8992,ZDUZ,"XQA",ZI,0) ; | 
|---|
| 252 | . S ZM=$P(ZL,U,2) ; RECORD ID | 
|---|
| 253 | . S ZN=$O(^XTV(8992.1,"B",ZM,"")) ;IEN OF ALERT TRACKING RECORD | 
|---|
| 254 | . S ZK=$$GET1^DIQ(8992.1,ZN_",",.03) | 
|---|
| 255 | . I ZK'["OR,1130" Q  ; NOT OUR PACKAGE - ALL ERX ALERTS START WITH 1130 | 
|---|
| 256 | . ; 11305 IS FOR REFILLS | 
|---|
| 257 | . ; 11306 IS FOR INCOMPLETE ORDERS | 
|---|
| 258 | . S ZJ="" | 
|---|
| 259 | . S ZJ=$$GET1^DIQ(8992.1,ZN_",",2) | 
|---|
| 260 | . I ZJ="" Q | 
|---|
| 261 | . ; FOR RENEWALS (11305) NEED TO PULL THE GUID OUT - IT IS THE FIRST PIECE | 
|---|
| 262 | . ; OTHERWISE USE THE ENTIRE STRING. FOR INCOMPLETE ORDERS THIS WILL | 
|---|
| 263 | . ; INCLUDE THE MED AND PRESCRIPTION DATE | 
|---|
| 264 | . I ZK["OR,11305" S ZJ=$P(ZJ,"^",1) ; FIRST PIECE IS THE GUILD GUID^DOB^SEX | 
|---|
| 265 | . S @ZARY@(ZJ)=ZN | 
|---|
| 266 | Q | 
|---|
| 267 | ; | 
|---|
| 268 | EN      ; BATCH ENTRY POINT FOR REFILL (RENEWAL) STATUS AND FAILEDFAX CHECKING | 
|---|
| 269 | D REFILL | 
|---|
| 270 | K ZRSLT | 
|---|
| 271 | ;D STATUS ; ALSO RUN CHECK FOR INCOMPLETE ORDERS | 
|---|
| 272 | D FAILFAX ; ALSO RUN CHECK FOR FAILED FAXES | 
|---|
| 273 | Q | 
|---|
| 274 | ; | 
|---|
| 275 | REFILL  ; PULL REFILL REQUESTS AND POST ALERTS | 
|---|
| 276 | ; | 
|---|
| 277 | N ZDUZ ; USER NUMBER UNDER WHICH WE BUILD THE WEB SERVICE CALL | 
|---|
| 278 | N ZDFN ; PATIENT NUMBER USED TO BUILD THE WEB SERVICE CALL | 
|---|
| 279 | S ZDUZ=$$PRIMARY^C0PMAIN() ; PRIMARY ERX USER FOR BATCH CALLS | 
|---|
| 280 | ;S ZDUZ=DUZ ; SHOULD CHANGE THIS FOR PRODUCTION TO A "BATCH" USER | 
|---|
| 281 | S ZDFN="" ; NO PATIENT NEEDED FOR THESE CALLS | 
|---|
| 282 | ; S ZDFN=18 ; SHOULD NOT NEED THIS BE MAKE THE CALL - FIX IN EN^C0PMAIN | 
|---|
| 283 | N ZRSLT | 
|---|
| 284 | D SOAP^C0PWS2("ZRSLT","REFILLS",ZDUZ,ZDFN) ; WS CALL TO RETURN REFILS | 
|---|
| 285 | ;S XXX=YYY  ; | 
|---|
| 286 | I $G(ZRSLT(1,"Status"))'="OK" Q  ; NO ROWS WERE RETURNED | 
|---|
| 287 | I $G(ZRSLT(1,"RowCount"))=0 Q  ; NO ROWS WERE RETURNED | 
|---|
| 288 | D NOTIPURG^XQALBUTL(11305) ; DELETE ALL CURRENT REFILL ALERTS | 
|---|
| 289 | S C0PNPIF=$$GET1^DIQ(C0PAF,C0PACCT_",",8,"I") ; LEGACY FLAG TO USE NPI FOR SID | 
|---|
| 290 | N ZI S ZI=0 | 
|---|
| 291 | N ZAPACK S ZAPACK="OR" ; ALERT PACKAGE CODE | 
|---|
| 292 | N ZADFN S ZADFN=0 ; DFN TO ASSOCIATE ALERT WITH - WE DON'T KNOW THIS | 
|---|
| 293 | N ZACODE S ZACODE=11305 ; IEN TO OE/RR NOTIFICATIONS file for eRx Refills | 
|---|
| 294 | F  S ZI=$O(ZRSLT(ZI)) Q:+ZI=0  D  ; FOR EACH RETURNED REFILL REQUEST | 
|---|
| 295 | . N ZSID S ZSID=ZRSLT(ZI,"ExternalDoctorId") ; NPI FOR SUBSCRIBER | 
|---|
| 296 | . I C0PNPIF'=1 S ZDUZ=$O(^VA(200,"AC0PSID",ZSID,"")) ; GUID SID | 
|---|
| 297 | . E  S ZDUZ=$O(^VA(200,"C0PNPI",ZSID,"")) ; DUZ FOR SUBSCRIBER | 
|---|
| 298 | . S ZRSLT("DUZ",ZDUZ,ZI)="" | 
|---|
| 299 | N ZJ S ZJ="" | 
|---|
| 300 | F  S ZJ=$O(ZRSLT("DUZ",ZJ)) Q:ZJ=""  D  ; FOR EACH PROVIDER | 
|---|
| 301 | . N ZGUIDS | 
|---|
| 302 | . D RGUIDS("ZGUIDS",ZJ) ; GET ARRAY OF CURRENT ACTIVE GUIDS | 
|---|
| 303 | . S ZI="" | 
|---|
| 304 | . F  S ZI=$O(ZRSLT("DUZ",ZJ,ZI)) Q:ZI=""  D  ; FOR EACH REQUEST | 
|---|
| 305 | . . N ZRRG S ZRRG=ZRSLT(ZI,"RenewalRequestGuid") ;renewal request number | 
|---|
| 306 | . . I $D(ZGUIDS(ZRRG)) D  Q  ; THIS REQUEST IS A DUPLICATE, SKIP IT | 
|---|
| 307 | . . . W ZRRG_" IS A DUP",! | 
|---|
| 308 | . . N ZDATE S ZDATE=$P(ZRSLT(ZI,"ReceivedTimestamp")," ",1) ;DATE RECEIVED | 
|---|
| 309 | . . I $G(^TMP("C0P","TestNoMatch"))=1 D  ; | 
|---|
| 310 | . . . S ZRSLT(ZI,"PatientMiddleName")="XXX" ;TESTING NO MATCH  REMOVE ME | 
|---|
| 311 | . . ;I DUZ=135 S ZRSLT(ZI,"PatientMiddleName")="Uta" ;TESTING NO MATCH REMOVE | 
|---|
| 312 | . . N ZPAT S ZPAT=$G(ZRSLT(ZI,"PatientLastName"))_","_$G(ZRSLT(ZI,"PatientFirstName")) ; PATIENT NAME LAST,FIRST | 
|---|
| 313 | . . I $G(ZRSLT(ZI,"PatientMiddleName"))'="" S ZPAT=ZPAT_" "_$G(ZRSLT(ZI,"PatientMiddleName")) | 
|---|
| 314 | . . S ZDOB=$G(ZRSLT(ZI,"PatientDOB")) ;patient date of birth | 
|---|
| 315 | . . S ZSEX=$G(ZRSLT(ZI,"PatientGender")) ;patient gender | 
|---|
| 316 | . . S ZADFN=$$PATMAT(ZPAT,ZDOB,ZSEX) ; TRY AND MATCH THE PATIENT | 
|---|
| 317 | . . ;W "DFN="_ZADFN," ",ZI,! | 
|---|
| 318 | . . N ZXQAID S ZXQAID=ZAPACK_","_ZADFN_","_ZACODE ; FORMAT FOR P1 OF XQAID | 
|---|
| 319 | . . N ZMED S ZMED=ZRSLT(ZI,"DrugInfo") | 
|---|
| 320 | . . ;S XQA(ZDUZ)="" ; WHO TO SEND THE ALERT TO | 
|---|
| 321 | . . I '$D(^TMP("C0P","AlertVerify")) S XQA(ZJ)="" ; WHO TO SEND THE ALERT TO | 
|---|
| 322 | . . E  D  ; AlertVerify sends alerts only to testers, not recipients | 
|---|
| 323 | . . . ; use this when installing eRx to verify ewd installation | 
|---|
| 324 | . . . N ZZZ S ZZZ="" | 
|---|
| 325 | . . . F  S ZZZ=$O(^TMP("C0P","AlertVerify",ZZZ)) Q:ZZZ=""  D  ; WHICH DUZ | 
|---|
| 326 | . . . . S XQA(ZZZ)="" ; MARK THIS USER TO RECIEVE ALERTS | 
|---|
| 327 | . . ;S XQA(135)="" ; ALWAYS SEND TO GPL | 
|---|
| 328 | . . ;S XQA(148)="" ; ALWAYS SEND TO RICH | 
|---|
| 329 | . . N ZP6 ; STRING THAT CPRS WILL RETURN FOR MATCHING | 
|---|
| 330 | . . I ZADFN=0 D  ; NO MATCH | 
|---|
| 331 | . . . S XQAMSG="no match: ): [eRx] "_ZPAT_" Renewal request for "_ZMED | 
|---|
| 332 | . . . S ZP6=ZPAT_" Renewal request for "_ZMED | 
|---|
| 333 | . . E  D  ; | 
|---|
| 334 | . . . S XQAMSG=ZPAT_": ): [eRx] Renewal request for "_ZMED | 
|---|
| 335 | . . . S ZP6="Renewal request for "_ZMED | 
|---|
| 336 | . . ;S XQAMSG=$E(XQAMSG,1,70) ; TRUNCATE TO 70 CHARS | 
|---|
| 337 | . . S XQAID=ZXQAID ; PACKAGE IDENTIFIER | 
|---|
| 338 | . . ;S XQADATA=ZRRG ; THE GUID OF THE REQUEST. NEEDED TO PROCESS THE ALERT | 
|---|
| 339 | . . S XQADATA=ZRRG_"^"_ZDOB_"^"_ZSEX ; SAVE DOB AND SEX WITH GUID | 
|---|
| 340 | . . W "SENDING",XQAID_" "_XQADATA,! | 
|---|
| 341 | . . D SETUP^XQALERT ; MAKE THE CALL TO SET THE ALERT | 
|---|
| 342 | K ZRSLT | 
|---|
| 343 | ;D STATUS ; ALSO RUN CHECK FOR INCOMPLETE ORDERS | 
|---|
| 344 | ;D FAILFAX ; ALSO RUN CHECK FOR FAILED FAXES | 
|---|
| 345 | Q | 
|---|
| 346 | ; | 
|---|
| 347 | PATMAT(ZNAME,INDOB,INSEX)       ;EXTRINSIC TO TRY AND MATCH THE PATIENT | 
|---|
| 348 | ; RETURNS ZERO IF NO EXACT MATCH IS FOUND | 
|---|
| 349 | N ZP | 
|---|
| 350 | S ZP=$O(^DPT("B",ZNAME,"")) | 
|---|
| 351 | I ZP="" Q 0 ; EXACT MATCH NOT FOUND ON NAME | 
|---|
| 352 | ; CHECK DATE OF BIRTH | 
|---|
| 353 | ;W "CHECKING DATE OF BIRTH",! | 
|---|
| 354 | N DOB | 
|---|
| 355 | S DOB=$$GET1^DIQ(2,ZP_",",.03,"I") ; PATIENT'S DATE OF BIRTH IN VISTA | 
|---|
| 356 | N ZD ;INCOMING DATE OF BIRTH IS IN YYYYMMDD FORMAT | 
|---|
| 357 | S ZD=($E(INDOB,1,4)-1700)_$E(INDOB,5,8) ; DATE OF BIRTH CONVERTED TO FM FORMAT | 
|---|
| 358 | ;W ZD_" "_DOB,! | 
|---|
| 359 | I +ZD'=+DOB Q 0 ; DATE OF BIRTH DOES NOT MATCH | 
|---|
| 360 | ; | 
|---|
| 361 | ; CHECK GENDER | 
|---|
| 362 | ;W "CHECKING GENDER",! | 
|---|
| 363 | N GENDER | 
|---|
| 364 | S GENDER=$$GET1^DIQ(2,ZP_",",.02,"I") ; PATIENT'S GENDER IN VISTA | 
|---|
| 365 | ;W GENDER_INSEX,! | 
|---|
| 366 | I GENDER'=INSEX Q 0 ;GENDER DOESN'T MATCH | 
|---|
| 367 | Q ZP | 
|---|
| 368 | ; | 
|---|
| 369 | STATUS  ; BATCH CALL TO RETRIEVE ERX ACCOUNT STATUS | 
|---|
| 370 | ; RETURNS UNFINISHED ORDERS FOR ALL PROVIDERS | 
|---|
| 371 | ; AND SENDS STATUS ALERTS | 
|---|
| 372 | N VOR | 
|---|
| 373 | S VOR("STATUS-SECTION-TYPE")="AllDoctorReview" | 
|---|
| 374 | S VOR("SORT-ORDER")="A" | 
|---|
| 375 | S VOR("INCLUDE-SCHEMA")="N" | 
|---|
| 376 | S ZDUZ=$$PRIMARY^C0PMAIN() ; PRIMARY ERX USER FOR BATCH CALLS | 
|---|
| 377 | K ZRSLT | 
|---|
| 378 | ; D SOAP^C0PWS1("ZRSLT","STATUS",ZDUZ,"","VOR") | 
|---|
| 379 | D SOAP^C0PWS2("ZRSLT","STATUS",ZDUZ,"","VOR") | 
|---|
| 380 | I '$D(ZRSLT) Q  ; SHOULDN'T HAPPEN | 
|---|
| 381 | I $G(ZRSLT(1,"DrugInfo"))="" Q  ; NO ROWS | 
|---|
| 382 | S C0PNPIF=$$GET1^DIQ(C0PAF,C0PACCT_",",8,"I") ; LEGACY FLAG TO USE NPI FOR SID | 
|---|
| 383 | N ZI S ZI=0 | 
|---|
| 384 | N ZAPACK S ZAPACK="OR" ; ALERT PACKAGE CODE | 
|---|
| 385 | N ZADFN S ZADFN=0 ; DFN TO ASSOCIATE ALERT WITH - WE DON'T KNOW THIS | 
|---|
| 386 | N ZACODE S ZACODE=11306 ; IEN TO OE/RR NOTIFICATIONS file for eRx incomplete | 
|---|
| 387 | ; orders | 
|---|
| 388 | F  S ZI=$O(ZRSLT(ZI)) Q:+ZI=0  D  ; FOR EACH RETURNED REFILL REQUEST | 
|---|
| 389 | . N ZSID S ZSID=$G(ZRSLT(ZI,"ExternalDoctorId")) ; NPI FOR SUBSCRIBER | 
|---|
| 390 | . I ZSID="" Q  ; NO EXTERNAL ID FOR THIS STATUS | 
|---|
| 391 | . I C0PNPIF'=1 S ZDUZ=$O(^VA(200,"AC0PSID",ZSID,"")) ; GUID SID | 
|---|
| 392 | . E  S ZDUZ=$O(^VA(200,"C0PNPI",ZSID,"")) ; DUZ FOR SUBSCRIBER | 
|---|
| 393 | . S ZRSLT("DUZ",ZDUZ,ZI)="" | 
|---|
| 394 | N ZJ S ZJ="" | 
|---|
| 395 | D RMSTATUS ; REMOVE ALL STATUS ALERTS | 
|---|
| 396 | F  S ZJ=$O(ZRSLT("DUZ",ZJ)) Q:ZJ=""  D  ; FOR EACH PROVIDER | 
|---|
| 397 | . N ZGUIDS | 
|---|
| 398 | . D RGUIDS("ZGUIDS",ZJ) ; GET ARRAY OF CURRENT ACTIVE ALERTS | 
|---|
| 399 | . S ZI="" | 
|---|
| 400 | . F  S ZI=$O(ZRSLT("DUZ",ZJ,ZI)) Q:ZI=""  D  ; FOR EACH REQUEST | 
|---|
| 401 | . . N ZRRG S ZRRG=$G(ZRSLT(ZI,"DrugInfo")) ; first piece of XQDATA | 
|---|
| 402 | . . S $P(ZRRG,"^",2)=$G(ZRSLT(ZI,"PrescriptionDate")) ; second piece | 
|---|
| 403 | . . I $D(ZGUIDS(ZRRG)) D  Q  ; THIS REQUEST IS A DUPLICATE, SKIP IT | 
|---|
| 404 | . . . ;W ZRRG_" IS A DUP",! | 
|---|
| 405 | . . I ZRRG="^" D  Q ; THIS IS AN ERROR | 
|---|
| 406 | . . . B | 
|---|
| 407 | . . N ZDATE S ZDATE=$P($G(ZRSLT(ZI,"PrescriptionDate"))," ",1) ; | 
|---|
| 408 | . . N ZPAT S ZPAT=$G(ZRSLT(ZI,"ExternalPatientId")) ; format PATIENTDFN | 
|---|
| 409 | . . I ZPAT="" Q  ;THIS IS AN ERROR | 
|---|
| 410 | . . S ZADFN=$P(ZPAT,"PATIENT",2) ; EXTRACT THE DFN | 
|---|
| 411 | . . S ZPAT=$$GET1^DIQ(2,ZADFN_",",.01) ;PATIENT'S NAME | 
|---|
| 412 | . . ;W "DFN="_ZADFN," ",ZI,! | 
|---|
| 413 | . . N ZXQAID S ZXQAID=ZAPACK_","_ZADFN_","_ZACODE ; FORMAT FOR P1 OF XQAID | 
|---|
| 414 | . . N ZMED S ZMED=ZRSLT(ZI,"DrugInfo") | 
|---|
| 415 | . . ;S XQA(ZDUZ)="" ; WHO TO SEND THE ALERT TO | 
|---|
| 416 | . . S XQA(ZJ)="" ; WHO TO SEND THE ALERT TO | 
|---|
| 417 | . . ;S XQA(135)="" ; ALWAYS SEND TO GPL | 
|---|
| 418 | . . ;S XQA(148)="" ; ALWAYS SEND TO RICH | 
|---|
| 419 | . . N ZP6 ; STRING THAT CPRS WILL RETURN FOR MATCHING | 
|---|
| 420 | . . I ZADFN=0 D  ; NO MATCH | 
|---|
| 421 | . . . S XQAMSG="no match: ): [eRx] "_ZPAT_" Incomplete Order for "_ZMED | 
|---|
| 422 | . . . S ZP6=ZPAT_" Incomplete Order for "_ZMED | 
|---|
| 423 | . . E  D  ; | 
|---|
| 424 | . . . S XQAMSG=ZPAT_": ): [eRx] Incomplete Order for "_ZMED | 
|---|
| 425 | . . . S ZP6="Incomplete Order for "_ZMED | 
|---|
| 426 | . . ;S XQAMSG=$E(XQAMSG,1,70) ; TRUNCATE TO 70 CHARS | 
|---|
| 427 | . . S XQAID=ZXQAID ; PACKAGE IDENTIFIER | 
|---|
| 428 | . . S XQADATA=ZRRG ; THE GUID OF THE REQUEST. NEEDED TO PROCESS THE ALERT | 
|---|
| 429 | . . D SETUP^XQALERT ; MAKE THE CALL TO SET THE ALERT | 
|---|
| 430 | Q | 
|---|
| 431 | ; | 
|---|
| 432 | RMSTATUS        ; DELETES ALL STATUS ALERTS FOR ALL USERS (THEY WILL BE | 
|---|
| 433 | ; RESTORED NEXT TIME STATUS^C0PREFIL IS RUN - IN ERX BATCH | 
|---|
| 434 | D NOTIPURG^XQALBUTL(11306) ; | 
|---|
| 435 | W !,"ALL ERX STATUS ALERTS HAVE BEEN DELETED" | 
|---|
| 436 | Q | 
|---|
| 437 | ; | 
|---|
| 438 | FAILFAX ; BATCH CALL TO RETRIEVE ERX FAILED FAX STATUS | 
|---|
| 439 | ; RETURNS A COUNT OF FAILED FAXES AND AN ARRAY OF PATIENTS | 
|---|
| 440 | N VOR,ZRSLT | 
|---|
| 441 | S VOR("STATUS-SECTION-TYPE")="FailedFax" | 
|---|
| 442 | ;S VOR("ACCOUNT-PARTNERNAME")="demo" | 
|---|
| 443 | S VOR("SORT-ORDER")="A" | 
|---|
| 444 | S VOR("INCLUDE-SCHEMA")="N" | 
|---|
| 445 | S ZDUZ=$$PRIMARY^C0PMAIN() ; PRIMARY ERX USER FOR BATCH CALLS | 
|---|
| 446 | D SOAP^C0PWS1("ZRSLT","STATUS",ZDUZ,"","VOR") | 
|---|
| 447 | N ZCOUNT | 
|---|
| 448 | S ZCOUNT=$O(ZRSLT(""),-1) ; HOW MANY FAILED FAXES | 
|---|
| 449 | I +ZCOUNT=0 Q  ; NO FAILED FAXES | 
|---|
| 450 | ;I $G(ZRSLT(1,"RowCount"))=0 Q  ; NO FAILED FAXES | 
|---|
| 451 | ;I $G(ZRSLT(1,"RowCount"))="" Q  ; SHOULD NOT HAPPEN | 
|---|
| 452 | N XQA,XQAMSG,XQAID,XQAKILL | 
|---|
| 453 | S XQAID="C0P" ; GOING TO FIRST KILL ALL FAILED FAX ALERTS | 
|---|
| 454 | D DELETEA^XQALERT ; KILL ALL FAILED FAX ALERTS | 
|---|
| 455 | S XQA("G.ERX HELP DESK")="" | 
|---|
| 456 | ;S XQA(135)="" | 
|---|
| 457 | S XQAID="C0P" | 
|---|
| 458 | S XQAMSG="eRx: "_ZCOUNT_" Failed Faxes on ePrescribing" | 
|---|
| 459 | D SETUP^XQALERT ; CREATE NEW FAILED FAX ALERTS TO THE MAILGROUP | 
|---|
| 460 | Q | 
|---|
| 461 | ; | 
|---|
| 462 | RUN     ; USED TO PROCESS AN ALERT. THIS ROUTINE IS LISTED IN | 
|---|
| 463 | ; 0E/RR CPRS NOTIFICATIONS AS THE ROUTINE TO RUN TO PROCESS | 
|---|
| 464 | ; A C0P ERX ALERT | 
|---|
| 465 | W "MADE IT TO RUN C0PREFIL",! | 
|---|
| 466 | W XQADATA | 
|---|
| 467 | B | 
|---|
| 468 | Q | 
|---|
| 469 | ; | 
|---|
| 470 | GETALRT(ZARY,ZID)       ; LOOKS UP AN ALERT BY USING THE "RECORDID" FROM CPRS, | 
|---|
| 471 | ; PASSED BY VALUE IN ZID. RESULTS ARE RETURNED IN ZARY, PASSED BY NAME | 
|---|
| 472 | ;N ZIEN | 
|---|
| 473 | ;S ZIEN=$O(^XTV(8992.1,"B",ZID,"")) ;IEN IN THE ALERT TRACKING FILE | 
|---|
| 474 | ;I ZIEN="" W "ERROR RETRIEVING ALERT",! Q  ; | 
|---|
| 475 | D GETN^C0CRNF(ZARY,8992.1,ZID,"B") ; GET ALL THE ALERT FIELDS | 
|---|
| 476 | ; THE FORMAT IS @ZARY@("DATA FOR PROCESSING")="FILE^FIELD^VALUE" | 
|---|
| 477 | ; ALL POPULATED FIELDS (BUT NOT SUBFILES) ARE RETURNED | 
|---|
| 478 | Q | 
|---|
| 479 | ; | 
|---|
| 480 | UPDIE     ; INTERNAL ROUTINE TO CALL UPDATE^DIE AND CHECK FOR ERRORS | 
|---|
| 481 | K ZERR | 
|---|
| 482 | D CLEAN^DILF | 
|---|
| 483 | D UPDATE^DIE("","C0PFDA","","ZERR") | 
|---|
| 484 | I $D(ZERR) D  ; | 
|---|
| 485 | . W "ERROR",! | 
|---|
| 486 | . ZWR ZERR | 
|---|
| 487 | . B | 
|---|
| 488 | K C0PFDA | 
|---|
| 489 | Q | 
|---|
| 490 | ; | 
|---|
| 491 | FIND    ; FIND ALL CURRENT ALERTS | 
|---|
| 492 | N ZI S ZI="" ; DUZ | 
|---|
| 493 | F  S ZI=$O(^XTV(8992,"AXQAN","OR,0,11305",ZI)) Q:ZI=""  D  ; | 
|---|
| 494 | . N ZJ S ZJ="" ; TIME STAMP | 
|---|
| 495 | . F  S ZJ=$O(^XTV(8992,"AXQAN","OR,0,11305",ZI,ZJ)) Q:ZJ=""  D  ; | 
|---|
| 496 | . . N ZZ,ZT | 
|---|
| 497 | . . S ZZ=$G(^XTV(8992,ZI,"XQA",ZJ,0)) | 
|---|
| 498 | . . S ZT=$P(ZZ,U,2) | 
|---|
| 499 | . . Q:ZT="" | 
|---|
| 500 | . . S ZG=$O(^XTV(8992.1,"B",ZT,"")) | 
|---|
| 501 | . . Q:ZG="" | 
|---|
| 502 | . . S ZGUID=$G(^XTV(8992.1,ZG,2)) | 
|---|
| 503 | . . Q:ZGUID="" | 
|---|
| 504 | . . S ZGUID=$P(ZGUID,U,1) | 
|---|
| 505 | . . W !,ZI," ",ZJ," ",ZT," ",ZG," ",ZGUID | 
|---|
| 506 | . . ;ZWR ^XTV(8992.1,ZG,*) | 
|---|
| 507 | . . S G(ZJ,ZT,ZGUID)="" | 
|---|
| 508 | Q | 
|---|
| 509 | ; | 
|---|