From 95731132dc3cb78a41fc83c68af0f0168f07f246 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Mon, 26 Feb 2001 20:06:25 +0000 Subject: Split wks pipe into interface and implementation modules. Jeremy. (This used to be commit 6a16b3850fdc4d6750ef2046f1db934f1ef92f17) --- source3/rpc_server/srv_wkssvc.c | 64 ++++++------------------------- source3/rpc_server/srv_wkssvc_nt.c | 77 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 88 insertions(+), 53 deletions(-) create mode 100644 source3/rpc_server/srv_wkssvc_nt.c (limited to 'source3/rpc_server') diff --git a/source3/rpc_server/srv_wkssvc.c b/source3/rpc_server/srv_wkssvc.c index d1e0c8e8eb..e648c0f122 100644 --- a/source3/rpc_server/srv_wkssvc.c +++ b/source3/rpc_server/srv_wkssvc.c @@ -22,76 +22,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/source3/rpc_server/srv_wkssvc_nt.c b/source3/rpc_server/srv_wkssvc_nt.c new file mode 100644 index 0000000000..81d3e1ef8f --- /dev/null +++ b/source3/rpc_server/srv_wkssvc_nt.c @@ -0,0 +1,77 @@ +#define OLD_NTDOMAIN 1 +/* + * 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; +} +#undef OLD_NTDOMAIN -- cgit