| 1 | MAGVCHK ;WOIFO/EdM - Checksums of Imaging Routines ; 08/22/2005  10:58
 | 
|---|
| 2 |  ;;3.0;IMAGING;**51**;26-August-2005
 | 
|---|
| 3 |  ;; +---------------------------------------------------------------+
 | 
|---|
| 4 |  ;; | Property of the US Government.                                |
 | 
|---|
| 5 |  ;; | No permission to copy or redistribute this software is given. |
 | 
|---|
| 6 |  ;; | Use of unreleased versions of this software requires the user |
 | 
|---|
| 7 |  ;; | to execute a written test agreement with the VistA Imaging    |
 | 
|---|
| 8 |  ;; | Development Office of the Department of Veterans Affairs,     |
 | 
|---|
| 9 |  ;; | telephone (301) 734-0100.                                     |
 | 
|---|
| 10 |  ;; |                                                               |
 | 
|---|
| 11 |  ;; | The Food and Drug Administration classifies this software as  |
 | 
|---|
| 12 |  ;; | a medical device.  As such, it may not be changed in any way. |
 | 
|---|
| 13 |  ;; | Modifications to this software may result in an adulterated   |
 | 
|---|
| 14 |  ;; | medical device under 21CFR820, the use of which is considered |
 | 
|---|
| 15 |  ;; | to be a violation of US Federal Statutes.                     |
 | 
|---|
| 16 |  ;; +---------------------------------------------------------------+
 | 
|---|
| 17 |  ;;
 | 
|---|
| 18 |  Q
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 |  ; The entry below is called from ET-Phone-Home
 | 
|---|
| 21 |  ;
 | 
|---|
| 22 | GATEWAY(ZTSK,MAGDBB) ; RPC = MAG VISTA CHECKSUMS
 | 
|---|
| 23 |  N D0,X,ZTDESC,ZTDTH,ZTRTN,ZTSAVE
 | 
|---|
| 24 |  S ZTSK=0,D0=$O(^MAG(2006.1,0)) Q:'D0
 | 
|---|
| 25 |  Q:$G(MAGDBB)'["@"  ; Must be valid e-mail address
 | 
|---|
| 26 |  L +^MAG(2006.1,"CHECKSUM"):10 Q:'$T  ; Don't hold up other processing...
 | 
|---|
| 27 |  D:$G(^MAG(2006.1,D0,"LAST CHECKSUM"))<DT
 | 
|---|
| 28 |  . ;
 | 
|---|
| 29 |  . S ZTRTN="CHECK^"_$T(+0)
 | 
|---|
| 30 |  . S ZTDESC="Imaging Checksum Collection"
 | 
|---|
| 31 |  . S ZTDTH=$H ; Now!
 | 
|---|
| 32 |  . S ZTSAVE("MAGDBB")=MAGDBB
 | 
|---|
| 33 |  . D ^%ZTLOAD,HOME^%ZIS
 | 
|---|
| 34 |  . I '$D(ZTSK) S ZTSK=0 Q  ; TaskMan did not Accept Request
 | 
|---|
| 35 |  . ; No matter how many sub-sites in the consolidated site,
 | 
|---|
| 36 |  . ; run this program only once per day:
 | 
|---|
| 37 |  . S D0=0 F  S D0=$O(^MAG(2006.1,D0)) Q:'D0  S ^MAG(2006.1,D0,"LAST CHECKSUM")=DT
 | 
|---|
| 38 |  . Q
 | 
|---|
| 39 |  L -^MAG(2006.1,"CHECKSUM")
 | 
|---|
| 40 |  Q
 | 
|---|
| 41 |  ;
 | 
|---|
| 42 | CHECK ; Collect checksums for Imaging Routines
 | 
|---|
| 43 |  N CUR,I,MAGFM,R,SITE,X,XMERR,XMID,XMSUB,XMY,XMZ
 | 
|---|
| 44 |  Q:$G(MAGDBB)'["@"  ; Must be valid e-mail address
 | 
|---|
| 45 |  D DT^DICRW
 | 
|---|
| 46 |  D
 | 
|---|
| 47 |  . N DATE,I,MAGDATA,MSG,N,PKG,PKT,PV
 | 
|---|
| 48 |  . S CUR=$$VERSION^XPDUTL("IMAGING")
 | 
|---|
| 49 |  . D LIST^DIC(9.7,,".01;2I;51I","K","*","MAG","MAG*","B",,,"MAGDATA","MSG")
 | 
|---|
| 50 |  . S I="" F  S I=$O(MAGDATA("DILIST",2,I)) Q:I=""  D
 | 
|---|
| 51 |  . . S I(+$G(MAGDATA("DILIST","ID",I,2)),I)=""
 | 
|---|
| 52 |  . . Q
 | 
|---|
| 53 |  . S N=0,DATE="" F  S DATE=$O(I(DATE)) Q:DATE=""  D
 | 
|---|
| 54 |  . . S I="" F  S I=$O(I(DATE,I)) Q:I=""  D
 | 
|---|
| 55 |  . . . S X=$G(MAGDATA("DILIST","ID",I,.01)) Q:$P(X,"*",2)'=CUR
 | 
|---|
| 56 |  . . . S PATCH=+$P(X,"*",3) Q:'PATCH
 | 
