MAGGTU9 ;WOIFO/LB/GEK - Imaging utilities assign key
;;3.0;IMAGING;**8,59**;Nov 27, 2007;Build 20
;; Per VHA Directive 2004-038, this routine should not be modified.
;; +---------------------------------------------------------------+
;; | Property of the US Government. |
;; | No permission to copy or redistribute this software is given. |
;; | Use of unreleased versions of this software requires the user |
;; | to execute a written test agreement with the VistA Imaging |
;; | Development Office of the Department of Veterans Affairs, |
;; | telephone (301) 734-0100. |
;; | |
;; | The Food and Drug Administration classifies this software as |
;; | a medical device. As such, it may not be changed in any way. |
;; | Modifications to this software may result in an adulterated |
;; | medical device under 21CFR820, the use of which is considered |
;; | to be a violation of US Federal Statutes. |
;; +---------------------------------------------------------------+
;;
Q
CHKKEY ;
N NOGIVE
S NOGIVE=1
GIVEKEY ;Give MAGDISP CLIN key to all MAG WINDOWS option holders
; that have neither MAGDISP CLIN nor MAGDISP ADMIN
; Find the menu option's IEN
N MKEYC,MKEYA,ERR,OPT,MAGUSER,I,KEYCLIN,KEYADMIN,KEYCT,KEYECT,XCT
N KEYHASC,KEYHASA,KEYHASB,KEYNONE,SP,LSP
N UCT,UTOT,OPTACC,MDOT,UDISCT
; This could be made Generic if ever a need, to search for users
; withour either key, and assigned those users the first (KEYCLIN)
S KEYCLIN="MAGDISP CLIN"
S KEYADMIN="MAGDISP ADMIN"
S KEYCT=0 ; count of number of users that were assigned the key.
S KEYECT=0 ; count of number of errors during the assignment.
S KEYHASC=0 ; count of number of users that already have key Clin
S KEYHASA=0 ; count of number of users that already have key Admin
S KEYHASB=0 ; count of number of users that Have Both keys
S KEYNONE=0 ; count of Users that have Neither Key.
S OPTACC=0 ; count of users with access to MAG WINDOWS.
S UDISCT=0 ; count of Disabled Users Skipped.
S MDOT=10000 ; print '.' to screen to show progress.
S UCT=0 ; user count. for progress
S UTOT=$P(^VA(200,0),"^",4)
;
I $G(NOGIVE) D
. D MES^XPDUTL("Checking for users that have access to Option : "_"MAG WINDOWS")
. D MES^XPDUTL(" but do not have either '"_KEYCLIN_"' or '"_KEYADMIN_"' Keys")
. D MES^XPDUTL(" Disabled users (DISUSER=1) are skipped, they are not checked.")
. Q
E D MES^XPDUTL("Assigning "_KEYCLIN_" to all users with access to Option : "_"MAG WINDOWS")
D MES^XPDUTL(" ")
S OPT=$$FIND1^DIC(19,"","X","MAG WINDOWS","","","ERR")
I OPT="" D MES^XPDUTL("ERROR ",$G(ERR("DIERR",1,"TEXT",1))) Q
I OPT=0 D MES^XPDUTL("MAG WINDOWS wasn't found in Option File") Q
; Lookup the security key
S MKEYC=$$LKUP^XPDKEY(KEYCLIN)
S MKEYA=$$LKUP^XPDKEY(KEYADMIN)
I ('MKEYC)!('MKEYA) D MES^XPDUTL("ERROR: Imaging Display Keys are not defined at this site") Q
; Check all Users at site to see if they don't have either Clin or Admin
D MES^XPDUTL("Checking users...")
D MES^XPDUTL(" ")
S I=0 F S I=$O(^VA(200,I)) Q:'I D
. I $$GET1^DIQ(200,I,7,"E")]"" S UDISCT=UDISCT+1 Q
. S UCT=UCT+1 I UCT>MDOT S MDOT=MDOT+10000 D MES^XPDUTL(UCT_" of "_UTOT_" users checked...")
. I (($$ACCESS^XQCHK(I,OPT))>0) S OPTACC=OPTACC+1 D C(I)
. Q
S SP=" "
S LSP=$L(UTOT)+3
D MES^XPDUTL(" ")
I $G(NOGIVE) D
. D MES^XPDUTL($E(SP,1,LSP-$L(OPTACC))_OPTACC_" of "_UTOT_" Users have access to option MAG WINDOWS.")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASB))_KEYHASB_" Users have Both Keys ")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASC))_KEYHASC_" Users only have "_KEYCLIN_" key")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASA))_KEYHASA_" Users only have "_KEYADMIN_" key")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYNONE))_KEYNONE_" Users have neither Key")
. I KEYECT>0 D MES^XPDUTL(KEYECT_" Errors during Key Assignment. See install log for details")
. Q
I '$G(NOGIVE) D
. D MES^XPDUTL($E(SP,1,LSP-$L(OPTACC))_OPTACC_" of "_UTOT_" Users have access to option MAG WINDOWS.")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASB))_KEYHASB_" Users already have Both Keys ")
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASC))_KEYHASC_" Users have Only Key "_KEYCLIN)
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYHASA))_KEYHASA_" Users have Only Key "_KEYADMIN)
. D MES^XPDUTL($E(SP,1,LSP-$L(KEYCT))_KEYCT_" Users were assigned key: "_KEYCLIN)
. D MES^XPDUTL("Assignment Complete.")
. I KEYECT>0 D MES^XPDUTL(KEYECT_" Errors during Key Assignment. See install log for details")
. Q
Q
C(USER) ;
; check KEY for USER
N DO,D1,MFDA,ZC,ZA,MIEN
; check to see if they have the Clin key
S ZC=$$FIND1^DIC(200.051,","_USER_",","",KEYCLIN)
I ZC="" D Q
. D MES^XPDUTL("ERROR Validating that user ("_USER_") has Key "_KEYCLIN)
. S KEYECT=KEYECT+1
. Q
; check to see if they have the Admin key
S ZA=$$FIND1^DIC(200.051,","_USER_",","",KEYADMIN)
I ZA="" D Q
. D MES^XPDUTL("ERROR Validating that user ("_USER_") has Key "_KEYADMIN)
. S KEYECT=KEYECT+1
. Q
I ((+ZC)&(+ZA)) S KEYHASB=KEYHASB+1 Q
I +ZC S KEYHASC=KEYHASC+1 Q
I +ZA S KEYHASA=KEYHASA+1 Q
S KEYNONE=KEYNONE+1
I $G(NOGIVE) D Q
. D MES^XPDUTL("User: "_$P($G(^VA(200,USER,0)),"^")_" has neither Key")
. Q
S MFDA(200.051,"+1,"_USER_",",.01)=MKEYC
S MFDA(200.051,"+1,"_USER_",",1)=DUZ
S MFDA(200.051,"+1,"_USER_",",2)=DT
S MIEN(1)=MKEYC_","
D UPDATE^DIE("","MFDA","MIEN")
I $D(DIERR) D Q
. D MES^XPDUTL("ERROR Assigning Key ("_KEYCLIN_") to user ("_USER_")")
. S KEYECT=KEYECT+1
. D CLEAN^DILF
. Q
S KEYCT=KEYCT+1
D CLEAN^DILF
Q
FLT ; Create a Few Public Filters as a default for sites.
; Only create new public filters if file is empty.
N DIK
I +$P(^MAG(2005.87,0),"^",3) D Q
. D MES^XPDUTL("The IMAGE LIST FILTERS File is not empty,")
. D MES^XPDUTL(" Default Public Filters were not installed.")
. Q
S ^MAG(2005.87,1,0)="Rad All^RAD^CLIN^^^^^^0"
S ^MAG(2005.87,1,1)="^1^.05"
S ^MAG(2005.87,2,0)="Clin All^^CLIN^^^^^^0"
S ^MAG(2005.87,2,1)="^1^.05"
S ^MAG(2005.87,3,0)="Admin All^^ADMIN^^^^^^0"
S ^MAG(2005.87,3,1)="^1^.05"
S ^MAG(2005.87,4,0)="Clin 2 yr^^CLIN^^^^^^-24"
S ^MAG(2005.87,4,1)="^1^.05"
S ^MAG(2005.87,5,0)="Admin 10-10EZ All^^ADMIN^46,^^^^^0"
S ^MAG(2005.87,5,1)="^1^.05"
S ^MAG(2005.87,6,0)="Adv Directives^^CLIN^67^^^^^0"
S ^MAG(2005.87,6,1)="^1^.05"
S ^MAG(2005.87,7,0)="All^^^^^^^^0"
S ^MAG(2005.87,7,1)="^1^.05"
S ^MAG(2005.87,8,0)="All 2 yr^^^^^^^^-24"
S ^MAG(2005.87,8,1)="^1^.05"
S ^MAG(2005.87,9,0)="All 6 mth^^^^^^^^-6"
S ^MAG(2005.87,9,1)="^1^.05"
;All Advance Directives^^CLIN^67^^^^^0
S DIK="^MAG(2005.87," D IXALL^DIK
D MES^XPDUTL("Default Public Filters added to IMAGE LIST FILTERS File.")
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMAGGTU9 6900 printed Dec 13, 2024@02:03:33 Page 2
MAGGTU9 ;WOIFO/LB/GEK - Imaging utilities assign key
+1 ;;3.0;IMAGING;**8,59**;Nov 27, 2007;Build 20
+2 ;; Per VHA Directive 2004-038, this routine should not be modified.
+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 QUIT
CHKKEY ;
+1 NEW NOGIVE
+2 SET NOGIVE=1
GIVEKEY ;Give MAGDISP CLIN key to all MAG WINDOWS option holders
+1 ; that have neither MAGDISP CLIN nor MAGDISP ADMIN
+2 ; Find the menu option's IEN
+3 NEW MKEYC,MKEYA,ERR,OPT,MAGUSER,I,KEYCLIN,KEYADMIN,KEYCT,KEYECT,XCT
+4 NEW KEYHASC,KEYHASA,KEYHASB,KEYNONE,SP,LSP
+5 NEW UCT,UTOT,OPTACC,MDOT,UDISCT
+6 ; This could be made Generic if ever a need, to search for users
+7 ; withour either key, and assigned those users the first (KEYCLIN)
+8 SET KEYCLIN="MAGDISP CLIN"
+9 SET KEYADMIN="MAGDISP ADMIN"
+10 ; count of number of users that were assigned the key.
SET KEYCT=0
+11 ; count of number of errors during the assignment.
SET KEYECT=0
+12 ; count of number of users that already have key Clin
SET KEYHASC=0
+13 ; count of number of users that already have key Admin
SET KEYHASA=0
+14 ; count of number of users that Have Both keys
SET KEYHASB=0
+15 ; count of Users that have Neither Key.
SET KEYNONE=0
+16 ; count of users with access to MAG WINDOWS.
SET OPTACC=0
+17 ; count of Disabled Users Skipped.
SET UDISCT=0
+18 ; print '.' to screen to show progress.
SET MDOT=10000
+19 ; user count. for progress
SET UCT=0
+20 SET UTOT=$PIECE(^VA(200,0),"^",4)
+21 ;
+22 IF $GET(NOGIVE)
Begin DoDot:1
+23 DO MES^XPDUTL("Checking for users that have access to Option : "_"MAG WINDOWS")
+24 DO MES^XPDUTL(" but do not have either '"_KEYCLIN_"' or '"_KEYADMIN_"' Keys")
+25 DO MES^XPDUTL(" Disabled users (DISUSER=1) are skipped, they are not checked.")
+26 QUIT
End DoDot:1
+27 IF '$TEST
DO MES^XPDUTL("Assigning "_KEYCLIN_" to all users with access to Option : "_"MAG WINDOWS")
+28 DO MES^XPDUTL(" ")
+29 SET OPT=$$FIND1^DIC(19,"","X","MAG WINDOWS","","","ERR")
+30 IF OPT=""
DO MES^XPDUTL("ERROR ",$GET(ERR("DIERR",1,"TEXT",1)))
QUIT
+31 IF OPT=0
DO MES^XPDUTL("MAG WINDOWS wasn't found in Option File")
QUIT
+32 ; Lookup the security key
+33 SET MKEYC=$$LKUP^XPDKEY(KEYCLIN)
+34 SET MKEYA=$$LKUP^XPDKEY(KEYADMIN)
+35 IF ('MKEYC)!('MKEYA)
DO MES^XPDUTL("ERROR: Imaging Display Keys are not defined at this site")
QUIT
+36 ; Check all Users at site to see if they don't have either Clin or Admin
+37 DO MES^XPDUTL("Checking users...")
+38 DO MES^XPDUTL(" ")
+39 SET I=0
FOR
SET I=$ORDER(^VA(200,I))
if 'I
QUIT
Begin DoDot:1
+40 IF $$GET1^DIQ(200,I,7,"E")]""
SET UDISCT=UDISCT+1
QUIT
+41 SET UCT=UCT+1
IF UCT>MDOT
SET MDOT=MDOT+10000
DO MES^XPDUTL(UCT_" of "_UTOT_" users checked...")
+42 IF (($$ACCESS^XQCHK(I,OPT))>0)
SET OPTACC=OPTACC+1
DO C(I)
+43 QUIT
End DoDot:1
+44 SET SP=" "
+45 SET LSP=$LENGTH(UTOT)+3
+46 DO MES^XPDUTL(" ")
+47 IF $GET(NOGIVE)
Begin DoDot:1
+48 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(OPTACC))_OPTACC_" of "_UTOT_" Users have access to option MAG WINDOWS.")
+49 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASB))_KEYHASB_" Users have Both Keys ")
+50 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASC))_KEYHASC_" Users only have "_KEYCLIN_" key")
+51 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASA))_KEYHASA_" Users only have "_KEYADMIN_" key")
+52 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYNONE))_KEYNONE_" Users have neither Key")
+53 IF KEYECT>0
DO MES^XPDUTL(KEYECT_" Errors during Key Assignment. See install log for details")
+54 QUIT
End DoDot:1
+55 IF '$GET(NOGIVE)
Begin DoDot:1
+56 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(OPTACC))_OPTACC_" of "_UTOT_" Users have access to option MAG WINDOWS.")
+57 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASB))_KEYHASB_" Users already have Both Keys ")
+58 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASC))_KEYHASC_" Users have Only Key "_KEYCLIN)
+59 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYHASA))_KEYHASA_" Users have Only Key "_KEYADMIN)
+60 DO MES^XPDUTL($EXTRACT(SP,1,LSP-$LENGTH(KEYCT))_KEYCT_" Users were assigned key: "_KEYCLIN)
+61 DO MES^XPDUTL("Assignment Complete.")
+62 IF KEYECT>0
DO MES^XPDUTL(KEYECT_" Errors during Key Assignment. See install log for details")
+63 QUIT
End DoDot:1
+64 QUIT
C(USER) ;
+1 ; check KEY for USER
+2 NEW DO,D1,MFDA,ZC,ZA,MIEN
+3 ; check to see if they have the Clin key
+4 SET ZC=$$FIND1^DIC(200.051,","_USER_",","",KEYCLIN)
+5 IF ZC=""
Begin DoDot:1
+6 DO MES^XPDUTL("ERROR Validating that user ("_USER_") has Key "_KEYCLIN)
+7 SET KEYECT=KEYECT+1
+8 QUIT
End DoDot:1
QUIT
+9 ; check to see if they have the Admin key
+10 SET ZA=$$FIND1^DIC(200.051,","_USER_",","",KEYADMIN)
+11 IF ZA=""
Begin DoDot:1
+12 DO MES^XPDUTL("ERROR Validating that user ("_USER_") has Key "_KEYADMIN)
+13 SET KEYECT=KEYECT+1
+14 QUIT
End DoDot:1
QUIT
+15 IF ((+ZC)&(+ZA))
SET KEYHASB=KEYHASB+1
QUIT
+16 IF +ZC
SET KEYHASC=KEYHASC+1
QUIT
+17 IF +ZA
SET KEYHASA=KEYHASA+1
QUIT
+18 SET KEYNONE=KEYNONE+1
+19 IF $GET(NOGIVE)
Begin DoDot:1
+20 DO MES^XPDUTL("User: "_$PIECE($GET(^VA(200,USER,0)),"^")_" has neither Key")
+21 QUIT
End DoDot:1
QUIT
+22 SET MFDA(200.051,"+1,"_USER_",",.01)=MKEYC
+23 SET MFDA(200.051,"+1,"_USER_",",1)=DUZ
+24 SET MFDA(200.051,"+1,"_USER_",",2)=DT
+25 SET MIEN(1)=MKEYC_","
+26 DO UPDATE^DIE("","MFDA","MIEN")
+27 IF $DATA(DIERR)
Begin DoDot:1
+28 DO MES^XPDUTL("ERROR Assigning Key ("_KEYCLIN_") to user ("_USER_")")
+29 SET KEYECT=KEYECT+1
+30 DO CLEAN^DILF
+31 QUIT
End DoDot:1
QUIT
+32 SET KEYCT=KEYCT+1
+33 DO CLEAN^DILF
+34 QUIT
FLT ; Create a Few Public Filters as a default for sites.
+1 ; Only create new public filters if file is empty.
+2 NEW DIK
+3 IF +$PIECE(^MAG(2005.87,0),"^",3)
Begin DoDot:1
+4 DO MES^XPDUTL("The IMAGE LIST FILTERS File is not empty,")
+5 DO MES^XPDUTL(" Default Public Filters were not installed.")
+6 QUIT
End DoDot:1
QUIT
+7 SET ^MAG(2005.87,1,0)="Rad All^RAD^CLIN^^^^^^0"
+8 SET ^MAG(2005.87,1,1)="^1^.05"
+9 SET ^MAG(2005.87,2,0)="Clin All^^CLIN^^^^^^0"
+10 SET ^MAG(2005.87,2,1)="^1^.05"
+11 SET ^MAG(2005.87,3,0)="Admin All^^ADMIN^^^^^^0"
+12 SET ^MAG(2005.87,3,1)="^1^.05"
+13 SET ^MAG(2005.87,4,0)="Clin 2 yr^^CLIN^^^^^^-24"
+14 SET ^MAG(2005.87,4,1)="^1^.05"
+15 SET ^MAG(2005.87,5,0)="Admin 10-10EZ All^^ADMIN^46,^^^^^0"
+16 SET ^MAG(2005.87,5,1)="^1^.05"
+17 SET ^MAG(2005.87,6,0)="Adv Directives^^CLIN^67^^^^^0"
+18 SET ^MAG(2005.87,6,1)="^1^.05"
+19 SET ^MAG(2005.87,7,0)="All^^^^^^^^0"
+20 SET ^MAG(2005.87,7,1)="^1^.05"
+21 SET ^MAG(2005.87,8,0)="All 2 yr^^^^^^^^-24"
+22 SET ^MAG(2005.87,8,1)="^1^.05"
+23 SET ^MAG(2005.87,9,0)="All 6 mth^^^^^^^^-6"
+24 SET ^MAG(2005.87,9,1)="^1^.05"
+25 ;All Advance Directives^^CLIN^67^^^^^0
+26 SET DIK="^MAG(2005.87,"
DO IXALL^DIK
+27 DO MES^XPDUTL("Default Public Filters added to IMAGE LIST FILTERS File.")
+28 QUIT