2 * Unix SMB/CIFS implementation.
3 * RPC Pipe client / server routines
4 * Copyright (C) Andrew Tridgell 1992-1997,
5 * Copyright (C) Luke Kenneth Casson Leighton 1996-1997,
6 * Copyright (C) Paul Ashton 1997.
7 * Copyright (C) Jeremy Allison 1999.
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
26 /****************************************************************************
27 do a server net conn enum
28 ****************************************************************************/
29 BOOL do_srv_net_srv_conn_enum(struct cli_state *cli,
30 char *server_name, char *qual_name,
31 uint32 switch_value, SRV_CONN_INFO_CTR *ctr,
37 SRV_Q_NET_CONN_ENUM q_o;
38 SRV_R_NET_CONN_ENUM r_o;
40 if (server_name == NULL || ctr == NULL || preferred_len == 0)
43 prs_init(&data, MAX_PDU_FRAG_LEN, cli->mem_ctx, MARSHALL);
44 prs_init(&rdata, 0, cli->mem_ctx, UNMARSHALL);
46 /* create and send a MSRPC command with api SRV_NETCONNENUM */
48 DEBUG(4,("SRV Net Server Connection Enum(%s, %s), level %d, enum:%8x\n",
49 server_name, qual_name, switch_value, get_enum_hnd(hnd)));
51 ctr->switch_value = switch_value;
52 ctr->ptr_conn_ctr = 1;
53 ctr->conn.info0.num_entries_read = 0;
54 ctr->conn.info0.ptr_conn_info = 1;
56 /* store the parameters */
57 init_srv_q_net_conn_enum(&q_o, server_name, qual_name,
62 /* turn parameters into data stream */
63 if(!srv_io_q_net_conn_enum("", &q_o, &data, 0)) {
69 /* send the data on \PIPE\ */
70 if(!rpc_api_pipe_req(cli, SRV_NETCONNENUM, &data, &rdata)) {
80 if(!srv_io_r_net_conn_enum("", &r_o, &rdata, 0)) {
85 if (r_o.status != 0) {
86 /* report error code */
87 DEBUG(0,("SRV_R_NET_SRV_CONN_ENUM: %s\n", get_nt_error_msg(r_o.status)));
92 if (r_o.ctr->switch_value != switch_value) {
93 /* different switch levels. oops. */
94 DEBUG(0,("SRV_R_NET_SRV_CONN_ENUM: info class %d does not match request %d\n",
95 r_o.ctr->switch_value, switch_value));
100 prs_mem_free(&rdata);
105 /****************************************************************************
106 do a server net sess enum
107 ****************************************************************************/
109 BOOL do_srv_net_srv_sess_enum(struct cli_state *cli,
110 char *server_name, char *qual_name,
111 uint32 switch_value, SRV_SESS_INFO_CTR *ctr,
112 uint32 preferred_len,
117 SRV_Q_NET_SESS_ENUM q_o;
118 SRV_R_NET_SESS_ENUM r_o;
120 if (server_name == NULL || ctr == NULL || preferred_len == 0)
123 prs_init(&data, MAX_PDU_FRAG_LEN, cli->mem_ctx, MARSHALL);
124 prs_init(&rdata, 0, cli->mem_ctx, UNMARSHALL);
126 /* create and send a MSRPC command with api SRV_NETSESSENUM */
128 DEBUG(4,("SRV Net Session Enum (%s), level %d, enum:%8x\n",
129 server_name, switch_value, get_enum_hnd(hnd)));
131 ctr->switch_value = switch_value;
132 ctr->ptr_sess_ctr = 1;
133 ctr->sess.info0.num_entries_read = 0;
134 ctr->sess.info0.ptr_sess_info = 1;
136 /* store the parameters */
137 init_srv_q_net_sess_enum(&q_o, server_name, qual_name,
142 /* turn parameters into data stream */
143 if(!srv_io_q_net_sess_enum("", &q_o, &data, 0)) {
145 prs_mem_free(&rdata);
149 /* send the data on \PIPE\ */
150 if (!rpc_api_pipe_req(cli, SRV_NETSESSENUM, &data, &rdata)) {
152 prs_mem_free(&rdata);
160 if(!srv_io_r_net_sess_enum("", &r_o, &rdata, 0)) {
161 prs_mem_free(&rdata);
165 if (r_o.status != 0) {
166 /* report error code */
167 DEBUG(0,("SRV_R_NET_SRV_SESS_ENUM: %s\n", get_nt_error_msg(r_o.status)));
168 prs_mem_free(&rdata);
172 if (r_o.ctr->switch_value != switch_value) {
173 /* different switch levels. oops. */
174 DEBUG(0,("SRV_R_NET_SRV_SESS_ENUM: info class %d does not match request %d\n",
175 r_o.ctr->switch_value, switch_value));
176 prs_mem_free(&rdata);
180 prs_mem_free(&rdata);
185 /****************************************************************************
186 do a server net share enum
187 ****************************************************************************/
188 BOOL do_srv_net_srv_share_enum(struct cli_state *cli,
190 uint32 switch_value, SRV_R_NET_SHARE_ENUM *r_o,
191 uint32 preferred_len, ENUM_HND *hnd)
195 SRV_Q_NET_SHARE_ENUM q_o;
197 if (server_name == NULL || preferred_len == 0)
200 prs_init(&data, MAX_PDU_FRAG_LEN, cli->mem_ctx, MARSHALL);
201 prs_init(&rdata, 0, cli->mem_ctx, UNMARSHALL);
203 /* create and send a MSRPC command with api SRV_NETSHAREENUM */
205 DEBUG(4,("SRV Get Share Info (%s), level %d, enum:%8x\n",
206 server_name, switch_value, get_enum_hnd(hnd)));
208 /* store the parameters */
209 init_srv_q_net_share_enum(&q_o, server_name, switch_value,
212 /* turn parameters into data stream */
213 if(!srv_io_q_net_share_enum("", &q_o, &data, 0)) {
215 prs_mem_free(&rdata);
219 /* send the data on \PIPE\ */
220 if (!rpc_api_pipe_req(cli, SRV_NETSHAREENUM, &data, &rdata)) {
222 prs_mem_free(&rdata);
228 if(!srv_io_r_net_share_enum("", r_o, &rdata, 0)) {
229 prs_mem_free(&rdata);
233 if (r_o->status != 0) {
234 /* report error code */
235 DEBUG(0,("SRV_R_NET_SHARE_ENUM: %s\n", get_nt_error_msg(r_o->status)));
236 prs_mem_free(&rdata);
240 if (r_o->ctr.switch_value != switch_value) {
241 /* different switch levels. oops. */
242 DEBUG(0,("SRV_R_NET_SHARE_ENUM: info class %d does not match request %d\n",
243 r_o->ctr.switch_value, switch_value));
244 prs_mem_free(&rdata);
248 prs_mem_free(&rdata);
253 /****************************************************************************
254 do a server net file enum
255 ****************************************************************************/
257 BOOL do_srv_net_srv_file_enum(struct cli_state *cli,
258 char *server_name, char *qual_name,
259 uint32 switch_value, SRV_FILE_INFO_CTR *ctr,
260 uint32 preferred_len,
265 SRV_Q_NET_FILE_ENUM q_o;
266 SRV_R_NET_FILE_ENUM r_o;
268 if (server_name == NULL || ctr == NULL || preferred_len == 0)
271 prs_init(&data, MAX_PDU_FRAG_LEN, cli->mem_ctx, MARSHALL);
272 prs_init(&rdata, 0, cli->mem_ctx, UNMARSHALL);
274 /* create and send a MSRPC command with api SRV_NETFILEENUM */
276 DEBUG(4,("SRV Get File Info (%s), level %d, enum:%8x\n",
277 server_name, switch_value, get_enum_hnd(hnd)));
279 q_o.file_level = switch_value;
281 ctr->switch_value = switch_value;
282 ctr->ptr_file_ctr = 1;
283 ctr->file.info3.num_entries_read = 0;
284 ctr->file.info3.ptr_file_info = 1;
286 /* store the parameters */
287 init_srv_q_net_file_enum(&q_o, server_name, qual_name,
292 /* turn parameters into data stream */
293 if(!srv_io_q_net_file_enum("", &q_o, &data, 0)) {
295 prs_mem_free(&rdata);
299 /* send the data on \PIPE\ */
300 if (!rpc_api_pipe_req(cli, SRV_NETFILEENUM, &data, &rdata)) {
302 prs_mem_free(&rdata);
310 if(!srv_io_r_net_file_enum("", &r_o, &rdata, 0)) {
311 prs_mem_free(&rdata);
315 if (r_o.status != 0) {
316 /* report error code */
317 DEBUG(0,("SRV_R_NET_FILE_ENUM: %s\n", get_nt_error_msg(r_o.status)));
318 prs_mem_free(&rdata);
322 if (r_o.ctr->switch_value != switch_value) {
323 /* different switch levels. oops. */
324 DEBUG(0,("SRV_R_NET_FILE_ENUM: info class %d does not match request %d\n",
325 r_o.ctr->switch_value, switch_value));
326 prs_mem_free(&rdata);
330 prs_mem_free(&rdata);
335 /****************************************************************************
337 ****************************************************************************/
338 BOOL do_srv_net_srv_get_info(struct cli_state *cli,
339 char *server_name, uint32 switch_value, SRV_INFO_CTR *ctr)
343 SRV_Q_NET_SRV_GET_INFO q_o;
344 SRV_R_NET_SRV_GET_INFO r_o;
346 if (server_name == NULL || switch_value == 0 || ctr == NULL)
349 prs_init(&data, MAX_PDU_FRAG_LEN, cli->mem_ctx, MARSHALL);
350 prs_init(&rdata, 0, cli->mem_ctx, UNMARSHALL);
352 /* create and send a MSRPC command with api SRV_NET_SRV_GET_INFO */
354 DEBUG(4,("SRV Get Server Info (%s), level %d\n", server_name, switch_value));
356 /* store the parameters */
357 init_srv_q_net_srv_get_info(&q_o, server_name, switch_value);
359 /* turn parameters into data stream */
360 if(!srv_io_q_net_srv_get_info("", &q_o, &data, 0)) {
362 prs_mem_free(&rdata);
366 /* send the data on \PIPE\ */
367 if (!rpc_api_pipe_req(cli, SRV_NET_SRV_GET_INFO, &data, &rdata)) {
369 prs_mem_free(&rdata);
377 if(!srv_io_r_net_srv_get_info("", &r_o, &rdata, 0)) {
378 prs_mem_free(&rdata);
382 if (r_o.status != 0) {
383 /* report error code */
384 DEBUG(0,("SRV_R_NET_SRV_GET_INFO: %s\n", get_nt_error_msg(r_o.status)));
385 prs_mem_free(&rdata);
389 if (r_o.ctr->switch_value != q_o.switch_value) {
390 /* different switch levels. oops. */
391 DEBUG(0,("SRV_R_NET_SRV_GET_INFO: info class %d does not match request %d\n",
392 r_o.ctr->switch_value, q_o.switch_value));
393 prs_mem_free(&rdata);
397 prs_mem_free(&rdata);