1 | XUSTERM1 ;SEA/WDE - DEACTIVATE USER ;6:40 AM 11 Oct 2006
|
---|
2 | ;;8.0;KERNEL;**102,180,208,222,274,313,332,360,384,436**;Jul 10, 1995;Build 2
|
---|
3 | ENALL ;Interactive scan all
|
---|
4 | S U="^",DTIME=$G(DTIME,60)
|
---|
5 | W !!,"This option can purge all access & verify codes, mail baskets, messages,",!,"authorized senders access, keys, and electronic signature codes of users who have been terminated."
|
---|
6 | RD1 W !!,"Do you wish to proceed "
|
---|
7 | S %=2 D YN^DICN G:%=2!(%=-1) END I %=0 S XQH="XUUSER-PURGEATT" D EN^XQH G RD1
|
---|
8 | RD2 W !,"Do you wish to verify each user "
|
---|
9 | S %=2,XUVE=0 D YN^DICN S:%=1 XUVE=1 G:%=1 CHECK G:%=-1 END I %=0 S XQH="XUUSER-PURGEATT-VER" D EN^XQH G RD2
|
---|
10 | QUE W !,"Do you wish to have this queued for a later time "
|
---|
11 | S %=1 D YN^DICN I %=1 D Q
|
---|
12 | . S ZTDESC="USER DEACTIVATION",ZTRTN="CHECK^XUSTERM1",ZTIO="",ZTSAVE("DUZ*")=""
|
---|
13 | . D ^%ZTLOAD
|
---|
14 | . Q
|
---|
15 | I %=0 K X,XUVE Q
|
---|
16 | ;Fall thru if user doesn't queue
|
---|
17 | CHECK ;Entry point for taskman.
|
---|
18 | N XUDT540,XUDT90,XUDT30,FDA,XUDT
|
---|
19 | S U="^",DT=$$DT^XLFDT(),XUDT90=$$HTFM^XLFDT($H-90,1),XUDT30=$$HTFM^XLFDT($H-30,1)
|
---|
20 | S XUDT540=$$HTFM^XLFDT($H-540,1) ;*p332
|
---|
21 | S XUDA=.6,XUVE=$G(XUVE,0)
|
---|
22 | F S XUDA=$O(^VA(200,XUDA)) Q:XUDA'>0 S XUJ=$G(^(XUDA,0)) D
|
---|
23 | . S XUDT=$P(XUJ,U,11)
|
---|
24 | . I $P(XUJ,U,3)]"",$L(XUDT),(XUDT'>DT) D
|
---|
25 | . . D GET
|
---|
26 | . . I 'XUEMP K Y D:XUVE DISP Q:$D(Y) D ACT ;XUEMP=any data to remove
|
---|
27 | . . Q
|
---|
28 | . I $P(XUJ,U,3)]"",'$P(XUJ,U,8),$$NOSIGNON D DISUSER(XUDA)
|
---|
29 | . I $P(XUJ,U,7) D AUSER(XUDA) ;*p332
|
---|
30 | . Q
|
---|
31 | ;
|
---|
32 | END K XUEMP,XUDA,XUI,XUJ,XUK,XUACT,XUKEY,XUGRP,XUSUR,XUNAM,XUF,XUDT,XUIN,XUVE,X,DIC,XUDB,XUDC,XUDP
|
---|
33 | Q
|
---|
34 | ;
|
---|
35 | DISUSER(XUDA) ;Set DISUSER flag and reason, Remove last menu option
|
---|
36 | Q:$P(XUJ,U,7) ;DISUSER already set *p332
|
---|
37 | N %,FDA S %=XUDA_","
|
---|
38 | S FDA(200,%,7)=1,FDA(200,%,9.4)="User Inactive for too long"
|
---|
39 | D FILE^DIE("","FDA"),CONTCL(XUDA) ;Set Disuser
|
---|
40 | Q
|
---|
41 | ;
|
---|
42 | AUSER(XUDA) ;If DISUSERed and Last Sign > 540[18Mo.*30] days, then remove"AUSER" xref
|
---|
43 | I $D(^XUSEC("XUORES",XUDA)) Q ;Owner of XUORES key ;p*436
|
---|
44 | N Q S Q=$P($G(^VA(200,XUDA,1.1)),U) ;Get last sign-on
|
---|
45 | I $L(Q),Q<XUDT540 K ^VA(200,"AUSER",$P(XUJ,U),XUDA) ;*p360;*p384
|
---|
46 | Q
|
---|
47 | ;
|
---|
48 | NOSIGNON() ;Check last signon. Return 1 if should disable account
|
---|
49 | N Q S Q=$P($G(^VA(200,XUDA,1.1)),U) ;Get last sign-on
|
---|
50 | I $L(Q),Q>XUDT90 Q 0 ;Last sign-on within 90 days
|
---|
51 | S Q=$P($G(^VA(200,XUDA,1.1)),U,4) ;Get last Edit date
|
---|
52 | I $L(Q),Q>XUDT30 Q 0 ;User edited in last 30 days
|
---|
53 | S Q=$P($G(^VA(200,XUDA,1)),U,7) ;Create Date
|
---|
54 | I $L(Q),Q>XUDT30 Q 0 ;User set up in last 30 days
|
---|
55 | S Q=$P($G(^VA(200,XUDA,.1)),U) ;Get verify code change date
|
---|
56 | I $L(Q),(Q+30)>$H Q 0 ;Verify code changed in last 30 days
|
---|
57 | Q 1
|
---|
58 | ;
|
---|
59 | CONTCL(XUDA) ;Clear the fields for Menu "Continue"
|
---|
60 | N FDA
|
---|
61 | S FDA(200,XUDA_",",202.1)="@",FDA(200,XUDA_",",202.2)="@"
|
---|
62 | D FILE^DIE("","FDA") ;Clear 202.1 and 202.2
|
---|
63 | Q
|
---|
64 | ;
|
---|
65 | ACT ;
|
---|
66 | D ACT^XUSTERM
|
---|
67 | S XUJ=^VA(200,XUDA,0) ;Get new copy of zero node
|
---|
68 | Q
|
---|
69 | ;
|
---|
70 | GET ;Kill ^DISV entries each time, should get all CPUs at some point
|
---|
71 | N XUJ
|
---|
72 | D GET^XUSTERM K ^DISV(XUDA),Y
|
---|
73 | Q
|
---|
74 | DISP ;Display info and get responses.
|
---|
75 | N DA,DIE,DR,XUJ
|
---|
76 | S DA=XUDA
|
---|
77 | L +^VA(200,DA,0):6 D DISP2 L -^VA(200,DA,0)
|
---|
78 | Q
|
---|
79 | DISP2 ;Do the work.
|
---|
80 | W !!,$S(XUTX1(1)["User":XUNAM_$P(XUTX1(1),"User",2),1:XUTX1(1)) ;*p360
|
---|
81 | S DR="9.21//YES",DIE=200 D ^DIE Q:$D(Y) G:'$D(XUSUR) KEYS
|
---|
82 | W !!,XUNAM," acts as surrogate for the following users:"
|
---|
83 | S XUJ=0,XUI=3 F XUK=0:1 S XUJ=$O(XUSUR(XUJ)) Q:XUJ'>0 W:'(XUK#XUI) ! W ?(XUK#XUI*26),$P(^VA(200,XUJ,0),U,1) W !,"These surrogate privileges will be deleted on deactivation."
|
---|
84 | KEYS ;This section checks for authorized senders of mail groups and security keys.
|
---|
85 | W !,"User will no longer be an authorized sender to any mail groups."
|
---|
86 | I '$D(XUKEY) W !!,XUNAM," currently holds no keys." G KEYS1
|
---|
87 | W !!,XUNAM," holds the following keys: "
|
---|
88 | S XUJ=0,XUI=5 F XUK=0:1 S XUJ=$O(XUKEY(XUJ)) Q:XUJ'>0 W:'(XUK#XUI) ! W ?(XUK#XUI*15),$P($G(^DIC(19.1,XUJ,0)),U,1)
|
---|
89 | KEYS1 W ! S DR="9.22//YES" D ^DIE Q:$D(Y)
|
---|
90 | GROUP I '$D(XUGRP) W !!,XUNAM," currently is not a member of any MAIL GROUP." G GROUP1
|
---|
91 | W !!,XUNAM," is a member of the following Mail Groups:"
|
---|
92 | S XUI="" F XUI=0:0 S XUI=$O(XUGRP(XUI)) Q:XUI'>0 D
|
---|
93 | . S XUJ=XUGRP(XUI)
|
---|
94 | . I $P(XUJ,U,2)="PU"!$D(^XMB(3.8,"AB",XUDA,XUI)) W !?2,$P(XUJ,U,1) W:$P(XUJ,U,3) " (Organizer)" W ?40,$S(($P(XUJ,U,2)="PR"):"(Private)",1:"(Public)")
|
---|
95 | . Q
|
---|
96 | GROUP1 W ! S DR="9.23//YES" D ^DIE Q:$D(Y)
|
---|
97 | Q
|
---|
98 | ;
|
---|
99 | DQ1 ;Terminate one person.
|
---|
100 | N XUJ,XUDT,XUVE
|
---|
101 | S XUJ=$G(^VA(200,XUDA,0)),XUDT=$P(XUJ,U,11) I XUDT,(XUDT'>DT) D
|
---|
102 | . S XUVE=0 D GET I 'XUEMP D ACT
|
---|
103 | . Q
|
---|
104 | Q
|
---|
105 | ;
|
---|
106 | SEND ; send deactivated message to assigned mail group
|
---|
107 | K XMB,XMY
|
---|
108 | S XMB(1)=$P(XUJ,"^",1)
|
---|
109 | S XMB(2)=$$GET1^DIQ(200,XUDA,8)
|
---|
110 | S XMB(3)=$$GET1^DIQ(200,XUDA,29)
|
---|
111 | S XMB(4)=$$FMTE^XLFDT(XUDT)
|
---|
112 | S XMB="XUSERDEAC" D ^XMB:$D(^XMB(3.6,"B",XMB))
|
---|
113 | K XMB
|
---|
114 | Q
|
---|