Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: DGISORPT

DGISORPT.m

Go to the documentation of this file.
  1. DGISORPT ;ALB/WJG/DHH SENSITIVE RECDS RPT;06/18/2005
  1. ;;5.3;Registration;**666,1015**;Aug 13, 1993;Build 21
  1. ;This was based off of a Pug Fileman template, that was tasked
  1. ;to run by the user. It was changed to incorporate the use of a
  1. ;Mail Group.
  1. ;
  1. EN ;
  1. K ^TMP($J),^UTILITY($J)
  1. S U="^"
  1. S (DGYEST,A)=9999999.9999-$$FMADD^XLFDT(DT,-1),A=A-1
  1. F S A=$O(^DGSL(38.1,"AD",A)),A1=0 Q:'A!(A>DGYEST) F S A1=$O(^DGSL(38.1,"AD",A,A1)) Q:A1="" D
  1. . S RECDAT=$G(^DGSL(38.1,A1,0)) Q:RECDAT=""
  1. . S RECDAT1=$G(^DGSL(38.1,A1,"D",A,0)) Q:RECDAT1=""
  1. . S RDATE=$P(RECDAT1,U) Q:RDATE=""
  1. . S RDATE1=$E(RDATE,4,5)_"/"_$E(RDATE,6,7)_"/"_$E(RDATE,2,3)
  1. . S TIME=$P(RDATE,".",2),TIME=$E(TIME_"0000",1,4)
  1. . S RDATE1=RDATE1_"@"_TIME
  1. . S PATNAME=$P($G(^DPT(A1,0)),U) Q:PATNAME=""
  1. . S USERIEN=$P(RECDAT1,U,2) Q:USERIEN=""
  1. . S OPT=$P(RECDAT1,U,3) S:OPT="" OPT=""
  1. . S INP=$P(RECDAT1,U,4) S:INP="" INP=""
  1. . S USERDAT=$G(^VA(200,USERIEN,0)) Q:USERDAT=""
  1. . S USER=$E($P(USERDAT,U),1,20) Q:USER=""
  1. . S TITLE1=$P(USERDAT,U,9) S:TITLE1="" TITLE=""
  1. . S:TITLE1'="" TITLE=$P($G(^DIC(3.1,TITLE1,0)),U)
  1. . S ALIAS=$P($G(^VA(200,USERIEN,3,1,0)),U)
  1. . S SECIEN=$P($G(^VA(200,USERIEN,5)),U) S:SECIEN="" SECT=""
  1. . S:SECIEN'="" SECT=$P($G(^DIC(49,SECIEN,0)),U) S:SECT="" SECT=""
  1. . S:USERIEN=".5" SECT="VISTA SYSTEM"
  1. . S:SECT'="" SECT=$E(SECT,1,20) S:ALIAS'="" ALIAS=$E(ALIAS,1,5) S:OPT'="" OPT=$E(OPT,1,25)
  1. . S ^UTILITY($J,RDATE,A1)=PATNAME_U_RDATE1_U_USER_U_TITLE_U_ALIAS_U_SECT_U_OPT_U_INP
  1. XMTEXT ;sets up message text
  1. S LINE=0
  1. S LINE=LINE+1
  1. S ^TMP($J,LINE)="PATIENT^DATE/TIME^USER^TITLE^ALIAS^SERVICE^OPTION USED^INPATIENT"
  1. S LINE=LINE+1
  1. S T1=0 F S T1=$O(^UTILITY($J,T1)) Q:T1="" S T2=0 F S T2=$O(^UTILITY($J,T1,T2)) Q:T2="" D
  1. . S TEXT=$G(^UTILITY($J,T1,T2)) Q:TEXT=""
  1. . S ^TMP($J,LINE)=TEXT,LINE=LINE+1
  1. NOPAT ;set message text if ^tmp($J=null
  1. I '$D(^TMP($J,2)) D
  1. . S ^TMP($J,2)="No Sensitive Records were accessed on "_$$FMTE^XLFDT(DT-1,1)_"."
  1. SEND ;
  1. S XMSUB="Sensitive Record Auditing Report"
  1. S XMTEXT="^TMP($J,"
  1. S XMY("G.DG ISO SENSITIVE RCDS")=""
  1. S XMDUZ=.5 D ^XMD
  1. K XMDUZ,XMSUB,XMTEXT,XMY,^TMP($J)
  1. Q ;
  1. K XMSUB,XMTEXT,XMY,XMDUZ,LINE,T1,T2,TEXT,^UTILITY($J),^TMP($J),X1,X2,RDATE,A,A1,PATNAME,RECDAT,RECDAT1,USER
  1. K TITLE,TITLE1,OPT,INP,USERDAT,SECT,ALIAS,USERIEN,X,Y,SECIEN,TIME,RDATE1,DGYEST
  1. Q
  1. S DGCNT=$G(DGCNT)+1
  1. I DGCNT=1 W !,"PATIENT^DATE/TIME^USER^TITLE^ALIAS^SERVICE^OPTION USED^INPATIENT",!
  1. ; DGCNT is killed upon exiting DG SENSITIVE RCDS RPT-EXPORT option
  1. Q