2 Unix SMB/CIFS implementation.
4 server side dcerpc handle code
6 Copyright (C) Andrew Tridgell 2003
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
23 #include "../lib/util/dlinklist.h"
24 #include "rpc_server/dcerpc_server.h"
25 #include "libcli/security/security.h"
26 #include "auth/session.h"
31 static int dcesrv_handle_destructor(struct dcesrv_handle
*h
)
33 DLIST_REMOVE(h
->assoc_group
->handles
, h
);
39 allocate a new rpc handle
42 struct dcesrv_handle
*dcesrv_handle_create(struct dcesrv_call_state
*call
,
45 struct dcesrv_connection_context
*context
= call
->context
;
46 struct auth_session_info
*session_info
=
47 dcesrv_call_session_info(call
);
48 struct dcesrv_handle
*h
;
52 * For simplicty, ensure we abort here for an interface that has no handles (programmer error)
54 SMB_ASSERT((context
->iface
->flags
& DCESRV_INTERFACE_FLAGS_HANDLES_NOT_USED
) == 0);
56 sid
= &session_info
->security_token
->sids
[PRIMARY_USER_SID_INDEX
];
58 h
= talloc_zero(context
->conn
->assoc_group
, struct dcesrv_handle
);
63 h
->sid
= dom_sid_dup(h
, sid
);
68 h
->assoc_group
= context
->conn
->assoc_group
;
69 h
->iface
= context
->iface
;
70 h
->wire_handle
.handle_type
= handle_type
;
71 h
->wire_handle
.uuid
= GUID_random();
73 DLIST_ADD(context
->conn
->assoc_group
->handles
, h
);
75 talloc_set_destructor(h
, dcesrv_handle_destructor
);
81 find an internal handle given a wire handle. If the wire handle is NULL then
86 struct dcesrv_handle
*dcesrv_handle_lookup(struct dcesrv_call_state
*call
,
87 const struct policy_handle
*p
,
90 struct dcesrv_connection_context
*context
= call
->context
;
91 struct auth_session_info
*session_info
=
92 dcesrv_call_session_info(call
);
93 struct dcesrv_handle
*h
;
97 * For simplicty, ensure we abort here for an interface that has no handles (programmer error)
99 SMB_ASSERT((context
->iface
->flags
& DCESRV_INTERFACE_FLAGS_HANDLES_NOT_USED
) == 0);
101 sid
= &session_info
->security_token
->sids
[PRIMARY_USER_SID_INDEX
];
103 if (ndr_policy_handle_empty(p
)) {
104 /* TODO: we should probably return a NULL handle here */
105 return dcesrv_handle_create(call
, handle_type
);
108 for (h
=context
->conn
->assoc_group
->handles
; h
; h
=h
->next
) {
109 if (h
->wire_handle
.handle_type
== p
->handle_type
&&
110 GUID_equal(&p
->uuid
, &h
->wire_handle
.uuid
)) {
111 if (handle_type
!= DCESRV_HANDLE_ANY
&&
112 p
->handle_type
!= handle_type
) {
113 DEBUG(0,("client gave us the wrong handle type (%d should be %d)\n",
114 p
->handle_type
, handle_type
));
117 if (!dom_sid_equal(h
->sid
, sid
)) {
118 DEBUG(0,(__location__
": Attempt to use invalid sid %s - %s\n",
119 dom_sid_string(context
, h
->sid
),
120 dom_sid_string(context
, sid
)));
123 if (h
->iface
!= context
->iface
) {
124 DEBUG(0,(__location__
": Attempt to use invalid iface\n"));