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

XUSTERM.m

Go to the documentation of this file.
  1. XUSTERM ;SEA/AMF/WDE - DEACTIVATE USER ;10/01/18
  1. ;;8.0;KERNEL;**36,73,135,148,169,222,313,384,489,527,588,645,693**;Jul 10, 1995;Build 13
  1. ;;"Per VHA Directive 2004-038, this routine should not be modified".
  1. LKUP N DIRUT,DIC,DIR,XUDA,DA
  1. S DIC=200,DIC("S")="I $L($P(^(0),U,3))",DIC(0)="AEQMZ",DIC("A")="Select USER to be deactivated: "
  1. D ^DIC K DIC G END:Y<0 S XUDA=+Y
  1. D INQ Q:$D(DIRUT)
  1. S DA=XUDA,DIE=200,DR="["_$$GET^XUPARAM("XUSERDEACT","N")_"]" D GET,XUDIE^XUS5
  1. S XUDT=$P(^VA(200,DA,0),U,11),XUACT=XUDT&(XUDT>DT) G END:'XUDT
  1. G:XUACT WHEN G NOW
  1. ;
  1. WHEN W !!,XUNAM," will be deactivated on date specified."
  1. S ZTDTH=XUDT,ZTRTN="DQ1^XUSTERM1",ZTDESC="DEACTIVATE USER",ZTSAVE("XUDA")="",ZTIO="" D ^%ZTLOAD
  1. G END
  1. ;
  1. NOW S DIR("A")=XUNAM_" will be deactivated now. Do you wish to proceed",DIR("B")="YES",DIR("??")="XUUSER-DEACT",DIR(0)="Y"
  1. D ^DIR I "Yy"'[$E(X_U) S XUDT=$$NOW^XLFDT G WHEN
  1. W ! S XUVE=1 D ACT
  1. G END
  1. ;
  1. INQ ;Ask to show User Inquiry
  1. N DIR,DIC,FLDS,BY,FR,TO,Y,L
  1. S DIR(0)="Y",DIR("A")="View/Print User Inquiry Data",DIR("B")="Yes" D ^DIR Q:$D(DIRUT)!('Y)
  1. S L=0,DIC=200,FLDS="[XUSERINQ]",BY="NUMBER",(TO,FR)=XUDA D EN1^DIP K DIC
  1. K DIR S DIR(0)="E" D ^DIR
  1. Q
  1. ;
  1. GET ;XUGRP=mail group, XUKEY=keys, XUSUR=mail surrogates, XUJ=# baskets, XUK=# mail msg, XUIN=# in-basket msg
  1. ;XUTX1, XUTX2 used in edit templates
  1. K XUGRP,XUKEY,XUSUR,XUTX1,XUTX2 N %,XU10,XU11,XU20,XU21,XU30,XU31
  1. S (XU10,XU20)=0,(XU11,XU21,XU31)=""
  1. S DA=XUDA,XUNAM=$P(^VA(200,XUDA,0),U,1)
  1. F XUI=0:0 S XUI=$O(^XMB(3.8,"AB",XUDA,XUI)) Q:XUI'>0 D ;Mail groups
  1. . S XUK=$G(^XMB(3.8,XUI,0)) I XUK="" Q S:'$L($P(XUK,U,2)) $P(XUK,U,2)="PU" ;588 added $G and I XUK="" Q
  1. . S XUGRP(XUI)=$P(XUK,U,1,2)_U_$S('$D(^XMB(3.8,XUI,3)):0,1:^(3)=XUDA)
  1. . S XU10=XU10+1 S:$L(XU11)<70 XU11=XU11_","_$P(XUK,U)
  1. F XUI=0:0 S XUI=$O(^VA(200,XUDA,51,XUI)) Q:XUI'>0 D ;Get keys
  1. . S %=$G(^DIC(19.1,XUI,0)),XU20=XU20+1
  1. . S:$L(XU21)<70 XU21=XU21_","_$P(%,U)
  1. . Q:$P(%,U,4)="y" ;Don't count keep at terminate keys
  1. . S XUKEY(XUI)=""
  1. F XUI=0:0 S XUI=$O(^XMB(3.7,"AB",XUDA,XUI)) Q:XUI'>0 D
  1. . S XUSUR(XUI)="" S:$L(XU31)<70 XU31=XU31_","_$P(^VA(200,XUI,0),U)
  1. S (XUJ,XUK,XUIN,XUNUM)=0
  1. F I=.9:0 S I=$O(^XMB(3.7,XUDA,2,I)) Q:I'>0 D
  1. . S XUJ=XUJ+1,XUNUM=$P($G(^XMB(3.7,XUDA,2,I,1,0)),U,4)
  1. . S:XUNUM>0 XUK=XUK+XUNUM S:I=1 XUIN=XUNUM
  1. . Q
  1. S XUTX1(1)="User has "_XUK_" messages in "_XUJ_" baskets, Member of "_XU10_" Mail Groups."
  1. S:XU10 XUTX1(2)="Mail Groups: "_$E(XU11,2,80) S:$L(XU31) XUTX1(3)="Surrogate for: "_$E(XU31,2,80)
  1. S XUTX2(1)="User has "_XU20_" keys" S:XU20 XUTX2(2)=$E(XU21,2,80)
  1. S XUEMP='($D(XUSUR)!$D(XUKEY)!$D(XUGRP)!XUJ!XUK!XUIN!$L($P(^VA(200,XUDA,0),U,3)))
  1. Q
  1. ACT ;First let others clean-up, Then do our part.
  1. ;D ^XUSTERM2 ;Cleanup by other packages.
  1. N DIC,DA,DIE,DR
  1. L +^VA(200,XUDA,0):6
  1. ;Delete Verify code, prevents user from logging on p645
  1. ;need Access code for XUSTERM1 to find terminated users
  1. N XUSVC S XUSVC=$$GET1^DIQ(200,XUDA,11) ;p693 prevent the Bulletin fires for users had already been deactivated
  1. S DIE=200,DA=XUDA,DR="11///@" D ^DIE
  1. ;send a bullentin to ISO SECURITY mail group, p693
  1. I $L(XUSVC)>0 D SEND^XUSTERM1
  1. ;check Purge flag, quit if no p645
  1. I '$$GET^XPAR("SYS","XU645",1,"Q") L -^VA(200,XUDA,0) Q
  1. ;Delete other fields
  1. ;Access code;Verify Code;PAC;Last signon;SMD delegate;electronic signature,Primary menu,Hinq Employee #
  1. S DIE=200,DA=XUDA,DR="2///@;11///@;14///@;1.1///@;19///@;19.2///@;20.4///@;201///@;14.9///@" D ^DIE
  1. L -^VA(200,XUDA,0)
  1. D DEQUE^XUSERP(XUDA,3) ;Cleanup by other packages.
  1. ;
  1. K DIC S DA=XUDA,XUJ=^VA(200,XUDA,0),XUNAM=$P(XUJ,U,1),XUACT(19)=$S($D(^VA(200,XUDA,19)):^(19),1:"") F XUI=5,6,10 S XUACT(XUI)=$P(XUJ,U,XUI)
  1. ACT1 K ^DISV(XUDA) ; WARNING: This only gets ^DISV entries on current CPU
  1. ;keys
  1. I XUACT(6)'="n" F XUI=0:0 S XUI=$O(^VA(200,XUDA,51,XUI)) Q:XUI'>0 I $P($G(^DIC(19.1,XUI,0)),U,4)'="y" S DA=XUI,DA(1)=XUDA,DIK="^VA(200,XUDA,51," D ^DIK W:XUVE "..."
  1. ;delegated keys
  1. I XUACT(6)'="n" F XUI=0:0 S XUI=$O(^VA(200,XUDA,52,XUI)) Q:XUI'>0 S DA=XUI,DA(1)=XUDA,DIK="^VA(200,XUDA,52," D ^DIK W:XUVE "..."
  1. ;Delegated options
  1. S DIK="^VA(200,XUDA,19.5,",DA(1)=XUDA F XUI=0:0 S XUI=$O(^VA(200,XUDA,19.5,XUI)) Q:XUI'>0 S DA=XUI D ^DIK
  1. ;Menu templates
  1. S DIK="^VA(200,XUDA,19.8,",DA(1)=XUDA F XUI=0:0 S XUI=$O(^VA(200,XUDA,19.8,XUI)) Q:XUI'>0 S DA=XUI D ^DIK
  1. ;Secondary Menus
  1. S DIK="^VA(200,XUDA,203,",DA(1)=XUDA F XUI=0:0 S XUI=$O(^VA(200,XUDA,203,XUI)) Q:XUI'>0 S DA=XUI D ^DIK
  1. S DA=0,DA(1)=XUDA D D2^XUFILE1 ;Remove all access to files.
  1. ;Terminate Person Class
  1. D TERM^XUA4A72(XUDA,XUDT)
  1. ;Remove all parameters for the user.
  1. D DELUSR^XPAR3(XUDA)
  1. ;
  1. ACT2 ;XUACT(5) All Mail access, Mail groups
  1. D MAIL
  1. W:XUVE "... DONE"
  1. Q
  1. ;
  1. END K C,D,D0,DI,DR,DIC,DIE,DA,DIR,XUEMP,XUDA,XUI,XUJ,XUK,XUACT,XUKEY,XUGRP,XUSUR,XUNAM,XUF,XUDT,XUIN,DIC,XUDB,XUDC,XUDP,XUGP,XUNUM,XUVE,Y
  1. K XUTX1,XUTX2,DIRUT,DIR
  1. Q
  1. MAIL ;Remove mail access
  1. I XUACT(5)'="n" D TERMINAT^XMUTERM1(XUDA)
  1. Q