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 2001,
8 * Copyright (C) Anthony Liguori 2003.
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 /* This is the interface to the srvsvc pipe. */
30 #define DBGC_CLASS DBGC_RPC_SRV
32 /*******************************************************************
33 api_srv_net_srv_get_info
34 ********************************************************************/
36 static BOOL
api_srv_net_srv_get_info(pipes_struct
*p
)
38 SRV_Q_NET_SRV_GET_INFO q_u
;
39 SRV_R_NET_SRV_GET_INFO r_u
;
40 prs_struct
*data
= &p
->in_data
.data
;
41 prs_struct
*rdata
= &p
->out_data
.rdata
;
46 /* grab the net server get info */
47 if (!srv_io_q_net_srv_get_info("", &q_u
, data
, 0))
50 r_u
.status
= _srv_net_srv_get_info(p
, &q_u
, &r_u
);
52 /* store the response in the SMB stream */
53 if (!srv_io_r_net_srv_get_info("", &r_u
, rdata
, 0))
59 /*******************************************************************
60 api_srv_net_srv_get_info
61 ********************************************************************/
63 static BOOL
api_srv_net_srv_set_info(pipes_struct
*p
)
65 SRV_Q_NET_SRV_SET_INFO q_u
;
66 SRV_R_NET_SRV_SET_INFO r_u
;
67 prs_struct
*data
= &p
->in_data
.data
;
68 prs_struct
*rdata
= &p
->out_data
.rdata
;
73 /* grab the net server set info */
74 if (!srv_io_q_net_srv_set_info("", &q_u
, data
, 0))
77 r_u
.status
= _srv_net_srv_set_info(p
, &q_u
, &r_u
);
79 /* store the response in the SMB stream */
80 if (!srv_io_r_net_srv_set_info("", &r_u
, rdata
, 0))
86 /*******************************************************************
88 ********************************************************************/
90 static BOOL
api_srv_net_file_enum(pipes_struct
*p
)
92 SRV_Q_NET_FILE_ENUM q_u
;
93 SRV_R_NET_FILE_ENUM r_u
;
94 prs_struct
*data
= &p
->in_data
.data
;
95 prs_struct
*rdata
= &p
->out_data
.rdata
;
100 /* grab the net file enum */
101 if (!srv_io_q_net_file_enum("", &q_u
, data
, 0))
104 r_u
.status
= _srv_net_file_enum(p
, &q_u
, &r_u
);
106 /* store the response in the SMB stream */
107 if(!srv_io_r_net_file_enum("", &r_u
, rdata
, 0))
113 /*******************************************************************
114 api_srv_net_conn_enum
115 ********************************************************************/
117 static BOOL
api_srv_net_conn_enum(pipes_struct
*p
)
119 SRV_Q_NET_CONN_ENUM q_u
;
120 SRV_R_NET_CONN_ENUM r_u
;
121 prs_struct
*data
= &p
->in_data
.data
;
122 prs_struct
*rdata
= &p
->out_data
.rdata
;
127 /* grab the net server get enum */
128 if (!srv_io_q_net_conn_enum("", &q_u
, data
, 0))
131 r_u
.status
= _srv_net_conn_enum(p
, &q_u
, &r_u
);
133 /* store the response in the SMB stream */
134 if (!srv_io_r_net_conn_enum("", &r_u
, rdata
, 0))
140 /*******************************************************************
142 ********************************************************************/
144 static BOOL
api_srv_net_sess_enum(pipes_struct
*p
)
146 SRV_Q_NET_SESS_ENUM q_u
;
147 SRV_R_NET_SESS_ENUM r_u
;
148 prs_struct
*data
= &p
->in_data
.data
;
149 prs_struct
*rdata
= &p
->out_data
.rdata
;
154 /* grab the net server get enum */
155 if (!srv_io_q_net_sess_enum("", &q_u
, data
, 0))
158 /* construct reply. always indicate success */
159 r_u
.status
= _srv_net_sess_enum(p
, &q_u
, &r_u
);
161 /* store the response in the SMB stream */
162 if (!srv_io_r_net_sess_enum("", &r_u
, rdata
, 0))
168 /*******************************************************************
169 RPC to enumerate shares.
170 ********************************************************************/
172 static BOOL
api_srv_net_share_enum_all(pipes_struct
*p
)
174 SRV_Q_NET_SHARE_ENUM q_u
;
175 SRV_R_NET_SHARE_ENUM r_u
;
176 prs_struct
*data
= &p
->in_data
.data
;
177 prs_struct
*rdata
= &p
->out_data
.rdata
;
182 /* Unmarshall the net server get enum. */
183 if(!srv_io_q_net_share_enum("", &q_u
, data
, 0)) {
184 DEBUG(0,("api_srv_net_share_enum_all: Failed to unmarshall SRV_Q_NET_SHARE_ENUM.\n"));
188 r_u
.status
= _srv_net_share_enum_all(p
, &q_u
, &r_u
);
190 if (!srv_io_r_net_share_enum("", &r_u
, rdata
, 0)) {
191 DEBUG(0,("api_srv_net_share_enum_all: Failed to marshall SRV_R_NET_SHARE_ENUM.\n"));
198 /*******************************************************************
199 RPC to enumerate shares.
200 ********************************************************************/
202 static BOOL
api_srv_net_share_enum(pipes_struct
*p
)
204 SRV_Q_NET_SHARE_ENUM q_u
;
205 SRV_R_NET_SHARE_ENUM r_u
;
206 prs_struct
*data
= &p
->in_data
.data
;
207 prs_struct
*rdata
= &p
->out_data
.rdata
;
212 /* Unmarshall the net server get enum. */
213 if(!srv_io_q_net_share_enum("", &q_u
, data
, 0)) {
214 DEBUG(0,("api_srv_net_share_enum: Failed to unmarshall SRV_Q_NET_SHARE_ENUM.\n"));
218 r_u
.status
= _srv_net_share_enum(p
, &q_u
, &r_u
);
220 if (!srv_io_r_net_share_enum("", &r_u
, rdata
, 0)) {
221 DEBUG(0,("api_srv_net_share_enum: Failed to marshall SRV_R_NET_SHARE_ENUM.\n"));
228 /*******************************************************************
229 RPC to return share information.
230 ********************************************************************/
232 static BOOL
api_srv_net_share_get_info(pipes_struct
*p
)
234 SRV_Q_NET_SHARE_GET_INFO q_u
;
235 SRV_R_NET_SHARE_GET_INFO r_u
;
236 prs_struct
*data
= &p
->in_data
.data
;
237 prs_struct
*rdata
= &p
->out_data
.rdata
;
242 /* Unmarshall the net server get info. */
243 if(!srv_io_q_net_share_get_info("", &q_u
, data
, 0)) {
244 DEBUG(0,("api_srv_net_share_get_info: Failed to unmarshall SRV_Q_NET_SHARE_GET_INFO.\n"));
248 r_u
.status
= _srv_net_share_get_info(p
, &q_u
, &r_u
);
250 if(!srv_io_r_net_share_get_info("", &r_u
, rdata
, 0)) {
251 DEBUG(0,("api_srv_net_share_get_info: Failed to marshall SRV_R_NET_SHARE_GET_INFO.\n"));
258 /*******************************************************************
259 RPC to set share information.
260 ********************************************************************/
262 static BOOL
api_srv_net_share_set_info(pipes_struct
*p
)
264 SRV_Q_NET_SHARE_SET_INFO q_u
;
265 SRV_R_NET_SHARE_SET_INFO r_u
;
266 prs_struct
*data
= &p
->in_data
.data
;
267 prs_struct
*rdata
= &p
->out_data
.rdata
;
272 /* Unmarshall the net server set info. */
273 if(!srv_io_q_net_share_set_info("", &q_u
, data
, 0)) {
274 DEBUG(0,("api_srv_net_share_set_info: Failed to unmarshall SRV_Q_NET_SHARE_SET_INFO.\n"));
278 r_u
.status
= _srv_net_share_set_info(p
, &q_u
, &r_u
);
280 if(!srv_io_r_net_share_set_info("", &r_u
, rdata
, 0)) {
281 DEBUG(0,("api_srv_net_share_set_info: Failed to marshall SRV_R_NET_SHARE_SET_INFO.\n"));
288 /*******************************************************************
289 RPC to add share information.
290 ********************************************************************/
292 static BOOL
api_srv_net_share_add(pipes_struct
*p
)
294 SRV_Q_NET_SHARE_ADD q_u
;
295 SRV_R_NET_SHARE_ADD r_u
;
296 prs_struct
*data
= &p
->in_data
.data
;
297 prs_struct
*rdata
= &p
->out_data
.rdata
;
302 /* Unmarshall the net server add info. */
303 if(!srv_io_q_net_share_add("", &q_u
, data
, 0)) {
304 DEBUG(0,("api_srv_net_share_add: Failed to unmarshall SRV_Q_NET_SHARE_ADD.\n"));
308 r_u
.status
= _srv_net_share_add(p
, &q_u
, &r_u
);
310 if(!srv_io_r_net_share_add("", &r_u
, rdata
, 0)) {
311 DEBUG(0,("api_srv_net_share_add: Failed to marshall SRV_R_NET_SHARE_ADD.\n"));
318 /*******************************************************************
319 RPC to delete share information.
320 ********************************************************************/
322 static BOOL
api_srv_net_share_del(pipes_struct
*p
)
324 SRV_Q_NET_SHARE_DEL q_u
;
325 SRV_R_NET_SHARE_DEL r_u
;
326 prs_struct
*data
= &p
->in_data
.data
;
327 prs_struct
*rdata
= &p
->out_data
.rdata
;
332 /* Unmarshall the net server del info. */
333 if(!srv_io_q_net_share_del("", &q_u
, data
, 0)) {
334 DEBUG(0,("api_srv_net_share_del: Failed to unmarshall SRV_Q_NET_SHARE_DEL.\n"));
338 r_u
.status
= _srv_net_share_del(p
, &q_u
, &r_u
);
340 if(!srv_io_r_net_share_del("", &r_u
, rdata
, 0)) {
341 DEBUG(0,("api_srv_net_share_del: Failed to marshall SRV_R_NET_SHARE_DEL.\n"));
348 /*******************************************************************
349 RPC to delete share information.
350 ********************************************************************/
352 static BOOL
api_srv_net_share_del_sticky(pipes_struct
*p
)
354 SRV_Q_NET_SHARE_DEL q_u
;
355 SRV_R_NET_SHARE_DEL r_u
;
356 prs_struct
*data
= &p
->in_data
.data
;
357 prs_struct
*rdata
= &p
->out_data
.rdata
;
362 /* Unmarshall the net server del info. */
363 if(!srv_io_q_net_share_del("", &q_u
, data
, 0)) {
364 DEBUG(0,("api_srv_net_share_del_sticky: Failed to unmarshall SRV_Q_NET_SHARE_DEL.\n"));
368 r_u
.status
= _srv_net_share_del_sticky(p
, &q_u
, &r_u
);
370 if(!srv_io_r_net_share_del("", &r_u
, rdata
, 0)) {
371 DEBUG(0,("api_srv_net_share_del_sticky: Failed to marshall SRV_R_NET_SHARE_DEL.\n"));
378 /*******************************************************************
379 api_srv_net_remote_tod
380 ********************************************************************/
382 static BOOL
api_srv_net_remote_tod(pipes_struct
*p
)
384 SRV_Q_NET_REMOTE_TOD q_u
;
385 SRV_R_NET_REMOTE_TOD r_u
;
386 prs_struct
*data
= &p
->in_data
.data
;
387 prs_struct
*rdata
= &p
->out_data
.rdata
;
392 /* grab the net server get enum */
393 if(!srv_io_q_net_remote_tod("", &q_u
, data
, 0))
396 r_u
.status
= _srv_net_remote_tod(p
, &q_u
, &r_u
);
398 /* store the response in the SMB stream */
399 if(!srv_io_r_net_remote_tod("", &r_u
, rdata
, 0))
405 /*******************************************************************
406 RPC to enumerate disks available on a server e.g. C:, D: ...
407 *******************************************************************/
409 static BOOL
api_srv_net_disk_enum(pipes_struct
*p
)
411 SRV_Q_NET_DISK_ENUM q_u
;
412 SRV_R_NET_DISK_ENUM r_u
;
413 prs_struct
*data
= &p
->in_data
.data
;
414 prs_struct
*rdata
= &p
->out_data
.rdata
;
419 /* Unmarshall the net server disk enum. */
420 if(!srv_io_q_net_disk_enum("", &q_u
, data
, 0)) {
421 DEBUG(0,("api_srv_net_disk_enum: Failed to unmarshall SRV_Q_NET_DISK_ENUM.\n"));
425 r_u
.status
= _srv_net_disk_enum(p
, &q_u
, &r_u
);
427 if(!srv_io_r_net_disk_enum("", &r_u
, rdata
, 0)) {
428 DEBUG(0,("api_srv_net_disk_enum: Failed to marshall SRV_R_NET_DISK_ENUM.\n"));
435 /*******************************************************************
436 NetValidateName (opnum 0x21)
437 *******************************************************************/
439 static BOOL
api_srv_net_name_validate(pipes_struct
*p
)
441 SRV_Q_NET_NAME_VALIDATE q_u
;
442 SRV_R_NET_NAME_VALIDATE r_u
;
443 prs_struct
*data
= &p
->in_data
.data
;
444 prs_struct
*rdata
= &p
->out_data
.rdata
;
449 /* Unmarshall the net server disk enum. */
450 if(!srv_io_q_net_name_validate("", &q_u
, data
, 0)) {
451 DEBUG(0,("api_srv_net_name_validate: Failed to unmarshall SRV_Q_NET_NAME_VALIDATE.\n"));
455 r_u
.status
= _srv_net_name_validate(p
, &q_u
, &r_u
);
457 if(!srv_io_r_net_name_validate("", &r_u
, rdata
, 0)) {
458 DEBUG(0,("api_srv_net_name_validate: Failed to marshall SRV_R_NET_NAME_VALIDATE.\n"));
465 /*******************************************************************
466 NetFileQuerySecdesc (opnum 0x27)
467 *******************************************************************/
469 static BOOL
api_srv_net_file_query_secdesc(pipes_struct
*p
)
471 SRV_Q_NET_FILE_QUERY_SECDESC q_u
;
472 SRV_R_NET_FILE_QUERY_SECDESC r_u
;
473 prs_struct
*data
= &p
->in_data
.data
;
474 prs_struct
*rdata
= &p
->out_data
.rdata
;
479 /* Unmarshall the net file get info from Win9x */
480 if(!srv_io_q_net_file_query_secdesc("", &q_u
, data
, 0)) {
481 DEBUG(0,("api_srv_net_file_query_secdesc: Failed to unmarshall SRV_Q_NET_FILE_QUERY_SECDESC.\n"));
485 r_u
.status
= _srv_net_file_query_secdesc(p
, &q_u
, &r_u
);
487 if(!srv_io_r_net_file_query_secdesc("", &r_u
, rdata
, 0)) {
488 DEBUG(0,("api_srv_net_file_query_secdesc: Failed to marshall SRV_R_NET_FILE_QUERY_SECDESC.\n"));
495 /*******************************************************************
496 NetFileSetSecdesc (opnum 0x28)
497 *******************************************************************/
499 static BOOL
api_srv_net_file_set_secdesc(pipes_struct
*p
)
501 SRV_Q_NET_FILE_SET_SECDESC q_u
;
502 SRV_R_NET_FILE_SET_SECDESC r_u
;
503 prs_struct
*data
= &p
->in_data
.data
;
504 prs_struct
*rdata
= &p
->out_data
.rdata
;
509 /* Unmarshall the net file set info from Win9x */
510 if(!srv_io_q_net_file_set_secdesc("", &q_u
, data
, 0)) {
511 DEBUG(0,("api_srv_net_file_set_secdesc: Failed to unmarshall SRV_Q_NET_FILE_SET_SECDESC.\n"));
515 r_u
.status
= _srv_net_file_set_secdesc(p
, &q_u
, &r_u
);
517 if(!srv_io_r_net_file_set_secdesc("", &r_u
, rdata
, 0)) {
518 DEBUG(0,("api_srv_net_file_set_secdesc: Failed to marshall SRV_R_NET_FILE_SET_SECDESC.\n"));
525 /*******************************************************************
526 \PIPE\srvsvc commands
527 ********************************************************************/
529 #ifdef RPC_SVC_DYNAMIC
530 int rpc_pipe_init(void)
532 int rpc_srv_init(void)
535 static const struct api_struct api_srv_cmds
[] =
537 { "SRV_NET_CONN_ENUM" , SRV_NET_CONN_ENUM
, api_srv_net_conn_enum
},
538 { "SRV_NET_SESS_ENUM" , SRV_NET_SESS_ENUM
, api_srv_net_sess_enum
},
539 { "SRV_NET_SHARE_ENUM_ALL" , SRV_NET_SHARE_ENUM_ALL
, api_srv_net_share_enum_all
},
540 { "SRV_NET_SHARE_ENUM" , SRV_NET_SHARE_ENUM
, api_srv_net_share_enum
},
541 { "SRV_NET_SHARE_ADD" , SRV_NET_SHARE_ADD
, api_srv_net_share_add
},
542 { "SRV_NET_SHARE_DEL" , SRV_NET_SHARE_DEL
, api_srv_net_share_del
},
543 { "SRV_NET_SHARE_DEL_STICKY" , SRV_NET_SHARE_DEL_STICKY
, api_srv_net_share_del_sticky
},
544 { "SRV_NET_SHARE_GET_INFO" , SRV_NET_SHARE_GET_INFO
, api_srv_net_share_get_info
},
545 { "SRV_NET_SHARE_SET_INFO" , SRV_NET_SHARE_SET_INFO
, api_srv_net_share_set_info
},
546 { "SRV_NET_FILE_ENUM" , SRV_NET_FILE_ENUM
, api_srv_net_file_enum
},
547 { "SRV_NET_SRV_GET_INFO" , SRV_NET_SRV_GET_INFO
, api_srv_net_srv_get_info
},
548 { "SRV_NET_SRV_SET_INFO" , SRV_NET_SRV_SET_INFO
, api_srv_net_srv_set_info
},
549 { "SRV_NET_REMOTE_TOD" , SRV_NET_REMOTE_TOD
, api_srv_net_remote_tod
},
550 { "SRV_NET_DISK_ENUM" , SRV_NET_DISK_ENUM
, api_srv_net_disk_enum
},
551 { "SRV_NET_NAME_VALIDATE" , SRV_NET_NAME_VALIDATE
, api_srv_net_name_validate
},
552 { "SRV_NET_FILE_QUERY_SECDESC", SRV_NET_FILE_QUERY_SECDESC
, api_srv_net_file_query_secdesc
},
553 { "SRV_NET_FILE_SET_SECDESC" , SRV_NET_FILE_SET_SECDESC
, api_srv_net_file_set_secdesc
}
555 return rpc_pipe_register_commands("srvsvc", "ntsvcs", api_srv_cmds
,
556 sizeof(api_srv_cmds
) / sizeof(struct api_struct
));