summaryrefslogtreecommitdiff
path: root/source3/rpc_server
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2001-02-26 20:06:25 +0000
committerJeremy Allison <jra@samba.org>2001-02-26 20:06:25 +0000
commit95731132dc3cb78a41fc83c68af0f0168f07f246 (patch)
treee1c8918035afa476b2668eb2dd8690eb86fd701e /source3/rpc_server
parentd757d61abfd028f9088ef133100d4c6aebce3fc6 (diff)
downloadsamba-95731132dc3cb78a41fc83c68af0f0168f07f246.tar.gz
samba-95731132dc3cb78a41fc83c68af0f0168f07f246.tar.bz2
samba-95731132dc3cb78a41fc83c68af0f0168f07f246.zip
Split wks pipe into interface and implementation modules.
Jeremy. (This used to be commit 6a16b3850fdc4d6750ef2046f1db934f1ef92f17)
Diffstat (limited to 'source3/rpc_server')
-rw-r--r--source3/rpc_server/srv_wkssvc.c64
-rw-r--r--source3/rpc_server/srv_wkssvc_nt.c77
2 files changed, 88 insertions, 53 deletions
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