3 * Unix SMB/Netbios implementation.
5 * RPC Pipe client / server routines
6 * Copyright (C) Andrew Tridgell 1992-1997,
7 * Copyright (C) Luke Kenneth Casson Leighton 1996-1997,
8 * Copyright (C) Paul Ashton 1997.
9 * Copyright (C) Jeremy Allison 1999.
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
33 extern int DEBUGLEVEL;
35 /****************************************************************************
36 do a server net conn enum
37 ****************************************************************************/
38 BOOL do_srv_net_srv_conn_enum(struct cli_state *cli,
39 char *server_name, char *qual_name,
40 uint32 switch_value, SRV_CONN_INFO_CTR *ctr,
46 SRV_Q_NET_CONN_ENUM q_o;
47 SRV_R_NET_CONN_ENUM r_o;
49 if (server_name == NULL || ctr == NULL || preferred_len == 0)
52 prs_init(&data , MAX_PDU_FRAG_LEN, 4, MARSHALL);
53 prs_init(&rdata, 0, 4, UNMARSHALL);
55 /* create and send a MSRPC command with api SRV_NETCONNENUM */
57 DEBUG(4,("SRV Net Server Connection Enum(%s, %s), level %d, enum:%8x\n",
58 server_name, qual_name, switch_value, get_enum_hnd(hnd)));
60 ctr->switch_value = switch_value;
61 ctr->ptr_conn_ctr = 1;
62 ctr->conn.info0.num_entries_read = 0;
63 ctr->conn.info0.ptr_conn_info = 1;
65 /* store the parameters */
66 init_srv_q_net_conn_enum(&q_o, server_name, qual_name,
71 /* turn parameters into data stream */
72 if(!srv_io_q_net_conn_enum("", &q_o, &data, 0)) {
78 /* send the data on \PIPE\ */
79 if(!rpc_api_pipe_req(cli, SRV_NETCONNENUM, &data, &rdata)) {
89 if(!srv_io_r_net_conn_enum("", &r_o, &rdata, 0)) {
94 if (r_o.status != 0) {
95 /* report error code */
96 DEBUG(0,("SRV_R_NET_SRV_CONN_ENUM: %s\n", get_nt_error_msg(r_o.status)));
101 if (r_o.ctr->switch_value != switch_value) {
102 /* different switch levels. oops. */
103 DEBUG(0,("SRV_R_NET_SRV_CONN_ENUM: info class %d does not match request %d\n",
104 r_o.ctr->switch_value, switch_value));
105 prs_mem_free(&rdata);
109 prs_mem_free(&rdata);
114 /****************************************************************************
115 do a server net sess enum
116 ****************************************************************************/
118 BOOL do_srv_net_srv_sess_enum(struct cli_state *cli,
119 char *server_name, char *qual_name,
120 uint32 switch_value, SRV_SESS_INFO_CTR *ctr,
121 uint32 preferred_len,
126 SRV_Q_NET_SESS_ENUM q_o;
127 SRV_R_NET_SESS_ENUM r_o;
129 if (server_name == NULL || ctr == NULL || preferred_len == 0)
132 prs_init(&data , MAX_PDU_FRAG_LEN, 4, MARSHALL);
133 prs_init(&rdata, 0, 4, UNMARSHALL);
135 /* create and send a MSRPC command with api SRV_NETSESSENUM */
137 DEBUG(4,("SRV Net Session Enum (%s), level %d, enum:%8x\n",
138 server_name, switch_value, get_enum_hnd(hnd)));
140 ctr->switch_value = switch_value;
141 ctr->ptr_sess_ctr = 1;
142 ctr->sess.info0.num_entries_read = 0;
143 ctr->sess.info0.ptr_sess_info = 1;
145 /* store the parameters */
146 init_srv_q_net_sess_enum(&q_o, server_name, qual_name,
151 /* turn parameters into data stream */
152 if(!srv_io_q_net_sess_enum("", &q_o, &data, 0)) {
154 prs_mem_free(&rdata);
158 /* send the data on \PIPE\ */
159 if (!rpc_api_pipe_req(cli, SRV_NETSESSENUM, &data, &rdata)) {
161 prs_mem_free(&rdata);
169 if(!srv_io_r_net_sess_enum("", &r_o, &rdata, 0)) {
170 prs_mem_free(&rdata);
174 if (r_o.status != 0) {
175 /* report error code */
176 DEBUG(0,("SRV_R_NET_SRV_SESS_ENUM: %s\n", get_nt_error_msg(r_o.status)));
177 prs_mem_free(&rdata);
181 if (r_o.ctr->switch_value != switch_value) {
182 /* different switch levels. oops. */
183 DEBUG(0,("SRV_R_NET_SRV_SESS_ENUM: info class %d does not match request %d\n",
184 r_o.ctr->switch_value, switch_value));
185 prs_mem_free(&rdata);
189 prs_mem_free(&rdata);
194 /****************************************************************************
195 do a server net share enum
196 ****************************************************************************/
197 BOOL do_srv_net_srv_share_enum(struct cli_state *cli,
199 uint32 switch_value, SRV_R_NET_SHARE_ENUM *r_o,
200 uint32 preferred_len, ENUM_HND *hnd)
204 SRV_Q_NET_SHARE_ENUM q_o;
206 if (server_name == NULL || preferred_len == 0)
209 prs_init(&data , MAX_PDU_FRAG_LEN, 4, MARSHALL);
210 prs_init(&rdata, 0, 4, UNMARSHALL);
212 /* create and send a MSRPC command with api SRV_NETSHAREENUM */
214 DEBUG(4,("SRV Get Share Info (%s), level %d, enum:%8x\n",
215 server_name, switch_value, get_enum_hnd(hnd)));
217 /* store the parameters */
218 init_srv_q_net_share_enum(&q_o, server_name, switch_value,
221 /* turn parameters into data stream */
222 if(!srv_io_q_net_share_enum("", &q_o, &data, 0)) {
224 prs_mem_free(&rdata);
228 /* send the data on \PIPE\ */
229 if (!rpc_api_pipe_req(cli, SRV_NETSHAREENUM, &data, &rdata)) {
231 prs_mem_free(&rdata);
237 if(!srv_io_r_net_share_enum("", r_o, &rdata, 0)) {
238 prs_mem_free(&rdata);
242 if (r_o->status != 0) {
243 /* report error code */
244 DEBUG(0,("SRV_R_NET_SHARE_ENUM: %s\n", get_nt_error_msg(r_o->status)));
245 prs_mem_free(&rdata);
246 free_srv_r_net_share_enum(r_o);
250 if (r_o->ctr.switch_value != switch_value) {
251 /* different switch levels. oops. */
252 DEBUG(0,("SRV_R_NET_SHARE_ENUM: info class %d does not match request %d\n",
253 r_o->ctr.switch_value, switch_value));
254 prs_mem_free(&rdata);
255 free_srv_r_net_share_enum(r_o);
259 prs_mem_free(&rdata);
264 /****************************************************************************
265 do a server net file enum
266 ****************************************************************************/
268 BOOL do_srv_net_srv_file_enum(struct cli_state *cli,
269 char *server_name, char *qual_name,
270 uint32 switch_value, SRV_FILE_INFO_CTR *ctr,
271 uint32 preferred_len,
276 SRV_Q_NET_FILE_ENUM q_o;
277 SRV_R_NET_FILE_ENUM r_o;
279 if (server_name == NULL || ctr == NULL || preferred_len == 0)
282 prs_init(&data , MAX_PDU_FRAG_LEN, 4, MARSHALL);
283 prs_init(&rdata, 0, 4, UNMARSHALL);
285 /* create and send a MSRPC command with api SRV_NETFILEENUM */
287 DEBUG(4,("SRV Get File Info (%s), level %d, enum:%8x\n",
288 server_name, switch_value, get_enum_hnd(hnd)));
290 q_o.file_level = switch_value;
292 ctr->switch_value = switch_value;
293 ctr->ptr_file_ctr = 1;
294 ctr->file.info3.num_entries_read = 0;
295 ctr->file.info3.ptr_file_info = 1;
297 /* store the parameters */
298 init_srv_q_net_file_enum(&q_o, server_name, qual_name,
303 /* turn parameters into data stream */
304 if(!srv_io_q_net_file_enum("", &q_o, &data, 0)) {
306 prs_mem_free(&rdata);
310 /* send the data on \PIPE\ */
311 if (!rpc_api_pipe_req(cli, SRV_NETFILEENUM, &data, &rdata)) {
313 prs_mem_free(&rdata);
321 if(!srv_io_r_net_file_enum("", &r_o, &rdata, 0)) {
322 prs_mem_free(&rdata);
326 if (r_o.status != 0) {
327 /* report error code */
328 DEBUG(0,("SRV_R_NET_FILE_ENUM: %s\n", get_nt_error_msg(r_o.status)));
329 prs_mem_free(&rdata);
333 if (r_o.ctr->switch_value != switch_value) {
334 /* different switch levels. oops. */
335 DEBUG(0,("SRV_R_NET_FILE_ENUM: info class %d does not match request %d\n",
336 r_o.ctr->switch_value, switch_value));
337 prs_mem_free(&rdata);
341 prs_mem_free(&rdata);
346 /****************************************************************************
348 ****************************************************************************/
349 BOOL do_srv_net_srv_get_info(struct cli_state *cli,
350 char *server_name, uint32 switch_value, SRV_INFO_CTR *ctr)
354 SRV_Q_NET_SRV_GET_INFO q_o;
355 SRV_R_NET_SRV_GET_INFO r_o;
357 if (server_name == NULL || switch_value == 0 || ctr == NULL)
360 prs_init(&data , MAX_PDU_FRAG_LEN, 4, MARSHALL);
361 prs_init(&rdata, 0, 4, UNMARSHALL);
363 /* create and send a MSRPC command with api SRV_NET_SRV_GET_INFO */
365 DEBUG(4,("SRV Get Server Info (%s), level %d\n", server_name, switch_value));
367 /* store the parameters */
368 init_srv_q_net_srv_get_info(&q_o, server_name, switch_value);
370 /* turn parameters into data stream */
371 if(!srv_io_q_net_srv_get_info("", &q_o, &data, 0)) {
373 prs_mem_free(&rdata);
377 /* send the data on \PIPE\ */
378 if (!rpc_api_pipe_req(cli, SRV_NET_SRV_GET_INFO, &data, &rdata)) {
380 prs_mem_free(&rdata);
388 if(!srv_io_r_net_srv_get_info("", &r_o, &rdata, 0)) {
389 prs_mem_free(&rdata);
393 if (r_o.status != 0) {
394 /* report error code */
395 DEBUG(0,("SRV_R_NET_SRV_GET_INFO: %s\n", get_nt_error_msg(r_o.status)));
396 prs_mem_free(&rdata);
400 if (r_o.ctr->switch_value != q_o.switch_value) {
401 /* different switch levels. oops. */
402 DEBUG(0,("SRV_R_NET_SRV_GET_INFO: info class %d does not match request %d\n",
403 r_o.ctr->switch_value, q_o.switch_value));
404 prs_mem_free(&rdata);
408 prs_mem_free(&rdata);