2 Unix SMB/CIFS implementation.
5 Copyright (C) Volker Lendecke 2009
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "rpcclient.h"
23 #include "../librpc/gen_ndr/ndr_epmapper_c.h"
24 #include "../librpc/gen_ndr/ndr_lsa.h"
26 static NTSTATUS
cmd_epmapper_map(struct rpc_pipe_client
*p
,
28 int argc
, const char **argv
)
30 struct dcerpc_binding_handle
*b
= p
->binding_handle
;
31 struct dcerpc_binding map_binding
;
32 struct epm_twr_t map_tower
;
33 struct epm_twr_p_t towers
[500];
34 struct policy_handle entry_handle
;
35 struct ndr_syntax_id abstract_syntax
;
37 TALLOC_CTX
*tmp_ctx
= talloc_stackframe();
42 abstract_syntax
= ndr_table_lsarpc
.syntax_id
;
44 map_binding
.transport
= NCACN_NP
;
45 map_binding
.object
= abstract_syntax
;
46 map_binding
.host
= "127.0.0.1"; /* needed? */
47 map_binding
.endpoint
= "0"; /* correct? needed? */
49 status
= dcerpc_binding_build_tower(tmp_ctx
, &map_binding
,
51 if (!NT_STATUS_IS_OK(status
)) {
52 d_fprintf(stderr
, "dcerpc_binding_build_tower returned %s\n",
58 ZERO_STRUCT(entry_handle
);
60 status
= dcerpc_epm_Map(
61 b
, tmp_ctx
, &abstract_syntax
.uuid
,
62 &map_tower
, &entry_handle
, ARRAY_SIZE(towers
),
63 &num_towers
, towers
, &result
);
64 if (!NT_STATUS_IS_OK(status
)) {
65 d_fprintf(stderr
, "dcerpc_epm_Map returned %s\n",
70 if (result
!= EPMAPPER_STATUS_OK
) {
71 d_fprintf(stderr
, "epm_Map returned %u (0x%08X)\n",
73 return NT_STATUS_UNSUCCESSFUL
;
76 d_printf("num_tower[%u]\n", num_towers
);
78 for (i
=0; i
< num_towers
; i
++) {
79 struct dcerpc_binding
*binding
;
81 if (towers
[i
].twr
== NULL
) {
82 d_fprintf(stderr
, "tower[%u] NULL\n", i
);
86 status
= dcerpc_binding_from_tower(tmp_ctx
, &towers
[i
].twr
->tower
,
88 if (!NT_STATUS_IS_OK(status
)) {
92 d_printf("tower[%u] %s\n", i
, dcerpc_binding_string(tmp_ctx
, binding
));
98 static NTSTATUS
cmd_epmapper_lookup(struct rpc_pipe_client
*p
,
100 int argc
, const char **argv
)
102 struct dcerpc_binding_handle
*b
= p
->binding_handle
;
103 struct policy_handle entry_handle
;
105 ZERO_STRUCT(entry_handle
);
108 TALLOC_CTX
*tmp_ctx
= talloc_new(mem_ctx
);
109 uint32_t num_entries
;
110 struct epm_entry_t entry
;
113 struct dcerpc_binding
*binding
;
116 status
= dcerpc_epm_Lookup(b
, tmp_ctx
,
117 0, /* rpc_c_ep_all */
120 0, /* rpc_c_vers_all */
123 &num_entries
, &entry
,
125 if (!NT_STATUS_IS_OK(status
)) {
126 d_fprintf(stderr
, "dcerpc_epm_Lookup returned %s\n",
131 if (result
== EPMAPPER_STATUS_NO_MORE_ENTRIES
) {
132 d_fprintf(stderr
, "epm_Lookup no more entries\n");
136 if (result
!= EPMAPPER_STATUS_OK
) {
137 d_fprintf(stderr
, "epm_Lookup returned %u (0x%08X)\n",
142 if (num_entries
!= 1) {
143 d_fprintf(stderr
, "epm_Lookup returned %d "
144 "entries, expected one\n", (int)num_entries
);
148 guid_string
= GUID_string(tmp_ctx
, &entry
.object
);
149 if (guid_string
== NULL
) {
153 status
= dcerpc_binding_from_tower(tmp_ctx
, &entry
.tower
->tower
,
155 if (!NT_STATUS_IS_OK(status
)) {
159 d_printf("%s %s: %s\n", guid_string
,
160 dcerpc_binding_string(tmp_ctx
, binding
),
163 TALLOC_FREE(tmp_ctx
);
170 /* List of commands exported by this module */
172 struct cmd_set epmapper_commands
[] = {
176 { "epmmap", RPC_RTYPE_NTSTATUS
, cmd_epmapper_map
, NULL
,
177 &ndr_table_epmapper
, NULL
, "Map a binding", "" },
178 { "epmlookup", RPC_RTYPE_NTSTATUS
, cmd_epmapper_lookup
, NULL
,
179 &ndr_table_epmapper
, NULL
, "Lookup bindings", "" },