|---|
| 57 |  . . . K:$G(N(1,PATCH)) N(2,N(1,PATCH))
 | 
|---|
| 58 |  . . . S N=N+1,N(1,PATCH)=N,N(2,N)=PATCH
 | 
|---|
| 59 |  . . . S N(3,N)=$G(MAGDATA("DILIST","ID",I,51))
 | 
|---|
| 60 |  . . . Q
 | 
|---|
| 61 |  . . Q
 | 
|---|
| 62 |  . S CUR=CUR_";IMAGING;",I="**",X=""
 | 
|---|
| 63 |  . S N="" F  S N=$O(N(2,N)) Q:N=""  S CUR=CUR_I_N(2,N),X=N(3,N),I=","
 | 
|---|
| 64 |  . S:I'="**" CUR=CUR_"**"
 | 
|---|
| 65 |  . S:X'="" CUR=CUR_";"_$$FMDATE(X)
 | 
|---|
| 66 |  . Q
 | 
|---|
| 67 |  S SITE=0 S:$T(INST^XUPARAM)'="" SITE=$$KSP^XUPARAM("INST")
 | 
|---|
| 68 |  D:SITE FIND^DIC(4,"",.01,"A",SITE,"*",,,,"MAGFM")
 | 
|---|
| 69 |  S SITE=$G(MAGFM("DILIST",1,1)) S:SITE'="" SITE=SITE_" "
 | 
|---|
| 70 |  S SITE=SITE_"VistA System"
 | 
|---|
| 71 |  K ^TMP("MAG",$J,"CHECKSUM"),MAGFM
 | 
|---|
| 72 |  S I=0
 | 
|---|
| 73 |  K X D DOMAIN^MAGDRPC1(.X)
 | 
|---|
| 74 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="SID="_X
 | 
|---|
| 75 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="DT="_DT
 | 
|---|
| 76 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="IP=VistA"
 | 
|---|
| 77 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="BLD="_CUR
 | 
|---|
| 78 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="TTL="_SITE
 | 
|---|
| 79 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="PHY=VistA"
 | 
|---|
| 80 |  S R="MAG" F  S R=$O(^$R(R)) Q:$E(R,1,3)'="MAG"  D
 | 
|---|
| 81 |  . S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="RTN="_R
 | 
|---|
| 82 |  . S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)="CHK="_$$CHK1(R)_"^"_$$CHK2(R)
 | 
|---|
| 83 |  . Q
 | 
|---|
| 84 |  S I=I+1,^TMP("MAG",$J,"CHECKSUM",I)=""
 | 
|---|
| 85 |  S XMSUB="Daily Report"
 | 
|---|
| 86 |  S XMID=$G(DUZ) S:'XMID XMID=.5
 | 
|---|
| 87 |  S XMY(XMID)=""
 | 
|---|
| 88 |  S XMY(MAGDBB)=""
 | 
|---|
| 89 |  D SENDMSG^XMXAPI(XMID,XMSUB,$NAME(^TMP("MAG",$J,"CHECKSUM")),.XMY,,.XMZ,)
 | 
|---|
| 90 |  I $G(XMERR) M XMERR=^TMP("XMERR",$J) S $EC=",U13-Cannot send MailMan message,"
 | 
|---|
| 91 |  Q
 | 
|---|
| 92 |  ;
 | 
|---|
| 93 | CHK1(R) N K,X,Y
 | 
|---|
| 94 |  S Y=0
 | 
|---|
| 95 |  F K=1:1 S X=$T(+K^@R) Q:X=""  S:K'=2 Y=Y+$$C1(X)
 | 
|---|
| 96 |  Q Y
 | 
|---|
| 97 |  ;
 | 
|---|
| 98 | C1(X) N F,I,Y
 | 
|---|
| 99 |  S Y=0
 | 
|---|
| 100 |  S F=$F(X," "),F=$S($E(X,F)'=";":$L(X),$E(X,F+1)=";":$L(X),1:F-2)
 | 
|---|
| 101 |  F I=1:1:F S Y=$A(X,I)*I+Y
 | 
|---|
| 102 |  Q Y
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | CHK2(R) N K,X,Y
 | 
|---|
| 105 |  S Y=0
 | 
|---|
| 106 |  F K=1:1 S X=$T(+K^@R) Q:X=""  S:K'=2 Y=Y+$$C2(X,K)
 | 
|---|
| 107 |  Q Y
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 | C2(X,K) N F,I,Y
 | 
|---|
| 110 |  S Y=0
 | 
|---|
| 111 |  S F=$F(X," "),F=$S($E(X,F)'=";":$L(X),$E(X,F+1)=";":$L(X),1:F-2)
 | 
|---|
| 112 |  F I=1:1:F S Y=$A(X,I)*(I+K)+Y
 | 
|---|
| 113 |  Q Y
 | 
|---|
| 114 |  ;
 | 
|---|
| 115 | FMDATE(X) N D,M,Y
 | 
|---|
| 116 |  S X=X\1,D=X#100,M=X\100#100,Y=X\10000+1700
 | 
|---|
| 117 |  Q D_"-"_$P("January February March April May June July August September October November December"," ",M)_"-"_Y
 | 
|---|
| 118 |  ;
 | 
|---|