r6303: Setting up for 3.0.15pre1
[Samba.git] / source / rpc_server / srv_srvsvc.c
blob0b4eac5cc7304310857e6fa70dac9985a80d7c3e
1 /*
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.
9 *
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. */
27 #include "includes.h"
29 #undef DBGC_CLASS
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;
43 ZERO_STRUCT(q_u);
44 ZERO_STRUCT(r_u);
46 /* grab the net server get info */
47 if (!srv_io_q_net_srv_get_info("", &q_u, data, 0))
48 return False;
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))
54 return False;
56 return True;
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;
70 ZERO_STRUCT(q_u);
71 ZERO_STRUCT(r_u);
73 /* grab the net server set info */
74 if (!srv_io_q_net_srv_set_info("", &q_u, data, 0))
75 return False;
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))
81 return False;
83 return True;
86 /*******************************************************************
87 api_srv_net_file_enum
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;
97 ZERO_STRUCT(q_u);
98 ZERO_STRUCT(r_u);
100 /* grab the net file enum */
101 if (!srv_io_q_net_file_enum("", &q_u, data, 0))
102 return False;
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))
108 return False;
110 return True;
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;
124 ZERO_STRUCT(q_u);
125 ZERO_STRUCT(r_u);
127 /* grab the net server get enum */
128 if (!srv_io_q_net_conn_enum("", &q_u, data, 0))
129 return False;
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))
135 return False;
137 return True;
140 /*******************************************************************
141 Enumerate sessions.
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;
151 ZERO_STRUCT(q_u);
152 ZERO_STRUCT(r_u);
154 /* grab the net server get enum */
155 if (!srv_io_q_net_sess_enum("", &q_u, data, 0))
156 return False;
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))
163 return False;
165 return True;
168 /*******************************************************************
169 Delete session.
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;
179 ZERO_STRUCT(q_u);
180 ZERO_STRUCT(r_u);
182 /* grab the net server get enum */
183 if (!srv_io_q_net_sess_del("", &q_u, data, 0))
184 return False;
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))
191 return False;
193 return True;
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;
207 ZERO_STRUCT(q_u);
208 ZERO_STRUCT(r_u);
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"));
213 return False;
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"));
220 return False;
223 return True;
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;
237 ZERO_STRUCT(q_u);
238 ZERO_STRUCT(r_u);
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"));
243 return False;
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"));
250 return False;
253 return True;
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;
267 ZERO_STRUCT(q_u);
268 ZERO_STRUCT(r_u);
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"));
273 return False;
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"));
280 return False;
283 return True;
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;
297 ZERO_STRUCT(q_u);
298 ZERO_STRUCT(r_u);
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"));
303 return False;
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"));
310 return False;
313 return True;
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;
327 ZERO_STRUCT(q_u);
328 ZERO_STRUCT(r_u);
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"));
333 return False;
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"));
340 return False;
343 return True;
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;
357 ZERO_STRUCT(q_u);
358 ZERO_STRUCT(r_u);
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"));
363 return False;
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"));
370 return False;
373 return True;
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;
387 ZERO_STRUCT(q_u);
388 ZERO_STRUCT(r_u);
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"));
393 return False;
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"));
400 return False;
403 return True;
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;
417 ZERO_STRUCT(q_u);
418 ZERO_STRUCT(r_u);
420 /* grab the net server get enum */
421 if(!srv_io_q_net_remote_tod("", &q_u, data, 0))
422 return False;
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))
428 return False;
430 return True;
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;
444 ZERO_STRUCT(q_u);
445 ZERO_STRUCT(r_u);
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"));
450 return False;
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"));
457 return False;
460 return True;
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;
474 ZERO_STRUCT(q_u);
475 ZERO_STRUCT(r_u);
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"));
480 return False;
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"));
487 return False;
490 return True;
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;
504 ZERO_STRUCT(q_u);
505 ZERO_STRUCT(r_u);
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"));
510 return False;
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"));
517 return False;
520 return True;
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;
534 ZERO_STRUCT(q_u);
535 ZERO_STRUCT(r_u);
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"));
540 return False;
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"));
547 return False;
550 return True;
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 )
581 *fns = api_srv_cmds;
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));