diff options
author | Jeremy Allison <jra@samba.org> | 2001-02-26 20:06:12 +0000 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2001-02-26 20:06:12 +0000 |
commit | 1ee0f29e382856e87f3c7ad593423c8dee238475 (patch) | |
tree | 886b5bd5a7354940ed56fb8accfdd23bb2c5dacd | |
parent | fc63aa0a4544913f23334623812f658089f00e3d (diff) | |
download | samba-1ee0f29e382856e87f3c7ad593423c8dee238475.tar.gz |
Split wks pipe into interface and implementation modules.
Jeremy.
-rw-r--r-- | source/Makefile.in | 2 | ||||
-rw-r--r-- | source/rpc_server/srv_wkssvc.c | 64 | ||||
-rw-r--r-- | source/rpc_server/srv_wkssvc_nt.c | 75 |
3 files changed, 87 insertions, 54 deletions
diff --git a/source/Makefile.in b/source/Makefile.in index e634b9ab835..3333e5e7147 100644 --- a/source/Makefile.in +++ b/source/Makefile.in @@ -131,7 +131,7 @@ RPC_SERVER_OBJ = rpc_server/srv_lsa.o rpc_server/srv_lsa_nt.o \ rpc_server/srv_lsa_hnd.o rpc_server/srv_netlog.o \ rpc_server/srv_pipe_hnd.o rpc_server/srv_reg.o rpc_server/srv_reg_nt.o \ rpc_server/srv_samr.o rpc_server/srv_samr_nt.o rpc_server/srv_srvsvc.o \ - rpc_server/srv_util.o rpc_server/srv_wkssvc.o \ + rpc_server/srv_util.o rpc_server/srv_wkssvc.o rpc_server/srv_wkssvc_nt.o \ rpc_server/srv_pipe.o rpc_server/srv_dfs.o \ rpc_server/srv_spoolss.o rpc_server/srv_spoolss_nt.o diff --git a/source/rpc_server/srv_wkssvc.c b/source/rpc_server/srv_wkssvc.c index c54052d2403..12e4a8f3359 100644 --- a/source/rpc_server/srv_wkssvc.c +++ b/source/rpc_server/srv_wkssvc.c @@ -21,76 +21,34 @@ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ +/* This is the interface to the wks pipe. */ + #include "includes.h" extern int DEBUGLEVEL; -extern pstring global_myname; - -/******************************************************************* - create_wks_info_100 - ********************************************************************/ -static void create_wks_info_100(WKS_INFO_100 *inf) -{ - pstring my_name; - pstring domain; - - DEBUG(5,("create_wks_info_100: %d\n", __LINE__)); - - pstrcpy (my_name, global_myname); - strupper(my_name); - - pstrcpy (domain, lp_workgroup()); - strupper(domain); - - init_wks_info_100(inf, - 0x000001f4, /* platform id info */ - lp_major_announce_version(), - lp_minor_announce_version(), - my_name, unix_to_dos(domain,False)); -} - -/******************************************************************* - wks_reply_query_info - - only supports info level 100 at the moment. - - ********************************************************************/ -static BOOL wks_reply_query_info(WKS_Q_QUERY_INFO *q_u, - prs_struct *rdata, - int status) -{ - WKS_R_QUERY_INFO r_u; - WKS_INFO_100 wks100; - - DEBUG(5,("wks_query_info: %d\n", __LINE__)); - - create_wks_info_100(&wks100); - init_wks_r_query_info(&r_u, q_u->switch_value, &wks100, status); - - /* store the response in the SMB stream */ - if(!wks_io_r_query_info("", &r_u, rdata, 0)) - return False; - - DEBUG(5,("wks_query_info: %d\n", __LINE__)); - - return True; -} /******************************************************************* api_wks_query_info ********************************************************************/ + static BOOL api_wks_query_info(pipes_struct *p) { WKS_Q_QUERY_INFO q_u; + WKS_R_QUERY_INFO r_u; prs_struct *data = &p->in_data.data; prs_struct *rdata = &p->out_data.rdata; + ZERO_STRUCT(q_u); + ZERO_STRUCT(r_u); + /* grab the net share enum */ if(!wks_io_q_query_info("", &q_u, data, 0)) return False; - /* construct reply. always indicate success */ - if(!wks_reply_query_info(&q_u, rdata, 0x0)) + r_u.status = _wks_query_info(p, &q_u, &r_u); + + /* store the response in the SMB stream */ + if(!wks_io_r_query_info("", &r_u, rdata, 0)) return False; return True; diff --git a/source/rpc_server/srv_wkssvc_nt.c b/source/rpc_server/srv_wkssvc_nt.c new file mode 100644 index 00000000000..54a9a96e865 --- /dev/null +++ b/source/rpc_server/srv_wkssvc_nt.c @@ -0,0 +1,75 @@ +/* + * Unix SMB/Netbios implementation. + * Version 1.9. + * RPC Pipe client / server routines + * Copyright (C) Andrew Tridgell 1992-1997, + * Copyright (C) Luke Kenneth Casson Leighton 1996-1997, + * Copyright (C) Paul Ashton 1997. + * Copyright (C) Jeremy Allison 2001. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +/* This is the implementation of the wks interface. */ + +#include "includes.h" + +extern int DEBUGLEVEL; +extern pstring global_myname; + +/******************************************************************* + create_wks_info_100 + ********************************************************************/ + +static void create_wks_info_100(WKS_INFO_100 *inf) +{ + pstring my_name; + pstring domain; + + DEBUG(5,("create_wks_info_100: %d\n", __LINE__)); + + pstrcpy (my_name, global_myname); + strupper(my_name); + + pstrcpy (domain, lp_workgroup()); + strupper(domain); + + init_wks_info_100(inf, + 0x000001f4, /* platform id info */ + lp_major_announce_version(), + lp_minor_announce_version(), + my_name, unix_to_dos(domain,False)); +} + +/******************************************************************* + wks_reply_query_info + + only supports info level 100 at the moment. + + ********************************************************************/ + +uint32 _wks_query_info(pipes_struct *p, WKS_Q_QUERY_INFO *q_u, WKS_R_QUERY_INFO *r_u) +{ + WKS_INFO_100 wks100; + + DEBUG(5,("_wks_query_info: %d\n", __LINE__)); + + create_wks_info_100(&wks100); + init_wks_r_query_info(r_u, q_u->switch_value, &wks100, NT_STATUS_NOPROBLEMO); + + DEBUG(5,("_wks_query_info: %d\n", __LINE__)); + + return r_u->status; +} |