BLRPRE39 ; IHS/MSC/MKK - IHS Lab Patch LR*5.2*1039 Pre/Post Routine ; 01-Jun-2016 07:27 ; MKK
;;5.2;IHS LABORATORY;**1039**;NOV 01, 1997;Build 38
;
ENVICHEK ; EP - Environment Checker
NEW BLRVERN,CP,ERRARRAY,ROWSTARS,RPMS,RPMSVER,TODAY,WOTCNT
;
Q:$$ENVIVARS()="Q"
;
D ENVHEADR^BLRKIDS2(CP,RPMSVER,RPMS),BLANK
;
D NEEDIT^BLRKIDS2(CP,"LR","5.2",1038,.ERRARRAY),BLANK ; Lab Pre-Requisite
;
I XPDABORT>0 D SORRYEND^BLRKIDS2(.ERRARRAY,CP) Q ; ENVIRONMENT HAS ERROR(S)
;
D BOKAY^BLRKIDS2("ENVIRONMENT")
;
Q
;
ENVIVARS() ; EP - Setup the Environment variables
D SETEVARS
;
S TODAY=$$DT^XLFDT
S WOTCNT=$$WOTCNT(BLRVERN)
S ROWSTARS=$TR($J("",65)," ","*") ; Row of asterisks
;
S ^XTMP(BLRVERN,0)=$$HTFM^XLFDT(+$H+90)_"^"_$$DT^XLFDT_"^IHS Lab Patch "_CPSTR
M ^XTMP(BLRVERN,TODAY,WOTCNT,"DUZ")=DUZ
S ^XTMP(BLRVERN,TODAY,WOTCNT,"BEGIN")=$$NOW^XLFDT
;
S XUMF=1
;
I $G(XPDNM)="" D SORRY^BLRKIDS2(CP,"XPDNM not defined or 0.") Q "Q"
;
S RPMS=$P(XPDNM,"*",1) ; RPMS Module
S RPMSVER=$P(XPDNM,"*",2) ; RPMS Version
;
I +$G(DUZ)<1 D SORRY^BLRKIDS2(CP,"DUZ UNDEFINED OR 0.") Q "Q"
I $$GET1^DIQ(200,DUZ,"NAME")="" D SORRY^BLRKIDS2(CP,"Installer cannot be identified!") Q "Q"
;
S XPDNOQUE=1 ; No Queuing Allowed
;
; The following line prevents the "Disable Options..." and "Move
; Routines..." questions from being asked during the install.
F X="XPO1","XPZ1","XPZ2","XPI1" S XPDDIQ(X)=0,XPDDIQ(X,"B")="NO"
;
S XPDABORT=0 ; KIDS install Flag
;
D HOME^%ZIS ; Reset/Initialize IO variables
D DTNOLF^DICRW ; Set DT variable without a Line Feed
;
Q "OK"
;
PRE ; EP - Ask for confirmation of Backup
NEW BLRVERN,CNT,CP,CPSTR,CRTLINE,DIRASTR,FDAROOT,IEN,IENS,MSGROOT
NEW BCKUPCNT ; Current Patch,Backup count
;
D SETEVARS
;
S XUMF=1
;
D INITSCR
D TITLE^XPDID(CPSTR)
D BLANK,BMES^XPDUTL("Pre-Install begins "_$$UP^XLFSTR($$HTE^XLFDT($H,"5MPZ"))_".")
;
Q:$$BACKUP()="Q"
;
D INITSCR
D TITLE^XPDID(CPSTR)
D BLANK,BMES^XPDUTL("Pre-Install of "_BLRVERN_" Continues.")
;
; Do Pre-install stuff here.
D SAVEOFF
;
D FILEDEL ; It's been decided that there are IHS UCUM updates. 08/25/2016.
;
D BMES^XPDUTL("Pre-Install ends "_$$UP^XLFSTR($$HTE^XLFDT($H,"5MPZ"))_".")
H 2 ; Pause so user can see the message.
;
; D EXIT^XPDID
Q
;
BACKUP() ; EP - Confirm Backup
NEW BCKUPCNT,SUCCSTR
;
D SHOWBOX^BLRGMENU("ATTENTION",10,70)
;
D ^XBFMK
S DIR(0)="Y"
S DIR("B")="NO"
I $G(IOST)["C-VT" S SUCCSTR=$C(27)_"[1;7;5m"_">> SUCCESSFUL <<"_$C(27)_"[0m"
E S SUCCSTR=">> SUCCESSFUL <<"
S DIR("A")=$J("",10)_"Has a "_SUCCSTR_" backup been performed?"
S DIR("?")="A *NO* answer will abort the install process."
D ^DIR
W !
;
Q:+$G(Y)'=1 $$NOBACKUP() ; If BACKUP not performed, then ABORT installation.
;
Q:+$G(DEBUG) $$OKBACKUP() ; DEBUG will *NOT* store Backup Confirmation data.
;
; Store backup confirmation person & date/time
S BCKUPCNT=1+$O(^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",0),-1)
S ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT)=$P($G(^VA(200,DUZ,0)),U)
S ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT,"DUZ")=DUZ
S ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT,"DATE/TIME")=$$HTE^XLFDT($H,"5MZ")
;
Q $$OKBACKUP()
;
OKBACKUP() ; EP - Backup Confirmed.
D BLANK
D OKAY^BLRKIDSU("SUCCESSFUL system backup CONFIRMED by: "_$$GET1^DIQ(200,DUZ,"NAME")_".",5)
I +$G(DEBUG) D
. D BLANK
. D TABMENU^BLRKIDSU("DEBUG will **NOT** Store Backup Confirmation.",10)
;
H 2 ; Pause to let the user see the message.
Q "OK"
;
NOBACKUP() ; EP - No backup message
S XPDABORT=1
D PASSMESG^BLRKIDS2("ATTENTION")
D TABMESG^BLRKIDSU("SUCCESSFUL system backup has >>> NOT <<< been confirmed.",15)
D TABMESG^BLRKIDSU("Installer: "_$$GET1^DIQ(200,DUZ,"NAME")_" ["_DUZ_"].",25)
D TABMESG^BLRKIDSU("Install Aborting.",15)
H 2 ; Pause to let the user see the message.
Q "Q"
;
DEBUG ; EP - Debugging Line Label for environment checker
NEW BEGTIME,BLRVERN,CP,CPSTR,DEBUG,ENDTIME,ERRARRAY,LASTLOGI
NEW LRBLNOW,PATCHNUM,PREREQ,QFLG,ROWSTARS,RPMS,RPMSVER,STR
NEW SUCCSTR,TODAY,WHATCNT,WOTCNT,XPDABORT,XPDENV,XPDNM
;
; NOTE: DEBUG will not store "Backup" data.
;
D SETEVARS
;
W !!
W "Debug Routine ",BLRVERN," Begins:",!!
;
S DEBUG=1 ; Don't Send Alerts
;
W !
S XPDNM=CPSTR
S (XPDENV,XPDABORT)=0
;
D PRE
Q:XPDABORT
;
W !!!
;
D ^XBFMK
S DIR(0)="YO"
S DIR("B")="NO"
S DIR("A")="Test Post Install Code"
D ^DIR
;
D:+$G(Y)=1 POST
;
W !!,"Debug Routine ",BLRVERN," Ends.",!!
Q
;
POST ; EP - Post-Install
NEW BLRVERN,CP,CPSTR,PATCHNUM,TODAY,WOTCNT
;
D BLANK,BMES^XPDUTL("Post-Install begins "_$$UP^XLFSTR($$HTE^XLFDT($H,"5MPZ"))_".")
D SETEVARS
;
S TODAY=$$DT^XLFDT
S WOTCNT=$$WOTCNT(BLRVERN)
;
D ADDOPTS ; Add new option to BLRMENU
;
D FORCENO ; Force new parameters to NO
;
D P1038UPD ; Update file 19.2 for new options from LR*5.2*1038
;
D BLANK,BMES^XPDUTL("Laboratory Patch "_CPSTR_" INSTALL complete."),BLANK
;
Q:+$G(DEBUG)
;
D POSTMAIL(BLRVERN,CPSTR)
;
S ^XTMP(BLRVERN,TODAY,WOTCNT,"END")=$$NOW^XLFDT
Q
;
ADDOPTS ; EP - Add new options
D ADDOPTS^BLRKIDS2("BLRMENU","BLR CREAT CLEAR DELTA CHECK","CCCD")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR CREATININE CLEARANCE TEST","TCCR")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR EMER ALERT Parameter Edit","EAPE")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR EDIT HIGH URG MGRP","EMGP")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR COLL DT PCC VIS PARAM EDIT","CDVC")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR MI INTERIM BY LOC","MILO")
D ADDOPTS^BLRKIDS2("BLRREFLABMENU","BLR REFLAB TESTS","NMAP")
D ADDOPTS^BLRKIDS2("BLRMENU","BLRF60SR","SF60")
D ADDOPTS^BLRKIDS2("BLRMENU","BLR MULTI ACCESSION CANCEL","MACC")
Q
;
FORCENO ; EP - Force new parameters to be NO
NEW (DEBUG,DILOCKTM,DISYS,DT,DTIME,DUZ,IO,IOBS,IOF,IOM,ION,IOS,IOSL,IOST,IOT,IOXY,U,XPARSYS,XQXFLG)
;
S BLRVERN=$TR($P($T(+1),";")," ")
;
I +$G(DEBUG) D Q ; If DEBUG, just print messages & quit
. S TAB=$J("",10)
. D BLANK,OKAY^BLRKIDSU("DEBUG: FORCENO^"_BLRVERN,4)
. D MES^XPDUTL(TAB_"DEBUG will *NOT* modify BLR EMERGENCY ALERT parameter.")
. D MES^XPDUTL(TAB_"DEBUG will *NOT* modify BLR COLL DT PCC VISIT CREATION parameter.")
;
F PARAMETER="BLR COLL DT PCC VISIT CREATION","BLR EMERGENCY ALERT" D
. K ERRS
. D EN^XPAR("PKG",PARAMETER,,"NO",.ERRS)
. I +$G(ERRS) D
.. D BLANK,MES^XPDUTL(PARAMETER_" parameter not modified."),BLANK
.. D STORERRS^BLREMERA(ERRS,PARAMETER)
Q
;
;
SAVEOFF ; EP - Save off all routines being updated by this patch into the ^rBACKUP global.
NEW (DEBUG,DILOCKTM,DISYS,DT,DTIME,DUZ,IO,IOBS,IOF,IOM,ION,IOS,IOSL,IOST,IOT,IOXY,U,XPARSYS,XQXFLG)
;
S BLRVERN=$TR($P($T(+1),";")," ")
;
I +$G(DEBUG) D Q ; If DEBUG, just print messages & quit
. S TAB=$J("",10)
. D BLANK,OKAY^BLRKIDSU("DEBUG: SAVEOFF^"_BLRVERN,4)
. D BMES^XPDUTL(TAB_"DEBUG does *NOT* Save off routines.")
;
S PATCH=$P($T(+2),"*",3)
S BUILD="LR*5.2*"_PATCH
S PATCHIEN=+$O(^XPD(9.6,"B",BUILD,"A"),-1) ; Get the most current Patch IEN
Q:PATCHIEN<1 ; If not in BUILD file, skip
;
D BMES^XPDUTL("Backing up routines.")
S RTN="",(CNT,RTNCNT)=0
F S RTN=$O(^XPD(9.6,PATCHIEN,"KRN",9.8,"NM","B",RTN)) Q:RTN="" D
. S RTNPATCH=+$RE($P($RE($TR($P($G(^ROUTINE(RTN,0,2)),";",5),"*")),","))
. Q:RTNPATCH<1 ; If RTN not in the ^ROUTINE global, skip
. Q:RTNPATCH'<PATCH ; Only versions < this patch
. ;
. S RTNCNT=RTNCNT+1
. K ERRS,RTNA
. F LN=0:1:$G(^ROUTINE(RTN,0,0)) S RTNA(LN)=$G(^ROUTINE(RTN,0,LN))
. S X=$$ROUTINE^%R(RTN_".INT",.RTNA,.ERRS,"CSB")
. S NOW=$H
. S ^BLRINSTL("LAB PATCH",PATCH,"SAVEOFF",NOW)=$$HTE^XLFDT(NOW,"5MZ")
. S ^BLRINSTL("LAB PATCH",PATCH,"SAVEOFF",NOW,RTN)=$S($D(ERRS)>1:"ERRORS",1:"OK")
. I $D(ERRS)'>1 D
.. D OKAY^BLRKIDSU("Routine "_RTN_" backed up.",4)
.. S CNT=CNT+1
;
I RTNCNT D
. S TAB=$J("",5)
. D BMES^XPDUTL(TAB_RTNCNT_" routines analyzed.")
. D BMES^XPDUTL(TAB_TAB_CNT_" routines backed up.")
Q
;
;
P1038UPD ; EP - Update File 19.2 with the new Options from LR*5.2*1038
NEW CNT,ERRS,FDA,IEN,OPT
;
S CNT=0
F OPT="IHS LAB BLRUER TASK","IHS LAB BLRSORA TASK","IHS LAB BLRSORC TASK" D
. Q:$$FIND1^DIC(19.2,,,OPT) ; If already in file 19.2, skip
. ;
. S IEN=$$FIND1^DIC(19,,,OPT)
. Q:IEN<1 ; If cannot find IEN of OPT, skip
. ;
. K ERRS,FDA
. S FDA(19.2,"+1,",.01)=IEN
. D UPDATE^DIE("","FDA",,"ERRS")
. Q:$D(ERRS) ; If Error, skip.
. ;
. S CNT=CNT+1
. D:CNT=1 BLANK
. D OKAY^BLRKIDSU("Added "_OPT_" to file 19.2.")
D:CNT BLANK
;
Q
;
;
; ========================= UTILITIES FOLLOW ==========================
;
SETEVARS ; EP - SET standard "Enviroment" VARiables.
S (CP,PATCHNUM)=$P($T(+2),"*",3)
S CPSTR="LR*5.2*"_CP
D SETBLRVS
Q
;
SETBLRVS(TWO) ; EP - Set the BLRVERN variable(s)
K BLRVERN,BLRVERN2
;
S BLRVERN=$P($P($T(+1),";")," ")
S:$L($G(TWO)) BLRVERN2=$G(TWO)
Q
;
BLANK ; EP - Blank Line
D MES^XPDUTL("")
Q
;
MESCNTR(STR) ; EP - Center a line and use XPDUTL to display it
D MES^XPDUTL($$CJ^XLFSTR(STR,IOM))
Q
;
WOTCNT(BLRVERN) ; EP - Counter for ^XTMP
NEW CNT,TODAY
;
S TODAY=$$DT^XLFDT
;
S CNT=1+$G(^XTMP(BLRVERN,0,TODAY))
S ^XTMP(BLRVERN,0,TODAY)=CNT
Q $TR($J(CNT,3)," ","0")
;
INITSCR ; EP - Initialize screen. Cloned from INIT^XPDID
N X,XPDSTR
I IO'=IO(0)!(IOST'["C-VT") S XPDIDVT=0 Q
I $T(PREP^XGF)="" S XPDIDVT=0 Q
D PREP^XGF
S XPDIDVT=1,X="IOSTBM",XPDSTR=""
D ENDR^%ZISS
S IOTM=3,IOBM=IOSL-4
W @IOSTBM
D FRAME^XGF(IOTM-2,0,IOTM-2,IOM-1) ; Top line
; D FRAME^XGF(IOBM+1,0,IOBM+1,IOM-1) ; Bottom line
D IOXY^XGF(IOTM-2,0)
Q
;
POSTMAIL(BLRVERN,CPSTR) ; EP - Post Install MailMan Message
NEW STR
;
S STR(1)=" "
S STR(2)=$J("",10)_"POST INSTALL of "_BLRVERN_" Routine."
S STR(3)=" "
S STR(4)=$J("",15)_"Laboratory Patch "_CPSTR_" INSTALL completed."
S STR(5)=" "
;
Q:+$G(DEBUG) ; No MailMan messages during debugging
;
; Send E-Mail to LMI Mail Group & Installer
D MAILALMI^BLRUTIL3("Laboratory Patch "_CPSTR_" INSTALL complete.",.STR,BLRVERN)
;
Q
;
; The following IHS UCUM deletions are necessary because the OVERWRITE flag in KIDS
; does *NOT* work: any data in the target system will not be overwritten if it's
; different from the incoming data. (Example: IEN 410 on SandPre.)
FILEDEL ; EP
NEW CNT,IEN
;
D DISABLE^%NOJRN ; Disable Journaling prior to deletions
;
D BMES^XPDUTL(" IHS UCUM Deletions")
S IEN=.9999999,CNT=0
F S IEN=$O(^BLRUCUM(IEN)) Q:IEN<1 D
. S CNT=CNT+1
. I CNT#100=0 W "." W:$X>75 !,?4
. D ^XBFMK
. S DIK="^BLRUCUM(",DA=IEN
. Q:$G(DEBUG)="YES" ; If DEBUG set, don't delete anything
. D ^DIK
D BOKAY^BLRKIDS2("IHS UCUM Deletions Complete.",10)
;
W !
;
D ENABLE^%NOJRN ; Restore Journaling
Q
BLRPRE39 ; IHS/MSC/MKK - IHS Lab Patch LR*5.2*1039 Pre/Post Routine ; 01-Jun-2016 07:27 ; MKK
+1 ;;5.2;IHS LABORATORY;**1039**;NOV 01, 1997;Build 38
+2 ;
ENVICHEK ; EP - Environment Checker
+1 NEW BLRVERN,CP,ERRARRAY,ROWSTARS,RPMS,RPMSVER,TODAY,WOTCNT
+2 ;
+3 IF $$ENVIVARS()="Q"
QUIT
+4 ;
+5 DO ENVHEADR^BLRKIDS2(CP,RPMSVER,RPMS)
DO BLANK
+6 ;
+7 ; Lab Pre-Requisite
DO NEEDIT^BLRKIDS2(CP,"LR","5.2",1038,.ERRARRAY)
DO BLANK
+8 ;
+9 ; ENVIRONMENT HAS ERROR(S)
IF XPDABORT>0
DO SORRYEND^BLRKIDS2(.ERRARRAY,CP)
QUIT
+10 ;
+11 DO BOKAY^BLRKIDS2("ENVIRONMENT")
+12 ;
+13 QUIT
+14 ;
ENVIVARS() ; EP - Setup the Environment variables
+1 DO SETEVARS
+2 ;
+3 SET TODAY=$$DT^XLFDT
+4 SET WOTCNT=$$WOTCNT(BLRVERN)
+5 ; Row of asterisks
SET ROWSTARS=$TRANSLATE($JUSTIFY("",65)," ","*")
+6 ;
+7 SET ^XTMP(BLRVERN,0)=$$HTFM^XLFDT(+$HOROLOG+90)_"^"_$$DT^XLFDT_"^IHS Lab Patch "_CPSTR
+8 MERGE ^XTMP(BLRVERN,TODAY,WOTCNT,"DUZ")=DUZ
+9 SET ^XTMP(BLRVERN,TODAY,WOTCNT,"BEGIN")=$$NOW^XLFDT
+10 ;
+11 SET XUMF=1
+12 ;
+13 IF $GET(XPDNM)=""
DO SORRY^BLRKIDS2(CP,"XPDNM not defined or 0.")
QUIT "Q"
+14 ;
+15 ; RPMS Module
SET RPMS=$PIECE(XPDNM,"*",1)
+16 ; RPMS Version
SET RPMSVER=$PIECE(XPDNM,"*",2)
+17 ;
+18 IF +$GET(DUZ)<1
DO SORRY^BLRKIDS2(CP,"DUZ UNDEFINED OR 0.")
QUIT "Q"
+19 IF $$GET1^DIQ(200,DUZ,"NAME")=""
DO SORRY^BLRKIDS2(CP,"Installer cannot be identified!")
QUIT "Q"
+20 ;
+21 ; No Queuing Allowed
SET XPDNOQUE=1
+22 ;
+23 ; The following line prevents the "Disable Options..." and "Move
+24 ; Routines..." questions from being asked during the install.
+25 FOR X="XPO1","XPZ1","XPZ2","XPI1"
SET XPDDIQ(X)=0
SET XPDDIQ(X,"B")="NO"
+26 ;
+27 ; KIDS install Flag
SET XPDABORT=0
+28 ;
+29 ; Reset/Initialize IO variables
DO HOME^%ZIS
+30 ; Set DT variable without a Line Feed
DO DTNOLF^DICRW
+31 ;
+32 QUIT "OK"
+33 ;
PRE ; EP - Ask for confirmation of Backup
+1 NEW BLRVERN,CNT,CP,CPSTR,CRTLINE,DIRASTR,FDAROOT,IEN,IENS,MSGROOT
+2 ; Current Patch,Backup count
NEW BCKUPCNT
+3 ;
+4 DO SETEVARS
+5 ;
+6 SET XUMF=1
+7 ;
+8 DO INITSCR
+9 DO TITLE^XPDID(CPSTR)
+10 DO BLANK
DO BMES^XPDUTL("Pre-Install begins "_$$UP^XLFSTR($$HTE^XLFDT($HOROLOG,"5MPZ"))_".")
+11 ;
+12 IF $$BACKUP()="Q"
QUIT
+13 ;
+14 DO INITSCR
+15 DO TITLE^XPDID(CPSTR)
+16 DO BLANK
DO BMES^XPDUTL("Pre-Install of "_BLRVERN_" Continues.")
+17 ;
+18 ; Do Pre-install stuff here.
+19 DO SAVEOFF
+20 ;
+21 ; It's been decided that there are IHS UCUM updates. 08/25/2016.
DO FILEDEL
+22 ;
+23 DO BMES^XPDUTL("Pre-Install ends "_$$UP^XLFSTR($$HTE^XLFDT($HOROLOG,"5MPZ"))_".")
+24 ; Pause so user can see the message.
HANG 2
+25 ;
+26 ; D EXIT^XPDID
+27 QUIT
+28 ;
BACKUP() ; EP - Confirm Backup
+1 NEW BCKUPCNT,SUCCSTR
+2 ;
+3 DO SHOWBOX^BLRGMENU("ATTENTION",10,70)
+4 ;
+5 DO ^XBFMK
+6 SET DIR(0)="Y"
+7 SET DIR("B")="NO"
+8 IF $GET(IOST)["C-VT"
SET SUCCSTR=$CHAR(27)_"[1;7;5m"_">> SUCCESSFUL <<"_$CHAR(27)_"[0m"
+9 IF '$TEST
SET SUCCSTR=">> SUCCESSFUL <<"
+10 SET DIR("A")=$JUSTIFY("",10)_"Has a "_SUCCSTR_" backup been performed?"
+11 SET DIR("?")="A *NO* answer will abort the install process."
+12 DO ^DIR
+13 WRITE !
+14 ;
+15 ; If BACKUP not performed, then ABORT installation.
IF +$GET(Y)'=1
QUIT $$NOBACKUP()
+16 ;
+17 ; DEBUG will *NOT* store Backup Confirmation data.
IF +$GET(DEBUG)
QUIT $$OKBACKUP()
+18 ;
+19 ; Store backup confirmation person & date/time
+20 SET BCKUPCNT=1+$ORDER(^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",0),-1)
+21 SET ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT)=$PIECE($GET(^VA(200,DUZ,0)),U)
+22 SET ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT,"DUZ")=DUZ
+23 SET ^BLRINSTL("LAB PATCH",CP,"BACKUP CONFIRMED BY",BCKUPCNT,"DATE/TIME")=$$HTE^XLFDT($HOROLOG,"5MZ")
+24 ;
+25 QUIT $$OKBACKUP()
+26 ;
OKBACKUP() ; EP - Backup Confirmed.
+1 DO BLANK
+2 DO OKAY^BLRKIDSU("SUCCESSFUL system backup CONFIRMED by: "_$$GET1^DIQ(200,DUZ,"NAME")_".",5)
+3 IF +$GET(DEBUG)
Begin DoDot:1
+4 DO BLANK
+5 DO TABMENU^BLRKIDSU("DEBUG will **NOT** Store Backup Confirmation.",10)
End DoDot:1
+6 ;
+7 ; Pause to let the user see the message.
HANG 2
+8 QUIT "OK"
+9 ;
NOBACKUP() ; EP - No backup message
+1 SET XPDABORT=1
+2 DO PASSMESG^BLRKIDS2("ATTENTION")
+3 DO TABMESG^BLRKIDSU("SUCCESSFUL system backup has >>> NOT <<< been confirmed.",15)
+4 DO TABMESG^BLRKIDSU("Installer: "_$$GET1^DIQ(200,DUZ,"NAME")_" ["_DUZ_"].",25)
+5 DO TABMESG^BLRKIDSU("Install Aborting.",15)
+6 ; Pause to let the user see the message.
HANG 2
+7 QUIT "Q"
+8 ;
DEBUG ; EP - Debugging Line Label for environment checker
+1 NEW BEGTIME,BLRVERN,CP,CPSTR,DEBUG,ENDTIME,ERRARRAY,LASTLOGI
+2 NEW LRBLNOW,PATCHNUM,PREREQ,QFLG,ROWSTARS,RPMS,RPMSVER,STR
+3 NEW SUCCSTR,TODAY,WHATCNT,WOTCNT,XPDABORT,XPDENV,XPDNM
+4 ;
+5 ; NOTE: DEBUG will not store "Backup" data.
+6 ;
+7 DO SETEVARS
+8 ;
+9 WRITE !!
+10 WRITE "Debug Routine ",BLRVERN," Begins:",!!
+11 ;
+12 ; Don't Send Alerts
SET DEBUG=1
+13 ;
+14 WRITE !
+15 SET XPDNM=CPSTR
+16 SET (XPDENV,XPDABORT)=0
+17 ;
+18 DO PRE
+19 IF XPDABORT
QUIT
+20 ;
+21 WRITE !!!
+22 ;
+23 DO ^XBFMK
+24 SET DIR(0)="YO"
+25 SET DIR("B")="NO"
+26 SET DIR("A")="Test Post Install Code"
+27 DO ^DIR
+28 ;
+29 IF +$GET(Y)=1
DO POST
+30 ;
+31 WRITE !!,"Debug Routine ",BLRVERN," Ends.",!!
+32 QUIT
+33 ;
POST ; EP - Post-Install
+1 NEW BLRVERN,CP,CPSTR,PATCHNUM,TODAY,WOTCNT
+2 ;
+3 DO BLANK
DO BMES^XPDUTL("Post-Install begins "_$$UP^XLFSTR($$HTE^XLFDT($HOROLOG,"5MPZ"))_".")
+4 DO SETEVARS
+5 ;
+6 SET TODAY=$$DT^XLFDT
+7 SET WOTCNT=$$WOTCNT(BLRVERN)
+8 ;
+9 ; Add new option to BLRMENU
DO ADDOPTS
+10 ;
+11 ; Force new parameters to NO
DO FORCENO
+12 ;
+13 ; Update file 19.2 for new options from LR*5.2*1038
DO P1038UPD
+14 ;
+15 DO BLANK
DO BMES^XPDUTL("Laboratory Patch "_CPSTR_" INSTALL complete.")
DO BLANK
+16 ;
+17 IF +$GET(DEBUG)
QUIT
+18 ;
+19 DO POSTMAIL(BLRVERN,CPSTR)
+20 ;
+21 SET ^XTMP(BLRVERN,TODAY,WOTCNT,"END")=$$NOW^XLFDT
+22 QUIT
+23 ;
ADDOPTS ; EP - Add new options
+1 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR CREAT CLEAR DELTA CHECK","CCCD")
+2 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR CREATININE CLEARANCE TEST","TCCR")
+3 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR EMER ALERT Parameter Edit","EAPE")
+4 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR EDIT HIGH URG MGRP","EMGP")
+5 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR COLL DT PCC VIS PARAM EDIT","CDVC")
+6 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR MI INTERIM BY LOC","MILO")
+7 DO ADDOPTS^BLRKIDS2("BLRREFLABMENU","BLR REFLAB TESTS","NMAP")
+8 DO ADDOPTS^BLRKIDS2("BLRMENU","BLRF60SR","SF60")
+9 DO ADDOPTS^BLRKIDS2("BLRMENU","BLR MULTI ACCESSION CANCEL","MACC")
+10 QUIT
+11 ;
FORCENO ; EP - Force new parameters to be NO
+1 NEW (DEBUG,DILOCKTM,DISYS,DT,DTIME,DUZ,IO,IOBS,IOF,IOM,ION,IOS,IOSL,IOST,IOT,IOXY,U,XPARSYS,XQXFLG)
+2 ;
+3 SET BLRVERN=$TRANSLATE($PIECE($TEXT(+1),";")," ")
+4 ;
+5 ; If DEBUG, just print messages & quit
IF +$GET(DEBUG)
Begin DoDot:1
+6 SET TAB=$JUSTIFY("",10)
+7 DO BLANK
DO OKAY^BLRKIDSU("DEBUG: FORCENO^"_BLRVERN,4)
+8 DO MES^XPDUTL(TAB_"DEBUG will *NOT* modify BLR EMERGENCY ALERT parameter.")
+9 DO MES^XPDUTL(TAB_"DEBUG will *NOT* modify BLR COLL DT PCC VISIT CREATION parameter.")
End DoDot:1
QUIT
+10 ;
+11 FOR PARAMETER="BLR COLL DT PCC VISIT CREATION","BLR EMERGENCY ALERT"
Begin DoDot:1
+12 KILL ERRS
+13 DO EN^XPAR("PKG",PARAMETER,,"NO",.ERRS)
+14 IF +$GET(ERRS)
Begin DoDot:2
+15 DO BLANK
DO MES^XPDUTL(PARAMETER_" parameter not modified.")
DO BLANK
+16 DO STORERRS^BLREMERA(ERRS,PARAMETER)
End DoDot:2
End DoDot:1
+17 QUIT
+18 ;
+19 ;
SAVEOFF ; EP - Save off all routines being updated by this patch into the ^rBACKUP global.
+1 NEW (DEBUG,DILOCKTM,DISYS,DT,DTIME,DUZ,IO,IOBS,IOF,IOM,ION,IOS,IOSL,IOST,IOT,IOXY,U,XPARSYS,XQXFLG)
+2 ;
+3 SET BLRVERN=$TRANSLATE($PIECE($TEXT(+1),";")," ")
+4 ;
+5 ; If DEBUG, just print messages & quit
IF +$GET(DEBUG)
Begin DoDot:1
+6 SET TAB=$JUSTIFY("",10)
+7 DO BLANK
DO OKAY^BLRKIDSU("DEBUG: SAVEOFF^"_BLRVERN,4)
+8 DO BMES^XPDUTL(TAB_"DEBUG does *NOT* Save off routines.")
End DoDot:1
QUIT
+9 ;
+10 SET PATCH=$PIECE($TEXT(+2),"*",3)
+11 SET BUILD="LR*5.2*"_PATCH
+12 ; Get the most current Patch IEN
SET PATCHIEN=+$ORDER(^XPD(9.6,"B",BUILD,"A"),-1)
+13 ; If not in BUILD file, skip
IF PATCHIEN<1
QUIT
+14 ;
+15 DO BMES^XPDUTL("Backing up routines.")
+16 SET RTN=""
SET (CNT,RTNCNT)=0
+17 FOR
SET RTN=$ORDER(^XPD(9.6,PATCHIEN,"KRN",9.8,"NM","B",RTN))
IF RTN=""
QUIT
Begin DoDot:1
+18 SET RTNPATCH=+$REVERSE($PIECE($REVERSE($TRANSLATE($PIECE($GET(^ROUTINE(RTN,0,2)),";",5),"*")),","))
+19 ; If RTN not in the ^ROUTINE global, skip
IF RTNPATCH<1
QUIT
+20 ; Only versions < this patch
IF RTNPATCH'<PATCH
QUIT
+21 ;
+22 SET RTNCNT=RTNCNT+1
+23 KILL ERRS,RTNA
+24 FOR LN=0:1:$GET(^ROUTINE(RTN,0,0))
SET RTNA(LN)=$GET(^ROUTINE(RTN,0,LN))
+25 SET X=$$ROUTINE^%R(RTN_".INT",.RTNA,.ERRS,"CSB")
+26 SET NOW=$HOROLOG
+27 SET ^BLRINSTL("LAB PATCH",PATCH,"SAVEOFF",NOW)=$$HTE^XLFDT(NOW,"5MZ")
+28 SET ^BLRINSTL("LAB PATCH",PATCH,"SAVEOFF",NOW,RTN)=$SELECT($DATA(ERRS)>1:"ERRORS",1:"OK")
+29 IF $DATA(ERRS)'>1
Begin DoDot:2
+30 DO OKAY^BLRKIDSU("Routine "_RTN_" backed up.",4)
+31 SET CNT=CNT+1
End DoDot:2
End DoDot:1
+32 ;
+33 IF RTNCNT
Begin DoDot:1
+34 SET TAB=$JUSTIFY("",5)
+35 DO BMES^XPDUTL(TAB_RTNCNT_" routines analyzed.")
+36 DO BMES^XPDUTL(TAB_TAB_CNT_" routines backed up.")
End DoDot:1
+37 QUIT
+38 ;
+39 ;
P1038UPD ; EP - Update File 19.2 with the new Options from LR*5.2*1038
+1 NEW CNT,ERRS,FDA,IEN,OPT
+2 ;
+3 SET CNT=0
+4 FOR OPT="IHS LAB BLRUER TASK","IHS LAB BLRSORA TASK","IHS LAB BLRSORC TASK"
Begin DoDot:1
+5 ; If already in file 19.2, skip
IF $$FIND1^DIC(19.2,,,OPT)
QUIT
+6 ;
+7 SET IEN=$$FIND1^DIC(19,,,OPT)
+8 ; If cannot find IEN of OPT, skip
IF IEN<1
QUIT
+9 ;
+10 KILL ERRS,FDA
+11 SET FDA(19.2,"+1,",.01)=IEN
+12 DO UPDATE^DIE("","FDA",,"ERRS")
+13 ; If Error, skip.
IF $DATA(ERRS)
QUIT
+14 ;
+15 SET CNT=CNT+1
+16 IF CNT=1
DO BLANK
+17 DO OKAY^BLRKIDSU("Added "_OPT_" to file 19.2.")
End DoDot:1
+18 IF CNT
DO BLANK
+19 ;
+20 QUIT
+21 ;
+22 ;
+23 ; ========================= UTILITIES FOLLOW ==========================
+24 ;
SETEVARS ; EP - SET standard "Enviroment" VARiables.
+1 SET (CP,PATCHNUM)=$PIECE($TEXT(+2),"*",3)
+2 SET CPSTR="LR*5.2*"_CP
+3 DO SETBLRVS
+4 QUIT
+5 ;
SETBLRVS(TWO) ; EP - Set the BLRVERN variable(s)
+1 KILL BLRVERN,BLRVERN2
+2 ;
+3 SET BLRVERN=$PIECE($PIECE($TEXT(+1),";")," ")
+4 IF $LENGTH($GET(TWO))
SET BLRVERN2=$GET(TWO)
+5 QUIT
+6 ;
BLANK ; EP - Blank Line
+1 DO MES^XPDUTL("")
+2 QUIT
+3 ;
MESCNTR(STR) ; EP - Center a line and use XPDUTL to display it
+1 DO MES^XPDUTL($$CJ^XLFSTR(STR,IOM))
+2 QUIT
+3 ;
WOTCNT(BLRVERN) ; EP - Counter for ^XTMP
+1 NEW CNT,TODAY
+2 ;
+3 SET TODAY=$$DT^XLFDT
+4 ;
+5 SET CNT=1+$GET(^XTMP(BLRVERN,0,TODAY))
+6 SET ^XTMP(BLRVERN,0,TODAY)=CNT
+7 QUIT $TRANSLATE($JUSTIFY(CNT,3)," ","0")
+8 ;
INITSCR ; EP - Initialize screen. Cloned from INIT^XPDID
+1 NEW X,XPDSTR
+2 IF IO'=IO(0)!(IOST'["C-VT")
SET XPDIDVT=0
QUIT
+3 IF $TEXT(PREP^XGF)=""
SET XPDIDVT=0
QUIT
+4 DO PREP^XGF
+5 SET XPDIDVT=1
SET X="IOSTBM"
SET XPDSTR=""
+6 DO ENDR^%ZISS
+7 SET IOTM=3
SET IOBM=IOSL-4
+8 WRITE @IOSTBM
+9 ; Top line
DO FRAME^XGF(IOTM-2,0,IOTM-2,IOM-1)
+10 ; D FRAME^XGF(IOBM+1,0,IOBM+1,IOM-1) ; Bottom line
+11 DO IOXY^XGF(IOTM-2,0)
+12 QUIT
+13 ;
POSTMAIL(BLRVERN,CPSTR) ; EP - Post Install MailMan Message
+1 NEW STR
+2 ;
+3 SET STR(1)=" "
+4 SET STR(2)=$JUSTIFY("",10)_"POST INSTALL of "_BLRVERN_" Routine."
+5 SET STR(3)=" "
+6 SET STR(4)=$JUSTIFY("",15)_"Laboratory Patch "_CPSTR_" INSTALL completed."
+7 SET STR(5)=" "
+8 ;
+9 ; No MailMan messages during debugging
IF +$GET(DEBUG)
QUIT
+10 ;
+11 ; Send E-Mail to LMI Mail Group & Installer
+12 DO MAILALMI^BLRUTIL3("Laboratory Patch "_CPSTR_" INSTALL complete.",.STR,BLRVERN)
+13 ;
+14 QUIT
+15 ;
+16 ; The following IHS UCUM deletions are necessary because the OVERWRITE flag in KIDS
+17 ; does *NOT* work: any data in the target system will not be overwritten if it's
+18 ; different from the incoming data. (Example: IEN 410 on SandPre.)
FILEDEL ; EP
+1 NEW CNT,IEN
+2 ;
+3 ; Disable Journaling prior to deletions
DO DISABLE^%NOJRN
+4 ;
+5 DO BMES^XPDUTL(" IHS UCUM Deletions")
+6 SET IEN=.9999999
SET CNT=0
+7 FOR
SET IEN=$ORDER(^BLRUCUM(IEN))
IF IEN<1
QUIT
Begin DoDot:1
+8 SET CNT=CNT+1
+9 IF CNT#100=0
WRITE "."
IF $X>75
WRITE !,?4
+10 DO ^XBFMK
+11 SET DIK="^BLRUCUM("
SET DA=IEN
+12 ; If DEBUG set, don't delete anything
IF $GET(DEBUG)="YES"
QUIT
+13 DO ^DIK
End DoDot:1
+14 DO BOKAY^BLRKIDS2("IHS UCUM Deletions Complete.",10)
+15 ;
+16 WRITE !
+17 ;
+18 ; Restore Journaling
DO ENABLE^%NOJRN
+19 QUIT