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) Jim McDonough <jmcd@us.ibm.com> 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 /*******************************************************************
170 ********************************************************************/
172 static BOOL api_srv_net_sess_del(pipes_struct *p)
174 SRV_Q_NET_SESS_DEL q_u;
175 SRV_R_NET_SESS_DEL r_u;
176 prs_struct *data = &p->in_data.data;
177 prs_struct *rdata = &p->out_data.rdata;
182 /* grab the net server get enum */
183 if (!srv_io_q_net_sess_del("", &q_u, data, 0))
186 /* construct reply. always indicate success */
187 r_u.status = _srv_net_sess_del(p, &q_u, &r_u);
189 /* store the response in the SMB stream */
190 if (!srv_io_r_net_sess_del("", &r_u, rdata, 0))
196 /*******************************************************************
197 RPC to enumerate shares.
198 ********************************************************************/
200 static BOOL api_srv_net_share_enum_all(pipes_struct *p)
202 SRV_Q_NET_SHARE_ENUM q_u;
203 SRV_R_NET_SHARE_ENUM r_u;
204 prs_struct *data = &p->in_data.data;
205 prs_struct *rdata = &p->out_data.rdata;
210 /* Unmarshall the net server get enum. */
211 if(!srv_io_q_net_share_enum("", &q_u, data, 0)) {
212 DEBUG(0,("api_srv_net_share_enum_all: Failed to unmarshall SRV_Q_NET_SHARE_ENUM.\n"));
216 r_u.status = _srv_net_share_enum_all(p, &q_u, &r_u);
218 if (!srv_io_r_net_share_enum("", &r_u, rdata, 0)) {
219 DEBUG(0,("api_srv_net_share_enum_all: Failed to marshall SRV_R_NET_SHARE_ENUM.\n"));
226 /*******************************************************************
227 RPC to enumerate shares.
228 ********************************************************************/
230 static BOOL api_srv_net_share_enum(pipes_struct *p)
232 SRV_Q_NET_SHARE_ENUM q_u;
233 SRV_R_NET_SHARE_ENUM r_u;
234 prs_struct *data = &p->in_data.data;
235 prs_struct *rdata = &p->out_data.rdata;
240 /* Unmarshall the net server get enum. */
241 if(!srv_io_q_net_share_enum("", &q_u, data, 0)) {
242 DEBUG(0,("api_srv_net_share_enum: Failed to unmarshall SRV_Q_NET_SHARE_ENUM.\n"));
246 r_u.status = _srv_net_share_enum(p, &q_u, &r_u);
248 if (!srv_io_r_net_share_enum("", &r_u, rdata, 0)) {
249 DEBUG(0,("api_srv_net_share_enum: Failed to marshall SRV_R_NET_SHARE_ENUM.\n"));
256 /*******************************************************************
257 RPC to return share information.
258 ********************************************************************/
260 static BOOL api_srv_net_share_get_info(pipes_struct *p)
262 SRV_Q_NET_SHARE_GET_INFO q_u;
263 SRV_R_NET_SHARE_GET_INFO r_u;
264 prs_struct *data = &p->in_data.data;
265 prs_struct *rdata = &p->out_data.rdata;
270 /* Unmarshall the net server get info. */
271 if(!srv_io_q_net_share_get_info("", &q_u, data, 0)) {
272 DEBUG(0,("api_srv_net_share_get_info: Failed to unmarshall SRV_Q_NET_SHARE_GET_INFO.\n"));
276 r_u.status = _srv_net_share_get_info(p, &q_u, &r_u);
278 if(!srv_io_r_net_share_get_info("", &r_u, rdata, 0)) {
279 DEBUG(0,("api_srv_net_share_get_info: Failed to marshall SRV_R_NET_SHARE_GET_INFO.\n"));
286 /*******************************************************************
287 RPC to set share information.
288 ********************************************************************/
290 static BOOL api_srv_net_share_set_info(pipes_struct *p)
292 SRV_Q_NET_SHARE_SET_INFO q_u;
293 SRV_R_NET_SHARE_SET_INFO r_u;
294 prs_struct *data = &p->in_data.data;
295 prs_struct *rdata = &p->out_data.rdata;
300 /* Unmarshall the net server set info. */
301 if(!srv_io_q_net_share_set_info("", &q_u, data, 0)) {
302 DEBUG(0,("api_srv_net_share_set_info: Failed to unmarshall SRV_Q_NET_SHARE_SET_INFO.\n"));
306 r_u.status = _srv_net_share_set_info(p, &q_u, &r_u);
308 if(!srv_io_r_net_share_set_info("", &r_u, rdata, 0)) {
309 DEBUG(0,("api_srv_net_share_set_info: Failed to marshall SRV_R_NET_SHARE_SET_INFO.\n"));
316 /*******************************************************************
317 RPC to add share information.
318 ********************************************************************/
320 static BOOL api_srv_net_share_add(pipes_struct *p)
322 SRV_Q_NET_SHARE_ADD q_u;
323 SRV_R_NET_SHARE_ADD r_u;
324 prs_struct *data = &p->in_data.data;
325 prs_struct *rdata = &p->out_data.rdata;
330 /* Unmarshall the net server add info. */
331 if(!srv_io_q_net_share_add("", &q_u, data, 0)) {
332 DEBUG(0,("api_srv_net_share_add: Failed to unmarshall SRV_Q_NET_SHARE_ADD.\n"));
336 r_u.status = _srv_net_share_add(p, &q_u, &r_u);
338 if(!srv_io_r_net_share_add("", &r_u, rdata, 0)) {
339 DEBUG(0,("api_srv_net_share_add: Failed to marshall SRV_R_NET_SHARE_ADD.\n"));
346 /*******************************************************************
347 RPC to delete share information.
348 ********************************************************************/
350 static BOOL api_srv_net_share_del(pipes_struct *p)
352 SRV_Q_NET_SHARE_DEL q_u;
353 SRV_R_NET_SHARE_DEL r_u;
354 prs_struct *data = &p->in_data.data;
355 prs_struct *rdata = &p->out_data.rdata;
360 /* Unmarshall the net server del info. */
361 if(!srv_io_q_net_share_del("", &q_u, data, 0)) {
362 DEBUG(0,("api_srv_net_share_del: Failed to unmarshall SRV_Q_NET_SHARE_DEL.\n"));
366 r_u.status = _srv_net_share_del(p, &q_u, &r_u);
368 if(!srv_io_r_net_share_del("", &r_u, rdata, 0)) {
369 DEBUG(0,("api_srv_net_share_del: Failed to marshall SRV_R_NET_SHARE_DEL.\n"));
376 /*******************************************************************
377 RPC to delete share information.
378 ********************************************************************/
380 static BOOL api_srv_net_share_del_sticky(pipes_struct *p)
382 SRV_Q_NET_SHARE_DEL q_u;
383 SRV_R_NET_SHARE_DEL r_u;
384 prs_struct *data = &p->in_data.data;
385 prs_struct *rdata = &p->out_data.rdata;
390 /* Unmarshall the net server del info. */
391 if(!srv_io_q_net_share_del("", &q_u, data, 0)) {
392 DEBUG(0,("api_srv_net_share_del_sticky: Failed to unmarshall SRV_Q_NET_SHARE_DEL.\n"));
396 r_u.status = _srv_net_share_del_sticky(p, &q_u, &r_u);
398 if(!srv_io_r_net_share_del("", &r_u, rdata, 0)) {
399 DEBUG(0,("api_srv_net_share_del_sticky: Failed to marshall SRV_R_NET_SHARE_DEL.\n"));
406 /*******************************************************************
407 api_srv_net_remote_tod
408 ********************************************************************/
410 static BOOL api_srv_net_remote_tod(pipes_struct *p)
412 SRV_Q_NET_REMOTE_TOD q_u;
413 SRV_R_NET_REMOTE_TOD r_u;
414 prs_struct *data = &p->in_data.data;
415 prs_struct *rdata = &p->out_data.rdata;
420 /* grab the net server get enum */
421 if(!srv_io_q_net_remote_tod("", &q_u, data, 0))
424 r_u.status = _srv_net_remote_tod(p, &q_u, &r_u);
426 /* store the response in the SMB stream */
427 if(!srv_io_r_net_remote_tod("", &r_u, rdata, 0))
433 /*******************************************************************
434 RPC to enumerate disks available on a server e.g. C:, D: ...
435 *******************************************************************/
437 static BOOL api_srv_net_disk_enum(pipes_struct *p)
439 SRV_Q_NET_DISK_ENUM q_u;
440 SRV_R_NET_DISK_ENUM r_u;
441 prs_struct *data = &p->in_data.data;
442 prs_struct *rdata = &p->out_data.rdata;
447 /* Unmarshall the net server disk enum. */
448 if(!srv_io_q_net_disk_enum("", &q_u, data, 0)) {
449 DEBUG(0,("api_srv_net_disk_enum: Failed to unmarshall SRV_Q_NET_DISK_ENUM.\n"));
453 r_u.status = _srv_net_disk_enum(p, &q_u, &r_u);
455 if(!srv_io_r_net_disk_enum("", &r_u, rdata, 0)) {
456 DEBUG(0,("api_srv_net_disk_enum: Failed to marshall SRV_R_NET_DISK_ENUM.\n"));
463 /*******************************************************************
464 NetValidateName (opnum 0x21)
465 *******************************************************************/
467 static BOOL api_srv_net_name_validate(pipes_struct *p)
469 SRV_Q_NET_NAME_VALIDATE q_u;
470 SRV_R_NET_NAME_VALIDATE r_u;
471 prs_struct *data = &p->in_data.data;
472 prs_struct *rdata = &p->out_data.rdata;
477 /* Unmarshall the net server disk enum. */
478 if(!srv_io_q_net_name_validate("", &q_u, data, 0)) {
479 DEBUG(0,("api_srv_net_name_validate: Failed to unmarshall SRV_Q_NET_NAME_VALIDATE.\n"));
483 r_u.status = _srv_net_name_validate(p, &q_u, &r_u);
485 if(!srv_io_r_net_name_validate("", &r_u, rdata, 0)) {
486 DEBUG(0,("api_srv_net_name_validate: Failed to marshall SRV_R_NET_NAME_VALIDATE.\n"));
493 /*******************************************************************
494 NetFileQuerySecdesc (opnum 0x27)
495 *******************************************************************/
497 static BOOL api_srv_net_file_query_secdesc(pipes_struct *p)
499 SRV_Q_NET_FILE_QUERY_SECDESC q_u;
500 SRV_R_NET_FILE_QUERY_SECDESC r_u;
501 prs_struct *data = &p->in_data.data;
502 prs_struct *rdata = &p->out_data.rdata;
507 /* Unmarshall the net file get info from Win9x */
508 if(!srv_io_q_net_file_query_secdesc("", &q_u, data, 0)) {
509 DEBUG(0,("api_srv_net_file_query_secdesc: Failed to unmarshall SRV_Q_NET_FILE_QUERY_SECDESC.\n"));
513 r_u.status = _srv_net_file_query_secdesc(p, &q_u, &r_u);
515 if(!srv_io_r_net_file_query_secdesc("", &r_u, rdata, 0)) {
516 DEBUG(0,("api_srv_net_file_query_secdesc: Failed to marshall SRV_R_NET_FILE_QUERY_SECDESC.\n"));
523 /*******************************************************************
524 NetFileSetSecdesc (opnum 0x28)
525 *******************************************************************/
527 static BOOL api_srv_net_file_set_secdesc(pipes_struct *p)
529 SRV_Q_NET_FILE_SET_SECDESC q_u;
530 SRV_R_NET_FILE_SET_SECDESC r_u;
531 prs_struct *data = &p->in_data.data;
532 prs_struct *rdata = &p->out_data.rdata;
537 /* Unmarshall the net file set info from Win9x */
538 if(!srv_io_q_net_file_set_secdesc("", &q_u, data, 0)) {
539 DEBUG(0,("api_srv_net_file_set_secdesc: Failed to unmarshall SRV_Q_NET_FILE_SET_SECDESC.\n"));
543 r_u.status = _srv_net_file_set_secdesc(p, &q_u, &r_u);
545 if(!srv_io_r_net_file_set_secdesc("", &r_u, rdata, 0)) {
546 DEBUG(0,("api_srv_net_file_set_secdesc: Failed to marshall SRV_R_NET_FILE_SET_SECDESC.\n"));
553 /*******************************************************************
554 \PIPE\srvsvc commands
555 ********************************************************************/
557 static struct api_struct api_srv_cmds[] =
559 { "SRV_NET_CONN_ENUM" , SRV_NET_CONN_ENUM , api_srv_net_conn_enum },
560 { "SRV_NET_SESS_ENUM" , SRV_NET_SESS_ENUM , api_srv_net_sess_enum },
561 { "SRV_NET_SESS_DEL" , SRV_NET_SESS_DEL , api_srv_net_sess_del },
562 { "SRV_NET_SHARE_ENUM_ALL" , SRV_NET_SHARE_ENUM_ALL , api_srv_net_share_enum_all },
563 { "SRV_NET_SHARE_ENUM" , SRV_NET_SHARE_ENUM , api_srv_net_share_enum },
564 { "SRV_NET_SHARE_ADD" , SRV_NET_SHARE_ADD , api_srv_net_share_add },
565 { "SRV_NET_SHARE_DEL" , SRV_NET_SHARE_DEL , api_srv_net_share_del },
566 { "SRV_NET_SHARE_DEL_STICKY" , SRV_NET_SHARE_DEL_STICKY , api_srv_net_share_del_sticky },
567 { "SRV_NET_SHARE_GET_INFO" , SRV_NET_SHARE_GET_INFO , api_srv_net_share_get_info },
568 { "SRV_NET_SHARE_SET_INFO" , SRV_NET_SHARE_SET_INFO , api_srv_net_share_set_info },
569 { "SRV_NET_FILE_ENUM" , SRV_NET_FILE_ENUM , api_srv_net_file_enum },
570 { "SRV_NET_SRV_GET_INFO" , SRV_NET_SRV_GET_INFO , api_srv_net_srv_get_info },
571 { "SRV_NET_SRV_SET_INFO" , SRV_NET_SRV_SET_INFO , api_srv_net_srv_set_info },
572 { "SRV_NET_REMOTE_TOD" , SRV_NET_REMOTE_TOD , api_srv_net_remote_tod },
573 { "SRV_NET_DISK_ENUM" , SRV_NET_DISK_ENUM , api_srv_net_disk_enum },
574 { "SRV_NET_NAME_VALIDATE" , SRV_NET_NAME_VALIDATE , api_srv_net_name_validate },
575 { "SRV_NET_FILE_QUERY_SECDESC", SRV_NET_FILE_QUERY_SECDESC, api_srv_net_file_query_secdesc },
576 { "SRV_NET_FILE_SET_SECDESC" , SRV_NET_FILE_SET_SECDESC , api_srv_net_file_set_secdesc }
579 void srvsvc_get_pipe_fns( struct api_struct **fns, int *n_fns )
582 *n_fns = sizeof(api_srv_cmds) / sizeof(struct api_struct);
586 NTSTATUS rpc_srv_init(void)
588 return rpc_pipe_register_commands(SMB_RPC_INTERFACE_VERSION, "srvsvc", "ntsvcs", api_srv_cmds,
589 sizeof(api_srv_cmds) / sizeof(struct api_struct));