1 | BMXRPC3 ; IHS/OIT/HMW - BMX REMOTE PROCEDURE CALLS ; 5/22/11 4:33pm
|
---|
2 | ;;4.1000;BMX;;Apr 17, 2011
|
---|
3 | ;
|
---|
4 | ; Changed for .1000 by WV/SMH on April 6 2011
|
---|
5 | ; - References to ^AUTTSITE in GETFC & GETFCRS removed, as VISTA doesn't use this file
|
---|
6 | ; -
|
---|
7 | ;
|
---|
8 | ;
|
---|
9 | ;
|
---|
10 | VARVAL(RESULT,VARIABLE) ;returns value of passed in variable
|
---|
11 | S VARIABLE=$TR(VARIABLE,"~","^")
|
---|
12 | S RESULT=VARIABLE ;can do this with the REFERENCE type parameter
|
---|
13 | Q
|
---|
14 | ;See GETV^XWBBRK for how we get the REFERENCE type parameter
|
---|
15 | ;
|
---|
16 | USER(RESULT,D) ;
|
---|
17 | ;
|
---|
18 | I '+D S RESULT="" Q
|
---|
19 | S RESULT=$P($G(^VA(200,D,0)),"^")
|
---|
20 | Q
|
---|
21 | ;
|
---|
22 | NTUSER(BMXY,BMXNTUSE) ;EP
|
---|
23 | ;Old code. Retain for reference
|
---|
24 | ;Returns NTDomain^NTUserName^RPMSName for user having DUZ=D
|
---|
25 | ;TODO: Move ANMC NT USERS file
|
---|
26 | ;from AZZWNT to BMX namespace and numberspace
|
---|
27 | ;
|
---|
28 | ;N BMX,BMXNOD,BMXDOM,BMXNAM,BMXCOL,BMXRNAM
|
---|
29 | ;S (BMXDOM,BMXNAM,BMXRNAM)=""
|
---|
30 | ;S U="^"
|
---|
31 | ;I '+D S RESULT="" Q
|
---|
32 | ;S BMXRNAM=$G(^VA(200,D,0)),BMXRNAM=$P(BMXRNAM,U)
|
---|
33 | ;I '$D(^AZZWNT("DUZ",D)) D NTU1 Q
|
---|
34 | ;S BMX=$O(^AZZWNT("DUZ",D,0))
|
---|
35 | ;I '+BMX D NTU1 Q
|
---|
36 | ;I '$D(^AZZWNT(BMX,0)) D NTU1 Q
|
---|
37 | ;S BMXNOD=^AZZWNT(BMX,0)
|
---|
38 | ;S BMXDOM=$P(BMXNOD,U,2)
|
---|
39 | ;S BMXNAM=$P(BMXNOD,U) ;,4)
|
---|
40 | ;D NTU1
|
---|
41 | Q
|
---|
42 | ;
|
---|
43 | ;
|
---|
44 | NTUGETD(BMXY,BMXNTNAM) ;EP
|
---|
45 | ;Entry point for debugging
|
---|
46 | ;
|
---|
47 | ;D DEBUG^%Serenji("NTUGETD^BMXRPC3(.BMXY,BMXNTNAM)")
|
---|
48 | Q
|
---|
49 | ;
|
---|
50 | NTUGET(BMXY,BMXNTNAM) ;EP
|
---|
51 | ;
|
---|
52 | ;Returns A ENCRYPTED and V ENCRYPTED for NT User BMXNTNM
|
---|
53 | ;Called by RPC BMXNetGetCodes
|
---|
54 | N BMXI,BMXNTID,BMXNTID,BMXNOD,BMXA,BMXV
|
---|
55 | S BMXI=0
|
---|
56 | S BMXY="^BMXTMP("_$J_")"
|
---|
57 | S X="NTUET^BMXRPC3",@^%ZOSF("TRAP")
|
---|
58 | S BMXI=BMXI+1
|
---|
59 | I BMXNTNM="" S ^BMXTMP($J,BMXI)="^" Q
|
---|
60 | S BMXNTID=$O(^BMXUSER("B",BMXNTNAM,0))
|
---|
61 | I '+BMXNTID S ^BMXTMP($J,BMXI)="^" Q
|
---|
62 | S BMXNOD=$G(^BMXUSER(BMXNTID,0))
|
---|
63 | S BMXA=$P(BMXNOD,U,2)
|
---|
64 | S BMXV=$P(BMXNOD,U,3)
|
---|
65 | S ^BMXTMP($J,BMXI)=BMXA_"^"_BMXV_"^"
|
---|
66 | Q
|
---|
67 | ;
|
---|
68 | WINUGET(BMXWINID) ;EP
|
---|
69 | ;Returns DUZ for user having Windows Identity BMXWINID
|
---|
70 | ;Returns 0 if no Windows user found
|
---|
71 | ;
|
---|
72 | N BMXIEN,BMXNOD,BMXDUZ
|
---|
73 | I BMXWINID="" Q 0
|
---|
74 | S BMXIEN=$O(^BMXUSER("B",BMXWINID,0))
|
---|
75 | I '+BMXIEN Q 0
|
---|
76 | S BMXNOD=$G(^BMXUSER(BMXIEN,0))
|
---|
77 | S BMXDUZ=$P(BMXNOD,U,2)
|
---|
78 | Q BMXDUZ
|
---|
79 | ;
|
---|
80 | NTUSET(BMXY,BMXNTNAM) ;EP
|
---|
81 | ;Sets NEW PERSON map entry for Windows Identity BMXNTNM
|
---|
82 | ;Returns ERRORID 0 if all ok
|
---|
83 | ;Called by RPC BMXNetSetUser
|
---|
84 | ;
|
---|
85 | ;
|
---|
86 | N BMXI,BMXNTID,BMXFDA,BMXF,BMXIEN,BMXMSG,BMXAPPTD
|
---|
87 | S BMXI=0
|
---|
88 | S BMXY="^BMXTMP("_$J_")"
|
---|
89 | S X="NTUET^BMXRPC3",@^%ZOSF("TRAP")
|
---|
90 | S BMXI=BMXI+1
|
---|
91 | ; Quit with error if no DUZ exists
|
---|
92 | I '+$G(DUZ) D NTUERR(BMXI,500) Q
|
---|
93 | ; Create entry or file in existing entry in BMX USER
|
---|
94 | I $D(^BMXUSER("B",BMXNTNAM)) S BMXF="?1,"
|
---|
95 | E S BMXF="+1,"
|
---|
96 | S BMXFDA(90093.1,BMXF,.01)=BMXNTNAM
|
---|
97 | S BMXFDA(90093.1,BMXF,.02)=$G(DUZ)
|
---|
98 | K BMXIEN,BMXMSG
|
---|
99 | D UPDATE^DIE("","BMXFDA","BMXIEN","BMXMSG")
|
---|
100 | S BMXAPPTD=+$G(BMXIEN(1))
|
---|
101 | S BMXI=BMXI+1
|
---|
102 | S ^BMXTMP($J,BMXI)=BMXAPPTD_"^0"
|
---|
103 | Q
|
---|
104 | ;
|
---|
105 | NTUET ;EP
|
---|
106 | ;Error trap from REGEVNT
|
---|
107 | ;
|
---|
108 | I '$D(BMXI) N BMXI S BMXI=999
|
---|
109 | S BMXI=BMXI+1
|
---|
110 | D NTUERR(BMXI,99)
|
---|
111 | Q
|
---|
112 | ;
|
---|
113 | NTUERR(BMXI,BMXERID) ;Error processing
|
---|
114 | S BMXI=BMXI+1
|
---|
115 | S ^BMXTMP($J,BMXI)="^"_BMXERID
|
---|
116 | Q
|
---|
117 | ;
|
---|
118 | ;
|
---|
119 | NTU1 ;S BMXCOL="T00030NT_DOMAIN^T00030NT_USERNAME^T00030RPMS_USERNAME"_$C(30)
|
---|
120 | ;S RESULT=BMXCOL_BMXDOM_U_BMXNAM_U_BMXRNAM_$C(30)_$C(31)
|
---|
121 | Q
|
---|
122 | ;
|
---|
123 | GETFC(BMXFACS,DUZ) ;Gets all facilities for a user -- *1000 - Changes to support VISTA
|
---|
124 | ; Input DUZ - user IEN from the NEW PERSON FILE
|
---|
125 | ; Output - Number of facilities;facility1 name&facility1 IEN;...facilityN&facilityN IEN
|
---|
126 | N BMXFN,BMXN
|
---|
127 | S BMXFN=0,BMXFACS=""
|
---|
128 | F BMXN=1:1 S BMXFN=$O(^VA(200,DUZ,2,BMXFN)) Q:BMXFN="" D
|
---|
129 | . S:BMXN>1 BMXFACS=BMXFACS_";" S BMXFACS=BMXFACS_$P(^DIC(4,BMXFN,0),U,1)_"&"_BMXFN
|
---|
130 | ;//smh I BMXN=1 S BMXFN=$P(^AUTTSITE(1,0),U,1) D
|
---|
131 | ;//smh . S BMXFACS=BMXFACS_$P(^DIC(4,BMXFN,0),U,1)_"&"_BMXFN
|
---|
132 | S BMXFACS=BMXN-(BMXN>1)_";"_BMXFACS
|
---|
133 | Q
|
---|
134 | ;
|
---|
135 | GETFCRS(BMXFACS,BMXDUZ) ;Gets all facilities for a user - returns RECORDSET -- *1000 - Changes to support VISTA
|
---|
136 | ;
|
---|
137 | ;TODO: return as global array, add error checking
|
---|
138 | N BMXFN,BMXN,BMXSUB,BMXRCNT
|
---|
139 | S BMXDUZ=$TR(BMXDUZ,$C(13),"")
|
---|
140 | S BMXDUZ=$TR(BMXDUZ,$C(10),"")
|
---|
141 | S BMXDUZ=$TR(BMXDUZ,$C(9),"")
|
---|
142 | S BMXFN=0
|
---|
143 | S BMXSUB="^VA(200,"_BMXDUZ_",2,"
|
---|
144 | S BMXFACS="T00030FACILITY_NAME^T00030FACILITY_IEN^T00002MOST_RECENT_LOOKUP"_$C(30)
|
---|
145 | F BMXN=1:1 S BMXFN=$O(^VA(200,BMXDUZ,2,BMXFN)) Q:'BMXFN D ;IHS/ANMC/LJF 8/9/01
|
---|
146 | . S BMXFACS=BMXFACS_$P(^DIC(4,BMXFN,0),U,1)_"^"_BMXFN
|
---|
147 | . ; S BMXRCNT=BMXRCNT+1 ;cmi/maw mod ; /smh WRONG WRONG WRONG WRONG. MOST RECENT LOOKUP is 1 or 0, not an increment
|
---|
148 | . N BMXSUB S BMXSUB="^VA(200,"_DUZ_",2," ; ^DISV subscript
|
---|
149 | . N BMXLAST S BMXLAST=(^DISV(DUZ,BMXSUB)=BMXFN) ; 1 or 0 if division is the same as the one in the subscript
|
---|
150 | . S BMXFACS=BMXFACS_"^"_BMXLAST_$C(30) ; append that and add eor
|
---|
151 | ; IF RPMS, RUN THESE
|
---|
152 | ;//smh I BMXN=1 S BMXFN=$P(^AUTTSITE(1,0),U,1) D ; rpms only!
|
---|
153 | ;//smh . S BMXFACS=BMXFACS_$P(^DIC(4,BMXFN,0),U,1)_"^"_BMXFN_"^"_1_$C(30) ; rpms only!
|
---|
154 | ; ELSE IF VISTA, RUN THESE
|
---|
155 | ; VISTA Only: If we have no results, use kernel's DUZ(2) set during sign-on
|
---|
156 | ; Equivalent to the RPMS lines above...
|
---|
157 | I BMXN=1 S BMXFACS=BMXFACS_$P(^DIC(4,DUZ(2),0),U,1)_U_DUZ(2)_U_1_$C(30)
|
---|
158 | S BMXFACS=BMXFACS_$C(31)
|
---|
159 | Q
|
---|
160 | ;
|
---|
161 | SETFCRS(BMXY,BMXFAC) ;
|
---|
162 | ;
|
---|
163 | ;Sets DUZ(2) to value in BMXFAC
|
---|
164 | ;Fails if BMXFAC is not one of the current user's divisions
|
---|
165 | ;Returns Recordset
|
---|
166 | ;
|
---|
167 | S X="ERFC^BMXRPC3",@^%ZOSF("TRAP")
|
---|
168 | S BMXY="T00030DUZ^T00030FACILITY_IEN^T00030FACILITY_NAME"_$C(30)
|
---|
169 | N BMXSUB,BMXFACN
|
---|
170 | I '+DUZ S BMXY=BMXY_0_"^"_0_"^"_0_$C(30)_$C(31) Q
|
---|
171 | I '+BMXFAC S BMXY=BMXY_DUZ_"^"_0_"^"_0_$C(30)_$C(31) Q
|
---|
172 | ;I '$D(^VA(200,DUZ,2,+BMXFAC,0)) S BMXY=BMXY_DUZ_"^"_0_"^"_0_$C(30)_$C(31) Q ; GIS/OIT Feb 9, 2010
|
---|
173 | S DUZ(2)=BMXFAC ;IHS/OIT/HMW SAC Exemption Applied For
|
---|
174 | S BMXFACN=$G(^DIC(4,+DUZ(2),0))
|
---|
175 | S BMXFACN=$P(BMXFACN,"^")
|
---|
176 | S BMXSUB="^VA(200,"_DUZ_",2,"
|
---|
177 | S ^DISV(DUZ,BMXSUB)=BMXFAC
|
---|
178 | S BMXY=BMXY_DUZ_"^"_BMXFAC_"^"_BMXFACN_$C(30)_$C(31)
|
---|
179 | Q
|
---|
180 | ;
|
---|
181 | ERFC ;
|
---|
182 | D ^%ZTER
|
---|
183 | S BMXY=$G(BMXY)_0_"^"_0_$C(30)_$C(31) Q
|
---|
184 | Q
|
---|
185 | ;
|
---|
186 | SETFC(BMXY,BMXFAC) ;
|
---|
187 | ;Sets DUZ(2) to value in BMXFAC
|
---|
188 | ;Fails if BMXFAC is not one of the current user's divisions
|
---|
189 | ;Returns 1 if successful, 0 if failed
|
---|
190 | ;
|
---|
191 | S BMXY=0
|
---|
192 | N BMXSUB
|
---|
193 | I '+DUZ S BMXY=0 Q
|
---|
194 | I '+BMXFAC S BMXY=0 Q
|
---|
195 | I '$D(^VA(200,DUZ,2,+BMXFAC,0)) S BMXY=0 Q
|
---|
196 | S DUZ(2)=BMXFAC ;IHS/OIT/HMW SAC Exemption Applied For
|
---|
197 | S BMXSUB="^VA(200,"_DUZ_",2,"
|
---|
198 | S ^DISV(DUZ,BMXSUB)=BMXFAC
|
---|
199 | S BMXY=1
|
---|
200 | Q
|
---|
201 | ;
|
---|
202 | APSEC(BMXY,BMXKEY) ;EP
|
---|
203 | ;Return IHSCD_SUCCEEDED (-1) if user has key BMXKEY
|
---|
204 | ;OR if user has key XUPROGMODE
|
---|
205 | ;Otherwise, returns IHSCD_FAILED (0)
|
---|
206 | N BMXIEN,BMXPROG,BMXPKEY
|
---|
207 | I '$G(DUZ) S BMXY=0 Q
|
---|
208 | I BMXKEY="" S BMXY=0 Q
|
---|
209 | ;
|
---|
210 | ;Test for programmer mode key
|
---|
211 | S BMXPROG=0
|
---|
212 | I $D(^DIC(19.1,"B","XUPROGMODE")) D
|
---|
213 | . S BMXPKEY=$O(^DIC(19.1,"B","XUPROGMODE",0))
|
---|
214 | . I '+BMXPKEY Q
|
---|
215 | . I '$D(^VA(200,DUZ,51,BMXPKEY,0)) Q
|
---|
216 | . S BMXPROG=1
|
---|
217 | I BMXPROG S BMXY=-1 Q
|
---|
218 | ;
|
---|
219 | I '$D(^DIC(19.1,"B",BMXKEY)) S BMXY=0 Q
|
---|
220 | S BMXIEN=$O(^DIC(19.1,"B",BMXKEY,0))
|
---|
221 | I '+BMXIEN S BMXY=0 Q
|
---|
222 | I '$D(^VA(200,DUZ,51,BMXIEN,0)) S BMXY=0 Q
|
---|
223 | S BMXY=-1
|
---|
224 | Q
|
---|
225 | ;
|
---|
226 | SIGCHK(BMXY,BMXSIG) ;EP
|
---|
227 | ;Checks BMXSIG against hashed value in NEW PERSON
|
---|
228 | ;Return IHSCD_SUCCEEDED (-1) if BMXSIG matches
|
---|
229 | ;Otherwise, returns IHSCD_FAILED (0)
|
---|
230 | N X
|
---|
231 | S BMXY=0
|
---|
232 | I '$G(DUZ) Q
|
---|
233 | I '$D(^VA(200,DUZ,20)) Q ;TODO What if no signature?
|
---|
234 | S BMXHSH=$P(^VA(200,DUZ,20),U,4)
|
---|
235 | S X=$G(BMXSIG)
|
---|
236 | D HASH^XUSHSHP
|
---|
237 | I X=BMXHSH S BMXY=-1
|
---|
238 | Q
|
---|