- XQARPRT1 ;JLI/OAK_OIFO-ROUTINE TO PROVIDE COUNTS OF ALERTS ; Oct 03, 2022@03:26:24
- ;;8.0;KERNEL;**316,338,631,690,777**;Jul 10, 1995;Build 1
- ;Per VA Directive 6402, this routine should not be modified.
- ; based on an original routine AMNUALT
- EN1 ; OPT - generates a listing of the number of alerts a user has as well as last sign-on date, number of critical and/or abnomal imaging alerts, and the date of the oldest alert
- N XQACRIT S XQACRIT=0
- EN2 ;
- N XQASDT,XQAEDT,XQAC1,XQAORDER,Y,DIR,%ZIS,POP,ZTSAVE,ZTDESC,ZTRTN
- N SHOWDIV,DIVISION,I,DATE,DIRUT,SERVICE,SERVSRT,ALLSERV,XQAWORDS,XQAQTVAR
- I 'XQACRIT D WORDS^XQARPRT2("A") K Y
- S DIR(0)="NO",DIR("A")="Display users whose "_$S(XQACRIT:"CRITICAL ",1:"")_"ALERT count is at least"
- S DIR("B")=$S(XQACRIT:10,1:100) D ^DIR K DIR Q:Y'>0 S XQAC1=Y
- D DATES Q:Y'>0
- D QUERYDIV Q:$D(DIRUT) D ORDER Q:XQAORDER'>0
- S %ZIS="MQ" D ^%ZIS Q:POP I $D(IO("Q")) K IO("Q") S ZTRTN="DQ1^XQARPRT1",ZTDESC="How Many "_$S(XQACRIT:"Critical ",1:"")_"Alerts",ZTSAVE("*")="" D ^%ZTLOAD W:$G(ZTSK)>0 !,"Task number is ",ZTSK K ZTSK Q
- G DQ1
- ;
- CRITICAL ; OPT - generates a listing of users with more than a specified number of alerts containing CRITICAL or ABNORMAL IMAGING
- N XQACRIT S XQACRIT=1
- G EN2
- ;
- DATES ;
- S DIR(0)="DO^::EX",DIR("A")="START DATE" ; Add "EX" to require eXact data and Echo input, XU*8*690
- D ^DIR K DIR Q:Y'>0
- S XQASDT=Y
- S DIR(0)="DO^::EX"_XQASDT_":DT",DIR("A")="END DATE" ; Add "EX" to require eXact data and Echo input, XU*8*690
- D ^DIR K DIR Q:Y'>0
- S XQAEDT=Y_".24"
- Q
- ;
- QUERYDIV ;
- S DIR(0)="Y",DIR("A")="Breakout by One or More Divisions",DIR("?")="Entering YES will result in the entries being grouped by DIVISION." D ^DIR K DIR S DIVISION=+Y Q:$D(DIRUT)
- I DIVISION D Q:SHOWDIV'>0
- . S DIR(0)="Y",DIR("A")="Show ALL Divisions",DIR("?",1)="Entering YES will result in the analysis being performed for ALL Divisons,",DIR("?")="A NO will result in prompts to select which division(S) you want listed."
- . D ^DIR K DIR I +Y D I 1
- . . S DIR(0)="S^1:Show only as 'Multiple Division';2:Show in EACH Division",DIR("A")="If a user has more than one division"
- . . S DIR("?",1)="If New Person entries have multiple divisions, entering 1 will result in",DIR("?",2)="those entries being shown only under a heading of 'These users are assigned"
- . . S DIR("?",3)="to multiple divisions', while entering 2 will result in the data for a",DIR("?",4)="specific New Person entry being shown under each division heading which",DIR("?")="that entry may select."
- . . D ^DIR K DIR S SHOWDIV=+Y
- . . Q
- . E S SHOWDIV=2 D K DIRUT
- . . F I=1:1 S DIR(0)="PO^4:EMZ",DIR("A")="Select "_$S(I>1:"Another ",1:"")_"Division: " D ^DIR K DIR Q:Y'>0 S DIVISION($P(Y,U,2))=""
- . Q
- Q
- ;
- ORDER ;
- S DIR(0)="SO^;1:By Name;2:By Number;3:By Service/Section;",DIR("A")="Select the ordering of results desired",DIR("?",1)="Select a number to indicate how you would like the selected entries to be"
- S DIR("?",2)="listed by"_$S(DIVISION:" (Within Division)",1:"")_": the New Person entrie's Name; the Number of "_$S(DIVISION:"",1:$S(XQACRIT:"Critical ",1:"")_"Alerts,")
- S DIR("?")=$S(DIVISION:$S(XQACRIT:"Critical ",1:"")_"Alerts, ",1:"")_"or by Service/Section"
- D ^DIR K DIR S XQAORDER=+Y
- I XQAORDER=3 D Q:$D(DIRUT)
- . S DIR(0)="Y",DIR("A")="Show ALL Service/Sections",DIR("?",1)="Entering YES will result in the analysis being performed for ALL Services,",DIR("?")="A NO will result in prompts to select which Service(s) you want listed."
- . D ^DIR K DIR Q:$D(DIRUT) S ALLSERV=+Y
- . I 'ALLSERV D
- . . S DIR(0)="PO^49:EMZ" F I=1:1 S DIR("A")="Select "_$S(I>1:"Another ",1:"")_"Service/Section" D ^DIR Q:Y'>0 S SERVICE($E($P(Y,U,2),1,17))=""
- . . K DIR
- . . Q
- . S DIR(0)="S^;1:By Name;2:By Number;",DIR("A")="Within Service/Section order results by" D ^DIR K DIR S:$D(DIRUT) XQAORDER=0 Q:$D(DIRUT) S SERVSRT=+Y
- . Q
- Q
- ;
- DQ1 ;
- N XQAGLOB,XQAN1
- S XQAGLOB=$NA(^TMP("XQARPRT1",$J)) K @XQAGLOB
- U IO
- D G1,PRT
- I '$D(ZTQUEUED),+$G(XQAQTVAR)'>0 W ! U IO(0) S DIR(0)="E" D ^DIR K DIR W ! U IO ; XU*8*690 - Pause end of user terminal report
- D ^%ZISC
- K @XQAGLOB
- Q
- ;
- G1 ;gather
- N COUNT,MSG,DATE,CRITMSG
- F XQAN1=0:0 S XQAN1=$O(^XTV(8992,XQAN1)) Q:XQAN1'>0 D
- . S COUNT=0,OLDEST=0,NCRIT=0 F I=0:0 S I=$O(^XTV(8992,XQAN1,"XQA",I)) Q:I'>0 D
- . . S DATE=$P($P(^XTV(8992,XQAN1,"XQA",I,0),U,2),";",3) S:OLDEST=0 OLDEST=DATE\1 I (DATE<XQASDT)!(DATE>XQAEDT) Q
- . . S MSG=$$UP^XLFSTR($P(^XTV(8992,XQAN1,"XQA",I,0),U,3))
- . . S CRITMSG=$G(^XTV(8992,XQAN1,"XQA",I,0)) I CRITMSG'="" D ; begin P631
- . . I $D(XQAWORDS)'>0 S COUNT=COUNT+1 I $$CHKCRIT^XQALSUR2(CRITMSG) S NCRIT=NCRIT+1
- . . I $D(XQAWORDS)>1 D I MSG'="" S COUNT=COUNT+1
- . . . N MSG1,I,J S MSG1=MSG F J=0:0 S J=$O(XQAWORDS(J)) Q:J'>0 S MSG=MSG1 D Q:MSG'=""
- . . . . F I=0:0 S I=$O(XQAWORDS(J,I)) Q:I'>0 D I MSG'[XQAWORDS(J,I) S MSG="" Q
- . . . . . I $D(XQAWORDS)>1,MSG[XQAWORDS(J,I),$$CHKCRIT^XQALSUR2(CRITMSG) S NCRIT=NCRIT+1
- . . . . . Q
- . . . . Q
- . . . Q
- . . Q ; end P631
- . I $S(XQACRIT:NCRIT,1:COUNT)<XQAC1 Q
- . S VALUE=COUNT_U_XQAN1_U_$$FMTE^XLFDT(OLDEST,"5DZ")_U_NCRIT_U_$$GET1^DIQ(200,XQAN1_",",.01)
- . I DIVISION D I 1
- . . K XQARRAY,XQADIV S XQADIV=0 D GETS^DIQ(200,XQAN1_",","16*","","XQARRAY") S:'$D(XQARRAY) XQADIV(0)="",XQADIV=1 I $D(XQARRAY) D
- . . . N K,L S K="" F S K=$O(XQARRAY(200.02,K)) Q:K="" D
- . . . . I $D(DIVISION)'>1 S XQADIV(XQARRAY(200.02,K,.01))="",XQADIV=XQADIV+1
- . . . . E S L=XQARRAY(200.02,K,.01) I $D(DIVISION(L))>0 S XQADIV(L)="",XQADIV=XQADIV+1
- . . . I XQADIV>1,SHOWDIV=1 K XQADIV S XQADIV(99999)="",XQADIV=1
- . . . Q
- . . S K=$S($D(DIVISION)'>1:"",1:0) F S K=$O(XQADIV(K)) Q:K="" S @XQAGLOB@("DIV",K,"NAME",$$GET1^DIQ(200,XQAN1_",",.01)_XQAN1)=VALUE
- . . Q
- . E S @XQAGLOB@("NAME",$$GET1^DIQ(200,XQAN1_",",.01)_XQAN1)=VALUE
- . Q
- Q
- ;
- PRT ;print
- N NAME,NUMBER,LSIGNON,VALUE,XQAGLOB1,DIVNAME,XQAFP,XQASVCFP
- S (XQAFP,XQASVCFP)=1
- S XQAGLOB1=XQAGLOB
- I DIVISION D I 1
- . S DIVNAME="" F S DIVNAME=$O(@XQAGLOB@("DIV",DIVNAME)) Q:DIVNAME="" S XQAGLOB1=$NA(@XQAGLOB@("DIV",DIVNAME)) D HEADER,PRTLOC
- E D HEADER,PRTLOC
- Q
- ;
- PRTLOC ;
- N PRTLOC
- S PRTLOC=$S(XQAORDER=1:"PRTNAME",XQAORDER=2:"PRTNUMBR",1:"PRTSERVC") D @PRTLOC
- Q
- ;
- N XQACTR SET XQACTR=0 ; XU*8*690 - For WORDHDR^XQARPRT2
- I '$D(ZTQUEUED) W @IOF ; XU*8*690 - Initial FormFeed for home device (screen)
- I $D(ZTQUEUED),'XQAFP W @IOF ; XU*8*690 - FormFeed page when queued (Printer)
- S XQAFP=0
- W " COUNT of ",$S($D(XQAWORDS)>1:"SELECTED ",1:""),"ALERTS - users with more than ",XQAC1," on ",$$FMTE^XLFDT($$NOW^XLFDT())
- W !," for date range ",$$FMTE^XLFDT(XQASDT,"5DZ")," to ",$$FMTE^XLFDT(XQAEDT,"5DZ")
- W !,"CRIT column indicates number of alerts containing critical text"
- D WORDHDR^XQARPRT2
- W !!,?42,$S($D(XQAWORDS)>1:"Selected",1:" Total"),?70,"Oldest"
- W !,"Name",?25,"Service/section",?43,"Alerts",?50,"Last Sign-on",?64,"CRIT Alert"
- W !,"-----------------",?25,"-----------------",?43,"------",?50,"------------",?64,"---- ----------"
- I $D(DIVNAME) D DIVPRINT
- Q
- ;
- PRTNAME ;
- N NAME,NUMBER,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- S FSTNOSVC=0 ; XU*8*690 - LIMIT ERROR tracking
- S NAME="" F S NAME=$O(@XQAGLOB1@("NAME",NAME)) Q:NAME="" S VALUE=@XQAGLOB1@("NAME",NAME) D PRINTVAL(0,.FSTNOSVC) Q:+$G(XQAQTVAR)>0 ; XU*8*690 - Quit on Terminal pause
- Q
- ;
- PRTNUMBR ;
- N NAME,NUMBER,NUMB,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- S FSTNOSVC=0 ; XU*8*690 - LIMIT ERROR tracking
- S NAME="" F S NAME=$O(@XQAGLOB1@("NAME",NAME)) Q:NAME="" Q:+$G(XQAQTVAR)>0 D ; XU*8*690 - Quit on Terminal pause
- . S NUMBER=$S(XQACRIT:$P(@XQAGLOB1@("NAME",NAME),U,4),1:+@XQAGLOB1@("NAME",NAME))
- . S @XQAGLOB1@("NUMB",100000-NUMBER,NAME)=@XQAGLOB1@("NAME",NAME)
- . Q
- N NUMB
- S NUMB=""
- F S NUMB=$O(@XQAGLOB1@("NUMB",NUMB)) Q:NUMB="" Q:+$G(XQAQTVAR)>0 S NAME="" DO
- . F S NAME=$O(@XQAGLOB1@("NUMB",NUMB,NAME)) Q:NAME="" Q:+$G(XQAQTVAR)>0 DO
- . . S VALUE=@XQAGLOB1@("NUMB",NUMB,NAME) D PRINTVAL(0,.FSTNOSVC) ; XU*8*690 - Quit on Terminal pause
- Q
- ;
- PRTSERVC ;
- N NAME,NUMBER,NUMB,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- S FSTNOSVC=0 ; XU*8*690 - LIMIT ERROR tracking
- S NAME=""
- F S NAME=$O(@XQAGLOB1@("NAME",NAME)) Q:NAME="" Q:+$G(XQAQTVAR)>0 D ; XU*8*690 - Quit on Terminal pause
- . S XQAN1=$P(@XQAGLOB1@("NAME",NAME),U,2)
- . S SERVICE=$E($$GET1^DIQ(200,XQAN1_",",29),1,17) I SERVICE="" S SERVICE="<No Service>"
- . I ALLSERV!$D(SERVICE(SERVICE)) D
- . . I SERVSRT=1 S @XQAGLOB1@("SERV",SERVICE,NAME)=@XQAGLOB1@("NAME",NAME) Q
- . . I SERVSRT=2 S @XQAGLOB1@("SERV",SERVICE,"NUMB",100000-@XQAGLOB1@("NAME",NAME),NAME)=@XQAGLOB1@("NAME",NAME)
- . . Q
- . Q
- S SERVICE=""
- F S SERVICE=$O(@XQAGLOB1@("SERV",SERVICE)) Q:SERVICE="" Q:+$G(XQAQTVAR)>0 D ; XU*8*690 - Quit on Terminal pause
- . SET XQASVCFP=0
- . I SERVSRT=1 DO
- . . S NAME=""
- . . F S NAME=$O(@XQAGLOB1@("SERV",SERVICE,NAME)) Q:NAME="" Q:+$G(XQAQTVAR)>0 DO
- . . . S VALUE=@XQAGLOB1@("SERV",SERVICE,NAME)
- . . . D PRINTVAL($$CHKSRV(XQAGLOB1,SERVICE,NAME,"NAME"),.FSTNOSVC) ; XU*8*690 - Terminal pause last service item
- . I SERVSRT=2 DO
- . . F NUMB=0:0 S NUMB=$O(@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB)) Q:+NUMB'>0 Q:+$G(XQAQTVAR)>0 D ; XU*8*690 - Quit on Terminal pause
- . . . S NAME=""
- . . . F S NAME=$O(@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB,NAME)) Q:NAME="" Q:+$G(XQAQTVAR)>0 DO
- . . . . S VALUE=@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB,NAME)
- . . . . D PRINTVAL($$CHKSRV(XQAGLOB1,SERVICE,NAME,"NUMB",NUMB),.FSTNOSVC) ; XU*8*690 - Terminal pause last service item
- . . Q
- . Q
- Q
- ;
- CHKSRV(XQAGLOB1,XQASRVC,XQACNAME,XQATYPE,XQANUM) ; Determine change to SERVICE/SECTION, XU*8*690
- ; Input:
- ; XQAGLOB1 - Value of ^TMP global root
- ; XQASRVC - Current Service
- ; XQASNAME - Current Name
- ; XQATYPE - Type of Report ("NUMB", "NAME")
- ; XQANUM - Number of Alerts (For Service report on Number)
- ;
- ; Result:
- ; 0 - Service did not change
- ; 1 - Service changed
- ;
- N RESULT,NXTSERV,XQANNAME,XQANNUM
- S (CHKCNT,RESULT)=0
- I XQATYPE="NAME" DO
- . SET:$O(@XQAGLOB1@("SERV",XQASRVC,XQACNAME))="" RESULT=1
- . IF RESULT=1 DO
- . . SET:$O(@XQAGLOB1@("SERV",XQASRVC))="" RESULT=0
- ;
- I XQATYPE="NUMB" DO
- . SET XQANNAME=$O(@XQAGLOB1@("SERV",XQASRVC,"NUMB",XQANUM,XQACNAME))
- . IF XQANNAME="" DO
- . . SET XQANNUM=$O(@XQAGLOB1@("SERV",XQASRVC,"NUMB",XQANUM))
- . . IF XQANNUM="" DO
- . . . SET NXTSERVC=$O(@XQAGLOB1@("SERV",XQASRVC))
- . . . IF (NXTSERVC'=XQASRVC),(NXTSERVC'="") SET RESULT=1
- Q RESULT
- ;
- PRINTVAL(XQAPAWS,FSTNOSVC) ;Print report value
- ; Input ; Add to indicate if report needs page break, XU*8*690
- ; XQAPAWS - 1: New Service
- ; 0: Same Service
- ; FSTNOSVC - 1: First line (No Service) written after ERROR LIMIT exceeded
- ; 0: First line NOT written after ERROR LIMIT exceeded
- ;
- N NAME,SRVERRCT,XQAWRTER
- S NUMBER=+VALUE,XQAN1=$P(VALUE,U,2),NCRIT=$P(VALUE,U,4),OLDEST=$P(VALUE,U,3),NAME=$P(VALUE,U,5)
- S SERVICE=$E($$GET1^DIQ(200,XQAN1_",",29),1,17)
- ;
- IF SERVICE="" DO ;XU*8*690 - Report <No Service> - SERVICE/SECTION not defined for user, Error Trap
- . NEW XQANOTES,XQAZTR,XQAFCNT,XQAZTEN
- . SET SERVICE="<No Service>"
- . SET XQAZTEN=$O(^%ZTER(3.077,"B",$E("Undefined SERVICE/SECTION Err",1,30),0))
- . IF 'XQAZTEN SET SRVERRCT=1
- . IF XQAZTEN DO
- . . SET SRVERRCT=0
- . . SET XQAZTR=$G(^%ZTER(3.077,XQAZTEN,4,+$H,0))
- . . FOR XQAFCNT=1:1:24 S SRVERRCT=SRVERRCT+$P(XQAZTR,"~",XQAFCNT)
- . . SET SRVERRCT=SRVERRCT+1
- . SET XQAWRTER=(SRVERRCT>$$XQZMAXER()) ;Error limit reached?
- . ;XQANOTES array = "ERROR description for inclusion in ERROR trap"
- . SET XQANOTES("PROGRAMMER",1,"WHAT HAPPENED")="Kernel Alerts Report included a user with a pending alert that did NOT have a SERVICE/SECTION in the New Person File."
- . SET XQANOTES("PROGRAMMER",2,"MENU REPORT OPTION")=$P($G(XQY0),"^",1,2)
- . SET XQANOTES("PROGRAMMER",3,"PROBLEM")="SERVICE/SECTION is a required field for all active VistA Users."
- . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",1)="Rerunning the report with the parameters in this log may or may not report all of the users missing SERVICE/SECTION."
- . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",2)="Users with alerts that have been processed since this log was recorded will not be reported."
- . IF SRVERRCT=$$XQZMAXER() DO
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",3)="The MENU REPORT OPTION will only create an Error Trap log for the first "_$$XQZMAXER()_" users missing SERVICE/SECTION."
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",4)="The daily Error Trap limit of "_$$XQZMAXER()_" is determined by the KERNEL SYSTEM PARAMETERS file (#8989.3), ERROR LIMIT field(#520.1)."
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",5)="The MENU REPORT OPTION includes a message after the limit of "_$$XQZMAXER()_" users missing SERVICE/SECTION is reached."
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",6)="When user number "_($$XQZMAXER()+1)_" missing SERVICE/SECTION is reported, the message is printed on the report but Error Traps are not logged."
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",7)="1st Message on report: 'Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION.'"
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",8)="2nd Message on report: Limit Reached. 'No more entries will be added for '<No Service>' users today!'"
- . . SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",9)="Any users on the report following that message will not be recorded in the Error Trap."
- . ;D APPERROR^%ZTER("Undefined SERVICE/SECTION Err") ;p777 comment out.
- ;
- S LSIGNON=$$GET1^DIQ(200,XQAN1_",",202)
- I LSIGNON["@" S LSIGNON=$P(LSIGNON,"@")
- I $Y>(IOSL-5) DO
- . I '$D(ZTQUEUED) W ! DO XQAPAUS(.XQAQTVAR)
- . I +$G(XQAQTVAR)'>0 D HEADER
- ;
- I +$G(XQAQTVAR)'>0 DO
- . ;XU*8*690 - Error trap limit exceeded
- . IF (SERVICE="<No Service>"),(+$$XQZMAXER()>0) DO ;Errors limited
- . . IF (SRVERRCT=($$XQZMAXER()+1)) DO
- . . . W !," Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION."
- . . . W !," Limit Reached. No more entries will be added for '<No Service>' users today!"
- . . . SET FSTNOSVC=1
- . . IF XQAWRTER,'FSTNOSVC DO ;Error limit reached before report
- . . . W !," Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION."
- . . . W !," Limit Reached. No more entries will be added for '<No Service>' users today!"
- . . . SET FSTNOSVC=1
- . W !,NAME,?25,SERVICE,?43,NUMBER,?50,LSIGNON,?64,NCRIT,?69,OLDEST
- ;
- I $G(XQAPAWS)>0 DO
- . I '$D(ZTQUEUED) W ! DO XQAPAUS(.XQAQTVAR)
- . I +$G(XQAQTVAR)'>0 D HEADER
- Q
- ;
- XQAPAUS(XQAQTVAR) ;; Pause API, XU*8*690
- U IO(0) S DIR(0)="E" D ^DIR
- IF $D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT) SET XQAQTVAR=1
- KILL DIR,X,Y,DTOUT,DUOUT,DIRUT,DIROUT
- Q
- ;
- XQZMAXER() ;;Return KERNEL SYSTEM PARAMETER file (#8989.3) ERROR LIMIT field (#520.1), XU*8*690
- Q +$P($G(^XTV(8989.3,1,"ZTER"),"10"),"^",1)
- ;
- DIVPRINT ;
- I $Y>(IOSL-6) D HEADER
- W !,?5,"Division: ",$S(DIVNAME=0:"These users are not assigned to a division",DIVNAME=99999:"These users are assigned to multiple divisions",1:DIVNAME)
- Q
- ;
- OLDEST() ; Returns date of oldest entry in alert tracking file
- N OLDEST,I,J,FND
- ; Use cross-ref, since if user data used to create entries in tracking file oldest may not be first in file
- ; Make sure cross-ref is valid
- S FND=0 F I=0:0 Q:FND S I=$O(^XTV(8992.1,"D",I)) Q:I'>0 F J=0:0 S J=$O(^XTV(8992.1,"D",I,J)) Q:J'>0 I $D(^XTV(8992.1,J,0)) S FND=1 Q
- S OLDEST=I S:OLDEST'>0 OLDEST=DT+1
- Q OLDEST\1
- ;
- VIEWTRAK ; OPT. View an entry in the Alert Tracking file in Captioned mode
- N DIR,X0,X1,DAARRAY
- S X0=$O(^XTV(8992.1,0)),X1=$P(^XTV(8992.1,0),U,3)
- S DIR(0)="NO^"_X0_":"_X1
- F I=1:1 S DIR("A")=$S(I>1:"Another ",1:"")_"Internal Entry number in Alert Tracking File" D ^DIR K DIRUT Q:Y'>0 S DAARRAY(I)=+Y
- K DIR Q:$D(DAARRAY)'>1
- S %ZIS="MQ" D ^%ZIS Q:POP I $D(IO("Q")) K IO("Q") S ZTRTN="VIEWDQ^XQARPRT1",ZTDESC="List data from Alert Tracking file",ZTSAVE("*")="" D ^%ZTLOAD W:$G(ZTSK)>0 !,"Task number is ",ZTSK K ZTSK Q
- ;
- VIEWDQ ;
- N DIC,DA,DIC,XQAI,DR,DIQ
- W @IOF
- S DIQ(0)="CR"
- F XQAI=0:0 S XQAI=$O(DAARRAY(XQAI)) Q:XQAI'>0 D
- . S DA=DAARRAY(XQAI),DIC="^XTV(8992.1," D EN^DIQ
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HXQARPRT1 16412 printed Mar 13, 2025@21:10:26 Page 2
- XQARPRT1 ;JLI/OAK_OIFO-ROUTINE TO PROVIDE COUNTS OF ALERTS ; Oct 03, 2022@03:26:24
- +1 ;;8.0;KERNEL;**316,338,631,690,777**;Jul 10, 1995;Build 1
- +2 ;Per VA Directive 6402, this routine should not be modified.
- +3 ; based on an original routine AMNUALT
- EN1 ; OPT - generates a listing of the number of alerts a user has as well as last sign-on date, number of critical and/or abnomal imaging alerts, and the date of the oldest alert
- +1 NEW XQACRIT
- SET XQACRIT=0
- EN2 ;
- +1 NEW XQASDT,XQAEDT,XQAC1,XQAORDER,Y,DIR,%ZIS,POP,ZTSAVE,ZTDESC,ZTRTN
- +2 NEW SHOWDIV,DIVISION,I,DATE,DIRUT,SERVICE,SERVSRT,ALLSERV,XQAWORDS,XQAQTVAR
- +3 IF 'XQACRIT
- DO WORDS^XQARPRT2("A")
- KILL Y
- +4 SET DIR(0)="NO"
- SET DIR("A")="Display users whose "_$SELECT(XQACRIT:"CRITICAL ",1:"")_"ALERT count is at least"
- +5 SET DIR("B")=$SELECT(XQACRIT:10,1:100)
- DO ^DIR
- KILL DIR
- if Y'>0
- QUIT
- SET XQAC1=Y
- +6 DO DATES
- if Y'>0
- QUIT
- +7 DO QUERYDIV
- if $DATA(DIRUT)
- QUIT
- DO ORDER
- if XQAORDER'>0
- QUIT
- +8 SET %ZIS="MQ"
- DO ^%ZIS
- if POP
- QUIT
- IF $DATA(IO("Q"))
- KILL IO("Q")
- SET ZTRTN="DQ1^XQARPRT1"
- SET ZTDESC="How Many "_$SELECT(XQACRIT:"Critical ",1:"")_"Alerts"
- SET ZTSAVE("*")=""
- DO ^%ZTLOAD
- if $GET(ZTSK)>0
- WRITE !,"Task number is ",ZTSK
- KILL ZTSK
- QUIT
- +9 GOTO DQ1
- +10 ;
- CRITICAL ; OPT - generates a listing of users with more than a specified number of alerts containing CRITICAL or ABNORMAL IMAGING
- +1 NEW XQACRIT
- SET XQACRIT=1
- +2 GOTO EN2
- +3 ;
- DATES ;
- +1 ; Add "EX" to require eXact data and Echo input, XU*8*690
- SET DIR(0)="DO^::EX"
- SET DIR("A")="START DATE"
- +2 DO ^DIR
- KILL DIR
- if Y'>0
- QUIT
- +3 SET XQASDT=Y
- +4 ; Add "EX" to require eXact data and Echo input, XU*8*690
- SET DIR(0)="DO^::EX"_XQASDT_":DT"
- SET DIR("A")="END DATE"
- +5 DO ^DIR
- KILL DIR
- if Y'>0
- QUIT
- +6 SET XQAEDT=Y_".24"
- +7 QUIT
- +8 ;
- QUERYDIV ;
- +1 SET DIR(0)="Y"
- SET DIR("A")="Breakout by One or More Divisions"
- SET DIR("?")="Entering YES will result in the entries being grouped by DIVISION."
- DO ^DIR
- KILL DIR
- SET DIVISION=+Y
- if $DATA(DIRUT)
- QUIT
- +2 IF DIVISION
- Begin DoDot:1
- +3 SET DIR(0)="Y"
- SET DIR("A")="Show ALL Divisions"
- SET DIR("?",1)="Entering YES will result in the analysis being performed for ALL Divisons,"
- SET DIR("?")="A NO will result in prompts to select which division(S) you want listed."
- +4 DO ^DIR
- KILL DIR
- IF +Y
- Begin DoDot:2
- +5 SET DIR(0)="S^1:Show only as 'Multiple Division';2:Show in EACH Division"
- SET DIR("A")="If a user has more than one division"
- +6 SET DIR("?",1)="If New Person entries have multiple divisions, entering 1 will result in"
- SET DIR("?",2)="those entries being shown only under a heading of 'These users are assigned"
- +7 SET DIR("?",3)="to multiple divisions', while entering 2 will result in the data for a"
- SET DIR("?",4)="specific New Person entry being shown under each division heading which"
- SET DIR("?")="that entry may select."
- +8 DO ^DIR
- KILL DIR
- SET SHOWDIV=+Y
- +9 QUIT
- End DoDot:2
- IF 1
- +10 IF '$TEST
- SET SHOWDIV=2
- Begin DoDot:2
- +11 FOR I=1:1
- SET DIR(0)="PO^4:EMZ"
- SET DIR("A")="Select "_$SELECT(I>1:"Another ",1:"")_"Division: "
- DO ^DIR
- KILL DIR
- if Y'>0
- QUIT
- SET DIVISION($PIECE(Y,U,2))=""
- End DoDot:2
- KILL DIRUT
- +12 QUIT
- End DoDot:1
- if SHOWDIV'>0
- QUIT
- +13 QUIT
- +14 ;
- ORDER ;
- +1 SET DIR(0)="SO^;1:By Name;2:By Number;3:By Service/Section;"
- SET DIR("A")="Select the ordering of results desired"
- SET DIR("?",1)="Select a number to indicate how you would like the selected entries to be"
- +2 SET DIR("?",2)="listed by"_$SELECT(DIVISION:" (Within Division)",1:"")_": the New Person entrie's Name; the Number of "_$SELECT(DIVISION:"",1:$SELECT(XQACRIT:"Critical ",1:"")_"Alerts,")
- +3 SET DIR("?")=$SELECT(DIVISION:$SELECT(XQACRIT:"Critical ",1:"")_"Alerts, ",1:"")_"or by Service/Section"
- +4 DO ^DIR
- KILL DIR
- SET XQAORDER=+Y
- +5 IF XQAORDER=3
- Begin DoDot:1
- +6 SET DIR(0)="Y"
- SET DIR("A")="Show ALL Service/Sections"
- SET DIR("?",1)="Entering YES will result in the analysis being performed for ALL Services,"
- SET DIR("?")="A NO will result in prompts to select which Service(s) you want listed."
- +7 DO ^DIR
- KILL DIR
- if $DATA(DIRUT)
- QUIT
- SET ALLSERV=+Y
- +8 IF 'ALLSERV
- Begin DoDot:2
- +9 SET DIR(0)="PO^49:EMZ"
- FOR I=1:1
- SET DIR("A")="Select "_$SELECT(I>1:"Another ",1:"")_"Service/Section"
- DO ^DIR
- if Y'>0
- QUIT
- SET SERVICE($EXTRACT($PIECE(Y,U,2),1,17))=""
- +10 KILL DIR
- +11 QUIT
- End DoDot:2
- +12 SET DIR(0)="S^;1:By Name;2:By Number;"
- SET DIR("A")="Within Service/Section order results by"
- DO ^DIR
- KILL DIR
- if $DATA(DIRUT)
- SET XQAORDER=0
- if $DATA(DIRUT)
- QUIT
- SET SERVSRT=+Y
- +13 QUIT
- End DoDot:1
- if $DATA(DIRUT)
- QUIT
- +14 QUIT
- +15 ;
- DQ1 ;
- +1 NEW XQAGLOB,XQAN1
- +2 SET XQAGLOB=$NAME(^TMP("XQARPRT1",$JOB))
- KILL @XQAGLOB
- +3 USE IO
- +4 DO G1
- DO PRT
- +5 ; XU*8*690 - Pause end of user terminal report
- IF '$DATA(ZTQUEUED)
- IF +$GET(XQAQTVAR)'>0
- WRITE !
- USE IO(0)
- SET DIR(0)="E"
- DO ^DIR
- KILL DIR
- WRITE !
- USE IO
- +6 DO ^%ZISC
- +7 KILL @XQAGLOB
- +8 QUIT
- +9 ;
- G1 ;gather
- +1 NEW COUNT,MSG,DATE,CRITMSG
- +2 FOR XQAN1=0:0
- SET XQAN1=$ORDER(^XTV(8992,XQAN1))
- if XQAN1'>0
- QUIT
- Begin DoDot:1
- +3 SET COUNT=0
- SET OLDEST=0
- SET NCRIT=0
- FOR I=0:0
- SET I=$ORDER(^XTV(8992,XQAN1,"XQA",I))
- if I'>0
- QUIT
- Begin DoDot:2
- +4 SET DATE=$PIECE($PIECE(^XTV(8992,XQAN1,"XQA",I,0),U,2),";",3)
- if OLDEST=0
- SET OLDEST=DATE\1
- IF (DATE<XQASDT)!(DATE>XQAEDT)
- QUIT
- +5 SET MSG=$$UP^XLFSTR($PIECE(^XTV(8992,XQAN1,"XQA",I,0),U,3))
- +6 ; begin P631
- SET CRITMSG=$GET(^XTV(8992,XQAN1,"XQA",I,0))
- IF CRITMSG'=""
- Begin DoDot:3
- End DoDot:3
- +7 IF $DATA(XQAWORDS)'>0
- SET COUNT=COUNT+1
- IF $$CHKCRIT^XQALSUR2(CRITMSG)
- SET NCRIT=NCRIT+1
- +8 IF $DATA(XQAWORDS)>1
- Begin DoDot:3
- +9 NEW MSG1,I,J
- SET MSG1=MSG
- FOR J=0:0
- SET J=$ORDER(XQAWORDS(J))
- if J'>0
- QUIT
- SET MSG=MSG1
- Begin DoDot:4
- +10 FOR I=0:0
- SET I=$ORDER(XQAWORDS(J,I))
- if I'>0
- QUIT
- Begin DoDot:5
- +11 IF $DATA(XQAWORDS)>1
- IF MSG[XQAWORDS(J,I)
- IF $$CHKCRIT^XQALSUR2(CRITMSG)
- SET NCRIT=NCRIT+1
- +12 QUIT
- End DoDot:5
- IF MSG'[XQAWORDS(J,I)
- SET MSG=""
- QUIT
- +13 QUIT
- End DoDot:4
- if MSG'=""
- QUIT
- +14 QUIT
- End DoDot:3
- IF MSG'=""
- SET COUNT=COUNT+1
- +15 ; end P631
- QUIT
- End DoDot:2
- +16 IF $SELECT(XQACRIT:NCRIT,1:COUNT)<XQAC1
- QUIT
- +17 SET VALUE=COUNT_U_XQAN1_U_$$FMTE^XLFDT(OLDEST,"5DZ")_U_NCRIT_U_$$GET1^DIQ(200,XQAN1_",",.01)
- +18 IF DIVISION
- Begin DoDot:2
- +19 KILL XQARRAY,XQADIV
- SET XQADIV=0
- DO GETS^DIQ(200,XQAN1_",","16*","","XQARRAY")
- if '$DATA(XQARRAY)
- SET XQADIV(0)=""
- SET XQADIV=1
- IF $DATA(XQARRAY)
- Begin DoDot:3
- +20 NEW K,L
- SET K=""
- FOR
- SET K=$ORDER(XQARRAY(200.02,K))
- if K=""
- QUIT
- Begin DoDot:4
- +21 IF $DATA(DIVISION)'>1
- SET XQADIV(XQARRAY(200.02,K,.01))=""
- SET XQADIV=XQADIV+1
- +22 IF '$TEST
- SET L=XQARRAY(200.02,K,.01)
- IF $DATA(DIVISION(L))>0
- SET XQADIV(L)=""
- SET XQADIV=XQADIV+1
- End DoDot:4
- +23 IF XQADIV>1
- IF SHOWDIV=1
- KILL XQADIV
- SET XQADIV(99999)=""
- SET XQADIV=1
- +24 QUIT
- End DoDot:3
- +25 SET K=$SELECT($DATA(DIVISION)'>1:"",1:0)
- FOR
- SET K=$ORDER(XQADIV(K))
- if K=""
- QUIT
- SET @XQAGLOB@("DIV",K,"NAME",$$GET1^DIQ(200,XQAN1_",",.01)_XQAN1)=VALUE
- +26 QUIT
- End DoDot:2
- IF 1
- +27 IF '$TEST
- SET @XQAGLOB@("NAME",$$GET1^DIQ(200,XQAN1_",",.01)_XQAN1)=VALUE
- +28 QUIT
- End DoDot:1
- +29 QUIT
- +30 ;
- PRT ;print
- +1 NEW NAME,NUMBER,LSIGNON,VALUE,XQAGLOB1,DIVNAME,XQAFP,XQASVCFP
- +2 SET (XQAFP,XQASVCFP)=1
- +3 SET XQAGLOB1=XQAGLOB
- +4 IF DIVISION
- Begin DoDot:1
- +5 SET DIVNAME=""
- FOR
- SET DIVNAME=$ORDER(@XQAGLOB@("DIV",DIVNAME))
- if DIVNAME=""
- QUIT
- SET XQAGLOB1=$NAME(@XQAGLOB@("DIV",DIVNAME))
- DO HEADER
- DO PRTLOC
- End DoDot:1
- IF 1
- +6 IF '$TEST
- DO HEADER
- DO PRTLOC
- +7 QUIT
- +8 ;
- PRTLOC ;
- +1 NEW PRTLOC
- +2 SET PRTLOC=$SELECT(XQAORDER=1:"PRTNAME",XQAORDER=2:"PRTNUMBR",1:"PRTSERVC")
- DO @PRTLOC
- +3 QUIT
- +4 ;
- +1 ; XU*8*690 - For WORDHDR^XQARPRT2
- NEW XQACTR
- SET XQACTR=0
- +2 ; XU*8*690 - Initial FormFeed for home device (screen)
- IF '$DATA(ZTQUEUED)
- WRITE @IOF
- +3 ; XU*8*690 - FormFeed page when queued (Printer)
- IF $DATA(ZTQUEUED)
- IF 'XQAFP
- WRITE @IOF
- +4 SET XQAFP=0
- +5 WRITE " COUNT of ",$SELECT($DATA(XQAWORDS)>1:"SELECTED ",1:""),"ALERTS - users with more than ",XQAC1," on ",$$FMTE^XLFDT($$NOW^XLFDT())
- +6 WRITE !," for date range ",$$FMTE^XLFDT(XQASDT,"5DZ")," to ",$$FMTE^XLFDT(XQAEDT,"5DZ")
- +7 WRITE !,"CRIT column indicates number of alerts containing critical text"
- +8 DO WORDHDR^XQARPRT2
- +9 WRITE !!,?42,$SELECT($DATA(XQAWORDS)>1:"Selected",1:" Total"),?70,"Oldest"
- +10 WRITE !,"Name",?25,"Service/section",?43,"Alerts",?50,"Last Sign-on",?64,"CRIT Alert"
- +11 WRITE !,"-----------------",?25,"-----------------",?43,"------",?50,"------------",?64,"---- ----------"
- +12 IF $DATA(DIVNAME)
- DO DIVPRINT
- +13 QUIT
- +14 ;
- PRTNAME ;
- +1 NEW NAME,NUMBER,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- +2 ; XU*8*690 - LIMIT ERROR tracking
- SET FSTNOSVC=0
- +3 ; XU*8*690 - Quit on Terminal pause
- SET NAME=""
- FOR
- SET NAME=$ORDER(@XQAGLOB1@("NAME",NAME))
- if NAME=""
- QUIT
- SET VALUE=@XQAGLOB1@("NAME",NAME)
- DO PRINTVAL(0,.FSTNOSVC)
- if +$GET(XQAQTVAR)>0
- QUIT
- +4 QUIT
- +5 ;
- PRTNUMBR ;
- +1 NEW NAME,NUMBER,NUMB,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- +2 ; XU*8*690 - LIMIT ERROR tracking
- SET FSTNOSVC=0
- +3 ; XU*8*690 - Quit on Terminal pause
- SET NAME=""
- FOR
- SET NAME=$ORDER(@XQAGLOB1@("NAME",NAME))
- if NAME=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:1
- +4 SET NUMBER=$SELECT(XQACRIT:$PIECE(@XQAGLOB1@("NAME",NAME),U,4),1:+@XQAGLOB1@("NAME",NAME))
- +5 SET @XQAGLOB1@("NUMB",100000-NUMBER,NAME)=@XQAGLOB1@("NAME",NAME)
- +6 QUIT
- End DoDot:1
- +7 NEW NUMB
- +8 SET NUMB=""
- +9 FOR
- SET NUMB=$ORDER(@XQAGLOB1@("NUMB",NUMB))
- if NUMB=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- SET NAME=""
- Begin DoDot:1
- +10 FOR
- SET NAME=$ORDER(@XQAGLOB1@("NUMB",NUMB,NAME))
- if NAME=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:2
- +11 ; XU*8*690 - Quit on Terminal pause
- SET VALUE=@XQAGLOB1@("NUMB",NUMB,NAME)
- DO PRINTVAL(0,.FSTNOSVC)
- End DoDot:2
- End DoDot:1
- +12 QUIT
- +13 ;
- PRTSERVC ;
- +1 NEW NAME,NUMBER,NUMB,VALUE,XQAN1,NCRIT,OLDEST,LSIGNON,FSTNOSVC
- +2 ; XU*8*690 - LIMIT ERROR tracking
- SET FSTNOSVC=0
- +3 SET NAME=""
- +4 ; XU*8*690 - Quit on Terminal pause
- FOR
- SET NAME=$ORDER(@XQAGLOB1@("NAME",NAME))
- if NAME=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:1
- +5 SET XQAN1=$PIECE(@XQAGLOB1@("NAME",NAME),U,2)
- +6 SET SERVICE=$EXTRACT($$GET1^DIQ(200,XQAN1_",",29),1,17)
- IF SERVICE=""
- SET SERVICE="<No Service>"
- +7 IF ALLSERV!$DATA(SERVICE(SERVICE))
- Begin DoDot:2
- +8 IF SERVSRT=1
- SET @XQAGLOB1@("SERV",SERVICE,NAME)=@XQAGLOB1@("NAME",NAME)
- QUIT
- +9 IF SERVSRT=2
- SET @XQAGLOB1@("SERV",SERVICE,"NUMB",100000-@XQAGLOB1@("NAME",NAME),NAME)=@XQAGLOB1@("NAME",NAME)
- +10 QUIT
- End DoDot:2
- +11 QUIT
- End DoDot:1
- +12 SET SERVICE=""
- +13 ; XU*8*690 - Quit on Terminal pause
- FOR
- SET SERVICE=$ORDER(@XQAGLOB1@("SERV",SERVICE))
- if SERVICE=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:1
- +14 SET XQASVCFP=0
- +15 IF SERVSRT=1
- Begin DoDot:2
- +16 SET NAME=""
- +17 FOR
- SET NAME=$ORDER(@XQAGLOB1@("SERV",SERVICE,NAME))
- if NAME=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:3
- +18 SET VALUE=@XQAGLOB1@("SERV",SERVICE,NAME)
- +19 ; XU*8*690 - Terminal pause last service item
- DO PRINTVAL($$CHKSRV(XQAGLOB1,SERVICE,NAME,"NAME"),.FSTNOSVC)
- End DoDot:3
- End DoDot:2
- +20 IF SERVSRT=2
- Begin DoDot:2
- +21 ; XU*8*690 - Quit on Terminal pause
- FOR NUMB=0:0
- SET NUMB=$ORDER(@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB))
- if +NUMB'>0
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:3
- +22 SET NAME=""
- +23 FOR
- SET NAME=$ORDER(@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB,NAME))
- if NAME=""
- QUIT
- if +$GET(XQAQTVAR)>0
- QUIT
- Begin DoDot:4
- +24 SET VALUE=@XQAGLOB1@("SERV",SERVICE,"NUMB",NUMB,NAME)
- +25 ; XU*8*690 - Terminal pause last service item
- DO PRINTVAL($$CHKSRV(XQAGLOB1,SERVICE,NAME,"NUMB",NUMB),.FSTNOSVC)
- End DoDot:4
- End DoDot:3
- +26 QUIT
- End DoDot:2
- +27 QUIT
- End DoDot:1
- +28 QUIT
- +29 ;
- CHKSRV(XQAGLOB1,XQASRVC,XQACNAME,XQATYPE,XQANUM) ; Determine change to SERVICE/SECTION, XU*8*690
- +1 ; Input:
- +2 ; XQAGLOB1 - Value of ^TMP global root
- +3 ; XQASRVC - Current Service
- +4 ; XQASNAME - Current Name
- +5 ; XQATYPE - Type of Report ("NUMB", "NAME")
- +6 ; XQANUM - Number of Alerts (For Service report on Number)
- +7 ;
- +8 ; Result:
- +9 ; 0 - Service did not change
- +10 ; 1 - Service changed
- +11 ;
- +12 NEW RESULT,NXTSERV,XQANNAME,XQANNUM
- +13 SET (CHKCNT,RESULT)=0
- +14 IF XQATYPE="NAME"
- Begin DoDot:1
- +15 if $ORDER(@XQAGLOB1@("SERV",XQASRVC,XQACNAME))=""
- SET RESULT=1
- +16 IF RESULT=1
- Begin DoDot:2
- +17 if $ORDER(@XQAGLOB1@("SERV",XQASRVC))=""
- SET RESULT=0
- End DoDot:2
- End DoDot:1
- +18 ;
- +19 IF XQATYPE="NUMB"
- Begin DoDot:1
- +20 SET XQANNAME=$ORDER(@XQAGLOB1@("SERV",XQASRVC,"NUMB",XQANUM,XQACNAME))
- +21 IF XQANNAME=""
- Begin DoDot:2
- +22 SET XQANNUM=$ORDER(@XQAGLOB1@("SERV",XQASRVC,"NUMB",XQANUM))
- +23 IF XQANNUM=""
- Begin DoDot:3
- +24 SET NXTSERVC=$ORDER(@XQAGLOB1@("SERV",XQASRVC))
- +25 IF (NXTSERVC'=XQASRVC)
- IF (NXTSERVC'="")
- SET RESULT=1
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +26 QUIT RESULT
- +27 ;
- PRINTVAL(XQAPAWS,FSTNOSVC) ;Print report value
- +1 ; Input ; Add to indicate if report needs page break, XU*8*690
- +2 ; XQAPAWS - 1: New Service
- +3 ; 0: Same Service
- +4 ; FSTNOSVC - 1: First line (No Service) written after ERROR LIMIT exceeded
- +5 ; 0: First line NOT written after ERROR LIMIT exceeded
- +6 ;
- +7 NEW NAME,SRVERRCT,XQAWRTER
- +8 SET NUMBER=+VALUE
- SET XQAN1=$PIECE(VALUE,U,2)
- SET NCRIT=$PIECE(VALUE,U,4)
- SET OLDEST=$PIECE(VALUE,U,3)
- SET NAME=$PIECE(VALUE,U,5)
- +9 SET SERVICE=$EXTRACT($$GET1^DIQ(200,XQAN1_",",29),1,17)
- +10 ;
- +11 ;XU*8*690 - Report <No Service> - SERVICE/SECTION not defined for user, Error Trap
- IF SERVICE=""
- Begin DoDot:1
- +12 NEW XQANOTES,XQAZTR,XQAFCNT,XQAZTEN
- +13 SET SERVICE="<No Service>"
- +14 SET XQAZTEN=$ORDER(^%ZTER(3.077,"B",$EXTRACT("Undefined SERVICE/SECTION Err",1,30),0))
- +15 IF 'XQAZTEN
- SET SRVERRCT=1
- +16 IF XQAZTEN
- Begin DoDot:2
- +17 SET SRVERRCT=0
- +18 SET XQAZTR=$GET(^%ZTER(3.077,XQAZTEN,4,+$HOROLOG,0))
- +19 FOR XQAFCNT=1:1:24
- SET SRVERRCT=SRVERRCT+$PIECE(XQAZTR,"~",XQAFCNT)
- +20 SET SRVERRCT=SRVERRCT+1
- End DoDot:2
- +21 ;Error limit reached?
- SET XQAWRTER=(SRVERRCT>$$XQZMAXER())
- +22 ;XQANOTES array = "ERROR description for inclusion in ERROR trap"
- +23 SET XQANOTES("PROGRAMMER",1,"WHAT HAPPENED")="Kernel Alerts Report included a user with a pending alert that did NOT have a SERVICE/SECTION in the New Person File."
- +24 SET XQANOTES("PROGRAMMER",2,"MENU REPORT OPTION")=$PIECE($GET(XQY0),"^",1,2)
- +25 SET XQANOTES("PROGRAMMER",3,"PROBLEM")="SERVICE/SECTION is a required field for all active VistA Users."
- +26 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",1)="Rerunning the report with the parameters in this log may or may not report all of the users missing SERVICE/SECTION."
- +27 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",2)="Users with alerts that have been processed since this log was recorded will not be reported."
- +28 IF SRVERRCT=$$XQZMAXER()
- Begin DoDot:2
- +29 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",3)="The MENU REPORT OPTION will only create an Error Trap log for the first "_$$XQZMAXER()_" users missing SERVICE/SECTION."
- +30 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",4)="The daily Error Trap limit of "_$$XQZMAXER()_" is determined by the KERNEL SYSTEM PARAMETERS file (#8989.3), ERROR LIMIT field(#520.1)."
- +31 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",5)="The MENU REPORT OPTION includes a message after the limit of "_$$XQZMAXER()_" users missing SERVICE/SECTION is reached."
- +32 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",6)="When user number "_($$XQZMAXER()+1)_" missing SERVICE/SECTION is reported, the message is printed on the report but Error Traps are not logged."
- +33 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",7)="1st Message on report: 'Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION.'"
- +34 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",8)="2nd Message on report: Limit Reached. 'No more entries will be added for '<No Service>' users today!'"
- +35 SET XQANOTES("PROGRAMMER",4,"REPORT NOTES",9)="Any users on the report following that message will not be recorded in the Error Trap."
- End DoDot:2
- +36 ;D APPERROR^%ZTER("Undefined SERVICE/SECTION Err") ;p777 comment out.
- End DoDot:1
- +37 ;
- +38 SET LSIGNON=$$GET1^DIQ(200,XQAN1_",",202)
- +39 IF LSIGNON["@"
- SET LSIGNON=$PIECE(LSIGNON,"@")
- +40 IF $Y>(IOSL-5)
- Begin DoDot:1
- +41 IF '$DATA(ZTQUEUED)
- WRITE !
- DO XQAPAUS(.XQAQTVAR)
- +42 IF +$GET(XQAQTVAR)'>0
- DO HEADER
- End DoDot:1
- +43 ;
- +44 IF +$GET(XQAQTVAR)'>0
- Begin DoDot:1
- +45 ;XU*8*690 - Error trap limit exceeded
- +46 ;Errors limited
- IF (SERVICE="<No Service>")
- IF (+$$XQZMAXER()>0)
- Begin DoDot:2
- +47 IF (SRVERRCT=($$XQZMAXER()+1))
- Begin DoDot:3
- +48 WRITE !," Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION."
- +49 WRITE !," Limit Reached. No more entries will be added for '<No Service>' users today!"
- +50 SET FSTNOSVC=1
- End DoDot:3
- +51 ;Error limit reached before report
- IF XQAWRTER
- IF 'FSTNOSVC
- Begin DoDot:3
- +52 WRITE !," Daily Error Trap limit is "_$$XQZMAXER()_" errors for users missing SERVICE/SECTION."
- +53 WRITE !," Limit Reached. No more entries will be added for '<No Service>' users today!"
- +54 SET FSTNOSVC=1
- End DoDot:3
- End DoDot:2
- +55 WRITE !,NAME,?25,SERVICE,?43,NUMBER,?50,LSIGNON,?64,NCRIT,?69,OLDEST
- End DoDot:1
- +56 ;
- +57 IF $GET(XQAPAWS)>0
- Begin DoDot:1
- +58 IF '$DATA(ZTQUEUED)
- WRITE !
- DO XQAPAUS(.XQAQTVAR)
- +59 IF +$GET(XQAQTVAR)'>0
- DO HEADER
- End DoDot:1
- +60 QUIT
- +61 ;
- XQAPAUS(XQAQTVAR) ;; Pause API, XU*8*690
- +1 USE IO(0)
- SET DIR(0)="E"
- DO ^DIR
- +2 IF $DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIRUT)!$DATA(DIROUT)
- SET XQAQTVAR=1
- +3 KILL DIR,X,Y,DTOUT,DUOUT,DIRUT,DIROUT
- +4 QUIT
- +5 ;
- XQZMAXER() ;;Return KERNEL SYSTEM PARAMETER file (#8989.3) ERROR LIMIT field (#520.1), XU*8*690
- +1 QUIT +$PIECE($GET(^XTV(8989.3,1,"ZTER"),"10"),"^",1)
- +2 ;
- DIVPRINT ;
- +1 IF $Y>(IOSL-6)
- DO HEADER
- +2 WRITE !,?5,"Division: ",$SELECT(DIVNAME=0:"These users are not assigned to a division",DIVNAME=99999:"These users are assigned to multiple divisions",1:DIVNAME)
- +3 QUIT
- +4 ;
- OLDEST() ; Returns date of oldest entry in alert tracking file
- +1 NEW OLDEST,I,J,FND
- +2 ; Use cross-ref, since if user data used to create entries in tracking file oldest may not be first in file
- +3 ; Make sure cross-ref is valid
- +4 SET FND=0
- FOR I=0:0
- if FND
- QUIT
- SET I=$ORDER(^XTV(8992.1,"D",I))
- if I'>0
- QUIT
- FOR J=0:0
- SET J=$ORDER(^XTV(8992.1,"D",I,J))
- if J'>0
- QUIT
- IF $DATA(^XTV(8992.1,J,0))
- SET FND=1
- QUIT
- +5 SET OLDEST=I
- if OLDEST'>0
- SET OLDEST=DT+1
- +6 QUIT OLDEST\1
- +7 ;
- VIEWTRAK ; OPT. View an entry in the Alert Tracking file in Captioned mode
- +1 NEW DIR,X0,X1,DAARRAY
- +2 SET X0=$ORDER(^XTV(8992.1,0))
- SET X1=$PIECE(^XTV(8992.1,0),U,3)
- +3 SET DIR(0)="NO^"_X0_":"_X1
- +4 FOR I=1:1
- SET DIR("A")=$SELECT(I>1:"Another ",1:"")_"Internal Entry number in Alert Tracking File"
- DO ^DIR
- KILL DIRUT
- if Y'>0
- QUIT
- SET DAARRAY(I)=+Y
- +5 KILL DIR
- if $DATA(DAARRAY)'>1
- QUIT
- +6 SET %ZIS="MQ"
- DO ^%ZIS
- if POP
- QUIT
- IF $DATA(IO("Q"))
- KILL IO("Q")
- SET ZTRTN="VIEWDQ^XQARPRT1"
- SET ZTDESC="List data from Alert Tracking file"
- SET ZTSAVE("*")=""
- DO ^%ZTLOAD
- if $GET(ZTSK)>0
- WRITE !,"Task number is ",ZTSK
- KILL ZTSK
- QUIT
- +7 ;
- VIEWDQ ;
- +1 NEW DIC,DA,DIC,XQAI,DR,DIQ
- +2 WRITE @IOF
- +3 SET DIQ(0)="CR"
- +4 FOR XQAI=0:0
- SET XQAI=$ORDER(DAARRAY(XQAI))
- if XQAI'>0
- QUIT
- Begin DoDot:1
- +5 SET DA=DAARRAY(XQAI)
- SET DIC="^XTV(8992.1,"
- DO EN^DIQ
- End DoDot:1
- +6 QUIT