| 1 | LA66    ;DALOI/JMC - LA*5.2*66 PATCH ENVIRONMENT CHECK ROUTINE ;May 7, 2008 | 
|---|
| 2 | ;;5.2;AUTOMATED LAB INSTRUMENTS;**66**;Sep 27, 1994;Build 30 | 
|---|
| 3 | ; | 
|---|
| 4 | ; Pre, Post, and Environment checks for LA*5.2*66 | 
|---|
| 5 | ; | 
|---|
| 6 | ENV     ; | 
|---|
| 7 | ; Environment checks | 
|---|
| 8 | S XPDNOQUE=1 ; no queuing | 
|---|
| 9 | N LAERR,LAADL | 
|---|
| 10 | K ^TMP($$RTNNM(),$J) | 
|---|
| 11 | I '$G(XPDENV) D  ; | 
|---|
| 12 | . N MSG | 
|---|
| 13 | . S MSG="Transport global for patch "_$G(XPDNM,"Unknown patch")_" loaded on "_$$HTE^XLFDT($H) | 
|---|
| 14 | . D ALERT(MSG) | 
|---|
| 15 | . D BMES("Sending transport global loaded alert to mail group G.LMI") | 
|---|
| 16 | ; | 
|---|
| 17 | I $G(XPDENV) D  ; | 
|---|
| 18 | . N MSG | 
|---|
| 19 | . S MSG="Installation of patch "_$G(XPDNM,"Unknown patch")_" started on "_$$HTE^XLFDT($H) | 
|---|
| 20 | . D ALERT(MSG) | 
|---|
| 21 | . D BMES("Sending install started alert to mail group G.LMI") | 
|---|
| 22 | ; | 
|---|
| 23 | S LAERR=0 | 
|---|
| 24 | I $S('$G(IOM):1,'$G(IOSL):1,$G(U)'="^":1,1:0) D  ; | 
|---|
| 25 | . D BMES("Terminal Device is not defined.") | 
|---|
| 26 | . S LAERR=2 | 
|---|
| 27 | ; | 
|---|
| 28 | I $S('$G(DUZ):1,$D(DUZ)[0:1,$D(DUZ(0))[0:1,1:0) D  ; | 
|---|
| 29 | . D BMES("Please login to set local DUZ variables.") | 
|---|
| 30 | . S LAERR=2 | 
|---|
| 31 | ; | 
|---|
| 32 | I 'LAERR,$P($$ACTIVE^XUSER(DUZ),"^")'=1 D  ; | 
|---|
| 33 | . D BMES("You are not a valid user on this system.") | 
|---|
| 34 | . S LAERR=2 | 
|---|
| 35 | ; | 
|---|
| 36 | ; If installing, run system config | 
|---|
| 37 | I 'LAERR,$G(XPDENV) D  ; | 
|---|
| 38 | . S LAADL=$G(^LA("ADL","STOP")) | 
|---|
| 39 | . D ENV2 | 
|---|
| 40 | . I $P(LAADL,"^")=0 D  ; | 
|---|
| 41 | . . D BMES("N O T E:  If you abort this installation") | 
|---|
| 42 | . . D MES("restart the Lab Universal Interface background job.") | 
|---|
| 43 | ; | 
|---|
| 44 | I LAERR!$D(XPDABORT)!$D(XPDQUIT) D  ; | 
|---|
| 45 | . S LAERR=1 | 
|---|
| 46 | . S XPDABORT=2 S XPDQUIT=2 | 
|---|
| 47 | . W !,$C(7) W ! D BMES("* * * Environment check FAILED * * *") | 
|---|
| 48 | ; | 
|---|
| 49 | I 'LAERR W ! D BMES("--- Environment is okay ---") | 
|---|
| 50 | ; | 
|---|
| 51 | I $G(XPDENV) S XPDDIQ("XPZ1","B")="NO" | 
|---|
| 52 | Q | 
|---|
| 53 | ; | 
|---|
| 54 | ; | 
|---|
| 55 | PRE     ; | 
|---|
| 56 | ; Pre install | 
|---|
| 57 | D BMES("*** Pre install started ***") | 
|---|
| 58 | D BMES("--- No action required for pre-install ---") | 
|---|
| 59 | D BMES("*** Pre install completed ***") | 
|---|
| 60 | Q | 
|---|
| 61 | ; | 
|---|
| 62 | ; | 
|---|
| 63 | POST    ; | 
|---|
| 64 | ; Post install | 
|---|
| 65 | N LAERR,LAFDA,LA7DIE,LA7FAC,LA7I,LA7X,LA7Y,LAMSG,LAPOST,DIERR | 
|---|
| 66 | S (LAERR,LAPOST)=0 | 
|---|
| 67 | D BMES("*** Post install started ***") | 
|---|
| 68 | ; | 
|---|
| 69 | ; Set facility station number into FACILITY NAME field in file #771. | 
|---|
| 70 | S LA7FAC=$P($$SITE^VASITE(DT),"^",3) | 
|---|
| 71 | I 'LA7FAC D  ; | 
|---|
| 72 | . S LAERR=1 | 
|---|
| 73 | . D BMES("ERROR: Could not determine Facility Number.") | 
|---|
| 74 | . D BMES("Edit file #771, FACILITY NAME field for LA7UI*") | 
|---|
| 75 | I LA7FAC'="" D | 
|---|
| 76 | . D BMES("*** Updating facility name for LA7UI* entries in file #771 ***") | 
|---|
| 77 | . ; Okayed by Thomas Grohowski | 
|---|
| 78 | . F LA7I=1:1:10 D  ; | 
|---|
| 79 | . . I LA7I S LA7X="LA7UI"_LA7I | 
|---|
| 80 | . . K DIERR | 
|---|
| 81 | . . S LA7Y=$$FIND1^DIC(771,"","OX",LA7X,"B") | 
|---|
| 82 | . . I LA7Y<1 D  Q | 
|---|
| 83 | . . . S LAERR=1 | 
|---|
| 84 | . . . D BMES("ERROR: "_LA7X_" not found in file #771") | 
|---|
| 85 | . . K LAFDA,DIERR,LAMSG | 
|---|
| 86 | . . S LAFDA(1,771,LA7Y_",",3)=LA7FAC | 
|---|
| 87 | . . D FILE^DIE("","LAFDA(1)","LAMSG") | 
|---|
| 88 | . . ; notify if could not update | 
|---|
| 89 | . . S LAERR=$$FMERR("LAMSG","ERROR: unable to update "_LA7X_" in file #771") | 
|---|
| 90 | . ; delete facility ID for LA7LAB | 
|---|
| 91 | . K LAFDA,LAMSG,DIERR | 
|---|
| 92 | . S LA7Y=$$FIND1^DIC(771,"","OX","LA7LAB","B") | 
|---|
| 93 | . I 'LA7Y D | 
|---|
| 94 | . . S LAERR=1 | 
|---|
| 95 | . . D BMES("*** Missing 'LA7LAB' entry in HL7 APPLICATION PARAMETER (#771) file ***") | 
|---|
| 96 | . I LA7Y D | 
|---|
| 97 | . . K DIERR,LAFDA,LAMSG | 
|---|
| 98 | . . S LAFDA(1,771,LA7Y_",",3)="@" | 
|---|
| 99 | . . D FILE^DIE("","LAFDA(1)","LAMSG") | 
|---|
| 100 | . . S LAERR=$$FMERR("LAMSG","ERROR: Failed to update LA7LAB entry in file #771.") | 
|---|
| 101 | . S LAPOST=1 | 
|---|
| 102 | . D BMES("*** Updating facility name completed"_$S(LAERR:" but with errors",1:"")_" ***") | 
|---|
| 103 | ; | 
|---|
| 104 | ; | 
|---|
| 105 | I $D(^TMP("LA66",$J,"62.48")) D | 
|---|
| 106 | . D BMES("*** Restoring existing LA7UI* entries to ACTIVE in file #62.48 ***") | 
|---|
| 107 | . S LA7I=0,LAPOST=1 | 
|---|
| 108 | . F  S LA7I=$O(^TMP("LA66",$J,"62.48",LA7I)) Q:'LA7I  D | 
|---|
| 109 | . . K DIERR,LAFDA,LAMSG | 
|---|
| 110 | . . S LA7Y=$P(^LAHM(62.48,LA7I,0),"^") | 
|---|
| 111 | . . D BMES("*** Updating entry "_LA7Y_" to ACTIVE in file #62.48 ***") | 
|---|
| 112 | . . S LAFDA(2,62.48,LA7I_",",2)=^TMP("LA66",$J,"62.48",LA7I) | 
|---|
| 113 | . . D FILE^DIE("","LAFDA(2)","LAMSG") | 
|---|
| 114 | . . S LAERR=$$FMERR("LAMSG","ERROR: Failed to update "_LA7Y_" entry in file #62.48.") | 
|---|
| 115 | . D BMES("*** Updating existing LA7UI* entries to ACTIVE completed ***") | 
|---|
| 116 | ; | 
|---|
| 117 | I 'LAERR,'LAPOST D BMES("--- No actions required for post install ---") | 
|---|
| 118 | ; | 
|---|
| 119 | D RESTORE | 
|---|
| 120 | D BMES("*** Post install completed"_$S(LAERR:" but with errors",1:"")_" ***") | 
|---|
| 121 | ; | 
|---|
| 122 | N MSG | 
|---|
| 123 | S MSG="Installation of patch "_$G(XPDNM,"Unknown patch")_" completed on "_$$HTE^XLFDT($H) | 
|---|
| 124 | D ALERT(MSG) | 
|---|
| 125 | D BMES("Sending install completion alert to mail group G.LMI") | 
|---|
| 126 | ; | 
|---|
| 127 | K ^TMP($$RTNNM(),$J),^TMP("LA66",$J) | 
|---|
| 128 | Q | 
|---|
| 129 | ; | 
|---|
| 130 | ; | 
|---|
| 131 | BMES(STR,POS)   ; | 
|---|
| 132 | ; Display messages using BMES^XPDUTL or MES^XPDUTL | 
|---|
| 133 | ; Accepts single string or string array | 
|---|
| 134 | ; Input | 
|---|
| 135 | ;  STR The string to display (byRef or byValue) | 
|---|
| 136 | ;  POS <opt> value for $$CJ^XLFSTR (80=default) | 
|---|
| 137 | ; | 
|---|
| 138 | N I,X | 
|---|
| 139 | S POS=$G(POS,80) | 
|---|
| 140 | ; If an array, step through it and pass each node to MES since $$CJ^XLFSTR can't handle arrays | 
|---|
| 141 | I $D(STR)>9 D | 
|---|
| 142 | . S I=0 | 
|---|
| 143 | . F  S I=$O(STR(I)) Q:'I  S X=STR(I) D MES^XPDUTL($$TRIM^XLFSTR($$CJ^XLFSTR(X,POS),"R"," ")) | 
|---|
| 144 | ; | 
|---|
| 145 | I $D(STR)<2 D MES^XPDUTL($$TRIM^XLFSTR($$CJ^XLFSTR(STR,POS),"R"," ")) | 
|---|
| 146 | Q | 
|---|
| 147 | ; | 
|---|
| 148 | ; | 
|---|
| 149 | MES(STR,CJ,LM)  ; | 
|---|
| 150 | ; Displays a string using MES^XPDUTL | 
|---|
| 151 | ;  Inputs | 
|---|
| 152 | ;  STR: String to display | 
|---|
| 153 | ;   CJ: Center text?  1=yes 0=1 <dflt=1> | 
|---|
| 154 | ;   LM: Left Margin (padding) | 
|---|
| 155 | N X | 
|---|
| 156 | S STR=$G(STR) | 
|---|
| 157 | S CJ=$G(CJ,1) | 
|---|
| 158 | S LM=$G(LM) | 
|---|
| 159 | I LM<0 S LM=0 | 
|---|
| 160 | I CJ S STR=$$TRIM^XLFSTR($$CJ^XLFSTR(STR,$G(IOM,80)),"R"," ") | 
|---|
| 161 | I 'CJ I LM S X="" S $P(X," ",LM)=" " S STR=X_STR | 
|---|
| 162 | D MES^XPDUTL(STR) | 
|---|
| 163 | Q | 
|---|
| 164 | ; | 
|---|
| 165 | ; | 
|---|
| 166 | FMERR(LAREF,MSG)        ; | 
|---|
| 167 | ; Checks if a FileMan error occurred and displays help message | 
|---|
| 168 | ; and error text message. | 
|---|
| 169 | ; Input | 
|---|
| 170 | ;   LAREF Name of array that has the FM DIERR subscripts | 
|---|
| 171 | ;         ie FILE^DIE  msg_root variable | 
|---|
| 172 | ;     MSG <opt> Additional help text | 
|---|
| 173 | ; Output | 
|---|
| 174 | ;  1 if an error occurred, 0 if no error | 
|---|
| 175 | ;  Also writes the messages to the device | 
|---|
| 176 | N LAERRMSG,OK,FMERR | 
|---|
| 177 | S LAREF=$G(LAREF) | 
|---|
| 178 | S MSG=$G(MSG) | 
|---|
| 179 | S FMERR=0 | 
|---|
| 180 | D MSG^DIALOG("AE",.LAERRMSG,,,LAREF) | 
|---|
| 181 | I $D(LAERRMSG) D  ; | 
|---|
| 182 | . I MSG'="" D BMES(MSG) | 
|---|
| 183 | . D BMES(.LAERRMSG) | 
|---|
| 184 | . S FMERR=1 | 
|---|
| 185 | Q FMERR | 
|---|
| 186 | ; | 
|---|
| 187 | ; | 
|---|
| 188 | ENV2    ; | 
|---|
| 189 | ; Secondary Environment checks | 
|---|
| 190 | N X,I | 
|---|
| 191 | ; check and shutdown Auto Download job. | 
|---|
| 192 | S X=$G(^LA("ADL","STOP")) | 
|---|
| 193 | I $P(X,"^")=0 D  ; | 
|---|
| 194 | . D SETSTOP^LA7ADL1(2,DUZ) | 
|---|
| 195 | . D BMES("Shutting down Lab Universal Interface Auto Download Job") | 
|---|
| 196 | . S ^TMP($$RTNNM(),$J,"ADL")=1 | 
|---|
| 197 | . F I=1:1:10 W "." H 1 | 
|---|
| 198 | ; | 
|---|
| 199 | ; | 
|---|
| 200 | ; If previously installed then save current ACTIVE LA7UI* entries. | 
|---|
| 201 | K ^TMP("LA66",$J,"62.48") | 
|---|
| 202 | S I=0 | 
|---|
| 203 | F  S I=$O(^LAHM(62.48,I)) Q:'I  I $E($P(^LAHM(62.48,I,0),"^"),1,5)="LA7UI",$P(^LAHM(62.48,I,0),"^",3)=1 S ^TMP("LA66",$J,"62.48",I)=1 | 
|---|
| 204 | Q | 
|---|
| 205 | ; | 
|---|
| 206 | ; | 
|---|
| 207 | RESTORE ; | 
|---|
| 208 | ; Restore system after install | 
|---|
| 209 | N LAADL,X | 
|---|
| 210 | ; Restart auto download process status if stopped by install | 
|---|
| 211 | S LAADL=$G(^TMP($$RTNNM(),$J,"ADL")) | 
|---|
| 212 | I LAADL=1 D  ; | 
|---|
| 213 | . D ZTSK^LA7ADL | 
|---|
| 214 | . D SETSTOP^LA7ADL1(1,DUZ) | 
|---|
| 215 | . D BMES("Restarting Lab Universal Interface Auto Download Job") | 
|---|
| 216 | . K ^TMP($$RTNNM(),$J,"ADL") | 
|---|
| 217 | . H 3 | 
|---|
| 218 | ; | 
|---|
| 219 | ; If ADL not started, notify user to restart | 
|---|
| 220 | S X=$G(^LA("ADL","STOP")) | 
|---|
| 221 | S X=$P(X,"^") | 
|---|
| 222 | I X'=0 D BMES("Be sure to restart the Lab Universal Interface Auto Download Job") | 
|---|
| 223 | K ^TMP($$RTNNM(),$J) | 
|---|
| 224 | Q | 
|---|
| 225 | ; | 
|---|
| 226 | ; | 
|---|
| 227 | ALERT(MSG,RECIPS)       ; | 
|---|
| 228 | N DA,DIK,XQA,XQAMSG | 
|---|
| 229 | S XQAMSG=$G(MSG) | 
|---|
| 230 | S XQA("G.LMI")="" | 
|---|
| 231 | I $D(RECIPS) M XQA=RECIPS | 
|---|
| 232 | D SETUP^XQALERT | 
|---|
| 233 | Q | 
|---|
| 234 | ; | 
|---|
| 235 | ; | 
|---|
| 236 | RTNNM() ; | 
|---|
| 237 | Q $T(+0) | 
|---|