| 1 | DIET ;SFISC/XAK-DISPLAY INPUT TEMPLATE    ALSO DOES AUDITING! ;22MAR2006
 | 
|---|
| 2 |  ;;22.0;VA FileMan;**69,49,104,129,147**;Mar 30, 1999
 | 
|---|
| 3 |  ;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 |  N DICMX
 | 
|---|
| 5 |  I '$D(^DIE(D0,0)) G EXIT
 | 
|---|
| 6 |  S DICMX="W X,!"
 | 
|---|
| 7 | EN ;
 | 
|---|
| 8 |  N DI,DIET,DIETS,D
 | 
|---|
| 9 |  S DIET=D0 D GET^DIETED("DIETS")
 | 
|---|
| 10 |  F D=0:0 S D=$O(DIETS(D)) Q:'D  S X=DIETS(D) X DICMX Q:'$D(D)
 | 
|---|
| 11 | EXIT S X="" Q
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 | AUD N DP,DG,DPS,DIEX,DIIX,DIANUM ; DI*22*49
 | 
|---|
| 16 |  S DIIX="3^.01^A",DP=+DO(2) D AUDIT:DP>0 Q
 | 
|---|
| 17 | AUDIT ;
 | 
|---|
| 18 |  N C,DIEDA,DIEF,%T,%F,%D,%,Y
 | 
|---|
| 19 |  I $D(^DD(DP,+$P(DIIX,U,2),"AX")) X ^("AX") Q:'$T
 | 
|---|
| 20 |  K % S DIEX=X D @+DIIX
 | 
|---|
| 21 |  K DIIX,DPS,DIEX
 | 
|---|
| 22 |  Q
 | 
|---|
| 23 | 3 ;
 | 
|---|
| 24 |  I $D(DG),$D(DIANUM($P(DIIX,U,2))) S Y=X,(DIEX(1),C)=$P(^DD(DP,+$P(DIIX,U,2),0),U,2) D Y^DIQ S @DIANUM($P(DIIX,U,2))=Y K DIANUM($P(DIIX,U,2)) G I
 | 
|---|
| 25 | 2 ;
 | 
|---|
| 26 |  S:$D(DP(1)) DPS=DP(1) S DIEDA="",DIEF="",%=1,DP(1)=DP,%F=+DP,X=DA
 | 
|---|
| 27 |  F C=1:1 Q:'$D(^DD(DP(1),0,"UP"))  S %F=^("UP"),%=$O(^DD(%F,"SB",DP(1),0)) S:%="" %=-1 S DIEDA=DA(C)_","_DIEDA,DIEF=%_","_DIEF,DP(1)=%F
 | 
|---|
| 28 |  D ADD I $D(DG),+DIIX=2 S DIANUM($P(DIIX,U,2))="^DIA("_%F_","_+Y_",3)"
 | 
|---|
| 29 |  S (DIEX(1),C)=$P(^DD(DP,+$P(DIIX,U,2),0),U,2),Y=DIEX D Y^DIQ
 | 
|---|
| 30 |  S ^DIA(%F,"B",DIEDA_DA,%D)="",X=DIEX S:$D(DPS) DP(1)=DPS
 | 
|---|
| 31 |  S ^DIA(%F,%D,0)=DIEDA_DA_U_%T_U_DIEF_+$P(DIIX,U,2)_U_DUZ_U_$P(DIIX,U,3),^(+DIIX)=Y
 | 
|---|
| 32 | I I (DIEX(1)["D")!(DIEX(1)["P")!(DIEX(1)["V")!(DIEX(1)["S") S ^(DIIX+.1)=X_U_DIEX(1)
 | 
|---|
| 33 |  Q
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 | ACCESSED(%F,REF) ;WILL FLAG ENTRY 'REF' IN FILE '%F' AS BEING ACCESSED BY CURRENT USER, CURRENT TIME, CURRENT OPTION
 | 
|---|
| 36 |  N Y,X,%T,%D
 | 
|---|
| 37 |  D:'$G(DT) DT^DICRW
 | 
|---|
| 38 |  Q:'%F!'REF  S %F=+%F,(REF,X)=+REF Q:'$D(^DIC(%F))
 | 
|---|
| 39 |  D ADD ;COMES BACK WITH %T AND Y--THE AUDIT REF
 | 
|---|
| 40 |  S ^DIA(%F,Y,0)=REF_U_%T_U_.01_U_DUZ_U_U_"i"
 | 
|---|
| 41 |  S ^DIA(%F,"B",REF,Y)=""
 | 
|---|
| 42 |  Q
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 | ADD S Y=$O(^DIA(%F,"A"),-1) I 'Y S ^DIA(%F,0)=$P(^DIC(%F,0),U)_" AUDIT^1.1I"
 | 
|---|
| 45 |  F Y=Y+1:1 I '$D(^(Y)) D LOCK^DILF("^DIA(%F,Y)") I  Q:'$D(^(Y))  L -^DIA(%F,Y) ;**PATCH 147
 | 
|---|
| 46 |  S ^(Y,0)=X L -^DIA(%F,Y)
 | 
|---|
| 47 |  S %T=$G(XQY),%D=$S($D(XQORNOD)#2:XQORNOD,$D(HLORNOD)#2:HLORNOD,1:"") I %T!%D S ^DIA(%F,Y,4.1)=%T_U_%D
 | 
|---|
| 48 |  S $P(^(0),U,3,4)=Y_U_($P(^DIA(%F,0),U,4)+1)
 | 
|---|
| 49 | TIME S %D=Y,%T=$$HTFM^DILIBF($H)
 | 
|---|
| 50 |  S ^DIA(%F,"C",%T,Y)="",^DIA(%F,"D",DUZ,Y)=""
 | 
|---|
| 51 |  Q
 | 
|---|