1 | PRCPAODI ;WOIFO/CC-enter/edit On-Demand users ; 2/8/07 4:15pm
|
---|
2 | ;;5.1;IFCAP;**98**;Oct 20, 2000;Build 37
|
---|
3 | ;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | Q
|
---|
5 | ;
|
---|
6 | ENT ;
|
---|
7 | I '$$KEY^PRCPUREP("PRCPODI",DUZ) D EN^DDIOL("You are not authorized to make managers On-Demand Users.") Q
|
---|
8 | ;
|
---|
9 | N %,D,DIC,PRCF,PRCP,PRCPIN,PRCPINPT,PRCPMAN,PRCPNAME,X,Y
|
---|
10 | ;
|
---|
11 | ; Prompt for user
|
---|
12 | USER S DIC="^VA(200,",DIC(0)="AEQMOZ",DIC("A")="INVENTORY POINT MANAGER: ",D="B"
|
---|
13 | D IX^DIC
|
---|
14 | K DIC,D I Y<0 Q
|
---|
15 | S PRCPMAN=+Y
|
---|
16 | L +^PRCPAODI(PRCPMAN):0 I $T=0 D EN^DDIOL(">>File in Use. Please try again later.") W ! G USER
|
---|
17 | ;
|
---|
18 | ; Verify user is active
|
---|
19 | S X=$$GET1^DIQ(200,PRCPMAN_",","9.2","I") ; termination date
|
---|
20 | I X,X'>DT D EN^DDIOL(">>This user has been terminated and cannot be selected.") W ! D EXIT G USER
|
---|
21 | ; Verify user has primary and/or secondary manager key
|
---|
22 | S PRCPMAN(1)=0,PRCPMAN(2)=0
|
---|
23 | S PRCPMAN(1)=$$KEY^PRCPUREP("PRCP MGRKEY",PRCPMAN)
|
---|
24 | S PRCPMAN(2)=$$KEY^PRCPUREP("PRCP2 MGRKEY",PRCPMAN)
|
---|
25 | I 'PRCPMAN(1),'PRCPMAN(2),'$O(^PRCP(445,"AJ",PRCPMAN,"")) D EN^DDIOL(">>User must be a manager of a Primary or Secondary Inventory Point") W ! D EXIT G USER
|
---|
26 | ;
|
---|
27 | ; Display ODI access to primary points
|
---|
28 | S PRCPNAME=$$GET1^DIQ(200,PRCPMAN_",",".01")
|
---|
29 | W ! D CHKPM
|
---|
30 | ;
|
---|
31 | ; Prompt for Site
|
---|
32 | S %=0 F I="FY","PARAM","PER","QTR","SITE" S %=1 Q
|
---|
33 | I % S PRCF("X")="S" D ^PRCFSITE I '$G(PRC("SITE")) K PRC,PRCP G EXIT
|
---|
34 | ;
|
---|
35 | ; Prompt for inventory point
|
---|
36 | IP S DIC="^PRCP(445,",DIC(0)="AEQMOZ"
|
---|
37 | S DIC("S")="I +^(0)=PRC(""SITE"")"
|
---|
38 | S DIC("A")="SELECT INVENTORY POINT: "
|
---|
39 | S D="C",PRCPPRIV=1
|
---|
40 | D IX^DIC K PRCPPRIV,D,DIC
|
---|
41 | I Y<0 G EXIT
|
---|
42 | S PRCP("I")=Y Q:'$G(PRCP("I"))
|
---|
43 | S PRCPINPT=$P(PRCP("I"),"^",2)
|
---|
44 | S PRCP("DPTYPE")=$P(^PRCP(445,+PRCP("I"),0),U,3)
|
---|
45 | I PRCP("DPTYPE")="W" D EN^DDIOL(" >>The warehouse has no On-Demand items - needs no On-Demand User.") W ! G IP
|
---|
46 | ;
|
---|
47 | D INIT(+PRCP("I"))
|
---|
48 | ;
|
---|
49 | ;Process Users that don't qualify
|
---|
50 | I 'PRCPMAN(3) D D:PRCP("DPTYPE")="P" CHKDP G IP
|
---|
51 | . D EN^DDIOL(">>"_PRCPNAME_" is not a "_PRCPMAN(3)_" of this inventory point")
|
---|
52 | . ; if user is not in node 9, give message - not added
|
---|
53 | . I 'PRCPIN D EN^DDIOL(" and therefore cannot be an On-Demand User") W !
|
---|
54 | . ; delete if user is set up in node 9 - show 'deleted'
|
---|
55 | . I PRCPIN D Q
|
---|
56 | . . D DEL(+PRCP("I"),PRCPIN) ; Delete entry
|
---|
57 | . . D EN^DDIOL(">>Removed as On-Demand User for: "_PRCPINPT) W !
|
---|
58 | ;
|
---|
59 | ; If user is already On-Demand, ask if they should be removed???
|
---|
60 | I PRCPIN D G IP
|
---|
61 | . D ASK(2,+PRCP("I"),PRCPMAN)
|
---|
62 | . I PRCP("DPTYPE")="P" D CHKDP
|
---|
63 | ;
|
---|
64 | ; Ask if user should be added to IP's list of On-Demand users
|
---|
65 | D ASK(1,+PRCP("I"),PRCPMAN)
|
---|
66 | I PRCP("DPTYPE")="P" D CHKDP
|
---|
67 | G IP
|
---|
68 | ;
|
---|
69 | Q
|
---|
70 | ;
|
---|
71 | ; Does user qualify?
|
---|
72 | INIT(PRCPINP) ;PRCPINP=inventory point being checked
|
---|
73 | S PRCPMAN(3)=1 ; assume user is OK
|
---|
74 | ; Verify user has manager key for type of IP selected
|
---|
75 | I PRCP("DPTYPE")="P",'PRCPMAN(1) S PRCPMAN(3)="manager"
|
---|
76 | I PRCP("DPTYPE")="S",'PRCPMAN(2) S PRCPMAN(3)="manager"
|
---|
77 | ; Verify user is a user of that IP
|
---|
78 | I '$D(^PRCP(445,+PRCPINP,4,PRCPMAN)) D
|
---|
79 | . I PRCPMAN(3)=1 S PRCPMAN(3)="user" Q
|
---|
80 | . S PRCPMAN(3)="manager nor user"
|
---|
81 | ;
|
---|
82 | ; set flag if user is already in list
|
---|
83 | S PRCPIN=""
|
---|
84 | S PRCPIN=$O(^PRCP(445,+PRCPINP,9,"B",PRCPMAN,PRCPIN))
|
---|
85 | Q
|
---|
86 | ;
|
---|
87 | DEL(PRCPINP,PRCPUSER) ; delete On-Demand authorization
|
---|
88 | ; also called from PRCPXTRM for user termination from VISTA
|
---|
89 | ;
|
---|
90 | ; PRCPINP inventory point from which user is being removed
|
---|
91 | ; PRCPUSER ien of user in the list
|
---|
92 | ;
|
---|
93 | N DA,DIK
|
---|
94 | S DIK="^PRCP(445,"_PRCPINP_",9,",DA(1)=+PRCPINP,DA=+PRCPUSER D ^DIK
|
---|
95 | Q
|
---|
96 | ;
|
---|
97 | ADD(PRCPINP,PRCPUSER) ; Add user to On-Demand Users
|
---|
98 | ;
|
---|
99 | ; PRCPINP
|
---|
100 | ; PRCPUSER
|
---|
101 | ;
|
---|
102 | ; save user in On-Demand Users list
|
---|
103 | N PRCPIEN,PRCPARRY,PRCPREC
|
---|
104 | S PRCPREC(1)=+PRCPMAN ; dinumed file
|
---|
105 | S PRCPIEN="+1,"_+PRCPINP_","
|
---|
106 | S PRCPARRY(445.027,PRCPIEN,.01)=+PRCPMAN
|
---|
107 | D UPDATE^DIE("","PRCPARRY","PRCPREC")
|
---|
108 | Q
|
---|
109 | ;
|
---|
110 | ; Find all distribution points
|
---|
111 | CHKDP N PRCPIN,PRCPIP,PRCPDA,PRCPDX,PRCPNM,FLAG,X
|
---|
112 | D EN^DDIOL("Checking distribution points for "_PRCPINPT_"...") W !
|
---|
113 | S PRCPIP=0,FLAG=1
|
---|
114 | S PRCP("DPTYPE")="S"
|
---|
115 | F S PRCPIP=$O(^PRCP(445,+PRCP("I"),2,PRCPIP)) Q:'+PRCPIP D
|
---|
116 | . S PRCPNM=$$INVNAME^PRCPUX1(PRCPIP),X=$P(PRCPNM,"-",2,99)
|
---|
117 | . I $E(X,1,12)="***INACTIVE_" Q ; IP not active
|
---|
118 | . I $P($G(^PRCP(445,PRCPIP,0)),"^",3)'="S" Q
|
---|
119 | . S FLAG=0 D INIT(PRCPIP)
|
---|
120 | . I 'PRCPMAN(3) D Q
|
---|
121 | . . I PRCPIN S PRCPDX(PRCPIP)=1_"^"_PRCPNM_"^"_PRCPIN Q
|
---|
122 | . S PRCPDA(PRCPIP)=1_"^"_PRCPNM_"^"_PRCPIN
|
---|
123 | ;
|
---|
124 | I FLAG=1 D EN^DDIOL("There are no distribution points on this primary") W ! Q
|
---|
125 | ;
|
---|
126 | ; check for IPs where the user is On-Demand
|
---|
127 | I $O(PRCPDA("")) D
|
---|
128 | . N PRCPD,X S PRCPD=""
|
---|
129 | . D EN^DDIOL(PRCPNAME_" is a User and Manager on the following Inventory Points:") W !
|
---|
130 | . F S PRCPD=$O(PRCPDA(PRCPD)) Q:'PRCPD D
|
---|
131 | . . S X=$P(PRCPDA(PRCPD),"^",2)
|
---|
132 | . . S X=X_$E(" ",$L(X),35)
|
---|
133 | . . S X=X_$S($P(PRCPDA(PRCPD),"^",3):"On-Demand User",1:"Not On-Demand User")
|
---|
134 | . . D EN^DDIOL(X)
|
---|
135 | . W !
|
---|
136 | ;
|
---|
137 | I $O(PRCPDX("")) D REMOVE(.PRCPDX)
|
---|
138 | ;
|
---|
139 | I '$O(PRCPDA("")),'$O(PRCPDX("")) D W !
|
---|
140 | . I PRCPMAN(2)'=1 D EN^DDIOL(PRCPNAME_" is not a manager of any distribution point") Q
|
---|
141 | . D EN^DDIOL(PRCPNAME_" is not a user of the distribution points found")
|
---|
142 | ;
|
---|
143 | ASK(PRCPOPT,PRCPIPT,PRCPUSER) ; Should user's authorization be removed?
|
---|
144 | ;
|
---|
145 | ; PRCPOPT 1 if add , 2 if delete
|
---|
146 | ; PRCPIPT Inventory Point ien
|
---|
147 | ; PRCPUSER DUZ of User
|
---|
148 | ;
|
---|
149 | N CNT,DIR,DIRUT,DIROUT,DTOUT,DUOUT,I,X,PRCPDP
|
---|
150 | S CNT=1,PRCPDP="",X=""
|
---|
151 | S DIR(0)="Y"
|
---|
152 | S DIR("A")="Add as an On-Demand User"
|
---|
153 | I PRCPOPT=2 S DIR("A")="Remove as an On-Demand User"
|
---|
154 | D ^DIR K DIR
|
---|
155 | I Y=0!$D(DTOUT)!$D(DUOUT) S X=" <<not added>>" S:PRCPOPT=2 X=" <<not removed>>" D EN^DDIOL(X) W ! Q
|
---|
156 | ; IF YES, LOOP THROUGH AND DELETE USER FROM ALL
|
---|
157 | I Y=1 D
|
---|
158 | . I PRCPOPT=2 D
|
---|
159 | . . D DEL(PRCPIPT,PRCPIN)
|
---|
160 | . . D EN^DDIOL(" <<Removed>>") W !
|
---|
161 | . I PRCPOPT=1 D
|
---|
162 | . . D ADD(PRCPIPT,PRCPUSER)
|
---|
163 | . . I $D(^TMP("DIERR",$J)) D EN^DDIOL(" <<Unable to Add - possible system problems>>") W ! Q
|
---|
164 | . . D EN^DDIOL(" <<Added>>") W !
|
---|
165 | Q
|
---|
166 | ;
|
---|
167 | REMOVE(PRCPDX) ; Auto remove ODI authorization
|
---|
168 | I $O(PRCPDX("")) D
|
---|
169 | . N PRCPD,X S PRCPD=""
|
---|
170 | . D EN^DDIOL("On-Demand Access was removed from the following:") W !
|
---|
171 | . F S PRCPD=$O(PRCPDX(PRCPD)) Q:'PRCPD D
|
---|
172 | . . D DEL(PRCPD,$P(PRCPDX(PRCPD),"^",3))
|
---|
173 | . . S X=$P(PRCPDX(PRCPD),"^",2) D EN^DDIOL(X)
|
---|
174 | . W !
|
---|
175 | Q
|
---|
176 | ;
|
---|
177 | CHKPM ; DISPLAY IPs User can access
|
---|
178 | N PRCPIN,PRCPIP,FLAG,PRCPDX,PRCPNM
|
---|
179 | S PRCPIP="",FLAG="",PRCP("DPTYPE")="P"
|
---|
180 | F S PRCPIP=$O(^PRCP(445,"AC","P",PRCPIP)) Q:'PRCPIP D
|
---|
181 | . I '$O(^PRCP(445,PRCPIP,9,"B",PRCPMAN,"")) Q
|
---|
182 | . D INIT(PRCPIP)
|
---|
183 | . S PRCPNM=$$INVNAME^PRCPUX1(PRCPIP),X=$P(PRCPNM,"-",2,99)
|
---|
184 | . I $E(X,1,12)="***INACTIVE_" Q ; IP not active
|
---|
185 | . I 'PRCPMAN(3) D Q
|
---|
186 | . . I PRCPIN S PRCPDX(PRCPIP)=1_"^"_PRCPNM_"^"_PRCPIN Q
|
---|
187 | . I 'FLAG S FLAG=1 D EN^DDIOL(PRCPNAME_" is an On-Demand User in these Primary Inventory Points:")
|
---|
188 | . D EN^DDIOL(PRCPNM)
|
---|
189 | I $O(PRCPDX("")) W ! D REMOVE(.PRCPDX)
|
---|
190 | I 'FLAG D EN^DDIOL(">>"_PRCPNAME_" is not an On-Demand User in any Primary Inventory Point")
|
---|
191 | W !
|
---|
192 | Q
|
---|
193 | ;
|
---|
194 | EXIT L -^PRCPAODI(PRCPMAN)
|
---|
195 | Q
|
---|