r23779: Change from v2 or later to v3 or later.
[samba.git] / source3 / rpc_server / srv_wkssvc_nt.c
index 81d3e1ef8f09c1f81d40161532d44e369cdc3871..51080fbd0f4b21835739612b23d5122cbd5cf740 100644 (file)
@@ -1,16 +1,13 @@
-#define OLD_NTDOMAIN 1
 /* 
- *  Unix SMB/Netbios implementation.
- *  Version 1.9.
+ *  Unix SMB/CIFS implementation.
  *  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.
+ *
+ *  Copyright (C) Andrew Tridgell              1992-1997,
+ *  Copyright (C) Gerald (Jerry) Carter                2006.
  *  
  *  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
+ *  the Free Software Foundation; either version 3 of the License, or
  *  (at your option) any later version.
  *  
  *  This program is distributed in the hope that it will be useful,
 
 #include "includes.h"
 
-extern int DEBUGLEVEL;
-extern pstring global_myname;
+#undef DBGC_CLASS
+#define DBGC_CLASS DBGC_RPC_SRV
 
 /*******************************************************************
- create_wks_info_100
+ Fill in the valiues for the struct wkssvc_NetWkstaInfo100.
  ********************************************************************/
 
-static void create_wks_info_100(WKS_INFO_100 *inf)
+static void create_wks_info_100(struct wkssvc_NetWkstaInfo100 *info100)
 {
        pstring my_name;
        pstring domain;
 
-       DEBUG(5,("create_wks_info_100: %d\n", __LINE__));
-
-       pstrcpy (my_name, global_myname);
-       strupper(my_name);
+       pstrcpy (my_name, global_myname());
+       strupper_m(my_name);
 
        pstrcpy (domain, lp_workgroup());
-       strupper(domain);
+       strupper_m(domain);
+       
+       info100->platform_id     = 0x000001f4;  /* unknown */
+       info100->version_major   = lp_major_announce_version(); 
+       info100->version_minor   = lp_minor_announce_version();   
+
+       info100->server_name = talloc_strdup( info100, my_name );
+       info100->domain_name = talloc_strdup( info100, 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));
+       return;
 }
 
-/*******************************************************************
- wks_reply_query_info
+/********************************************************************
  only supports info level 100 at the moment.
+ ********************************************************************/
+
+WERROR _wkssvc_NetWkstaGetInfo( pipes_struct *p, struct wkssvc_NetWkstaGetInfo *r)
+{
+       struct wkssvc_NetWkstaInfo100 *wks100 = NULL;
+       
+       /* We only support info level 100 currently */
+       
+       if ( r->in.level != 100 ) {
+               return WERR_UNKNOWN_LEVEL;
+       }
+
+       if ( (wks100 = TALLOC_ZERO_P(p->mem_ctx, struct wkssvc_NetWkstaInfo100)) == NULL ) {
+               return WERR_NOMEM;
+       }
+
+       create_wks_info_100( wks100 );
+       
+       r->out.info->info100 = wks100;
+
+       return WERR_OK;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetWkstaSetInfo( pipes_struct *p, struct wkssvc_NetWkstaSetInfo *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetWkstaEnumUsers( pipes_struct *p, struct wkssvc_NetWkstaEnumUsers *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRWKSTAUSERGETINFO( pipes_struct *p, struct WKSSVC_NETRWKSTAUSERGETINFO *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRWKSTAUSERSETINFO( pipes_struct *p, struct WKSSVC_NETRWKSTAUSERSETINFO *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetWkstaTransportEnum( pipes_struct *p, struct wkssvc_NetWkstaTransportEnum *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRWKSTATRANSPORTADD( pipes_struct *p, struct WKSSVC_NETRWKSTATRANSPORTADD *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRWKSTATRANSPORTDEL( pipes_struct *p, struct WKSSVC_NETRWKSTATRANSPORTDEL *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRUSEADD( pipes_struct *p, struct WKSSVC_NETRUSEADD *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRUSEGETINFO( pipes_struct *p, struct WKSSVC_NETRUSEGETINFO *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRUSEDEL( pipes_struct *p, struct WKSSVC_NETRUSEDEL *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRUSEENUM( pipes_struct *p, struct WKSSVC_NETRUSEENUM *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRMESSAGEBUFFERSEND( pipes_struct *p, struct WKSSVC_NETRMESSAGEBUFFERSEND *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRWORKSTATIONSTATISTICSGET( pipes_struct *p, struct WKSSVC_NETRWORKSTATIONSTATISTICSGET *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRLOGONDOMAINNAMEADD( pipes_struct *p, struct WKSSVC_NETRLOGONDOMAINNAMEADD *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRLOGONDOMAINNAMEDEL( pipes_struct *p, struct WKSSVC_NETRLOGONDOMAINNAMEDEL *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRJOINDOMAIN( pipes_struct *p, struct WKSSVC_NETRJOINDOMAIN *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRUNJOINDOMAIN( pipes_struct *p, struct WKSSVC_NETRUNJOINDOMAIN *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRRENAMEMACHINEINDOMAIN( pipes_struct *p, struct WKSSVC_NETRRENAMEMACHINEINDOMAIN *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRVALIDATENAME( pipes_struct *p, struct WKSSVC_NETRVALIDATENAME *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRGETJOININFORMATION( pipes_struct *p, struct WKSSVC_NETRGETJOININFORMATION *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRGETJOINABLEOUS( pipes_struct *p, struct WKSSVC_NETRGETJOINABLEOUS *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetrJoinDomain2(pipes_struct *p, struct wkssvc_NetrJoinDomain2 *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetrUnjoinDomain2(pipes_struct *p, struct wkssvc_NetrUnjoinDomain2 *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _wkssvc_NetrRenameMachineInDomain2(pipes_struct *p, struct wkssvc_NetrRenameMachineInDomain2 *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRVALIDATENAME2( pipes_struct *p, struct WKSSVC_NETRVALIDATENAME2 *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
 
+/********************************************************************
  ********************************************************************/
 
-uint32 _wks_query_info(pipes_struct *p, WKS_Q_QUERY_INFO *q_u, WKS_R_QUERY_INFO *r_u)
+WERROR _WKSSVC_NETRGETJOINABLEOUS2( pipes_struct *p, struct WKSSVC_NETRGETJOINABLEOUS2 *r )
 {
-       WKS_INFO_100 wks100;
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
 
-       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);
+WERROR _wkssvc_NetrAddAlternateComputerName(pipes_struct *p, struct wkssvc_NetrAddAlternateComputerName *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
 
-       DEBUG(5,("_wks_query_info: %d\n", __LINE__));
+/********************************************************************
+ ********************************************************************/
 
-       return r_u->status;
+WERROR _wkssvc_NetrRemoveAlternateComputerName(pipes_struct *p, struct wkssvc_NetrRemoveAlternateComputerName *r)
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
 }
-#undef OLD_NTDOMAIN
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRSETPRIMARYCOMPUTERNAME( pipes_struct *p, struct WKSSVC_NETRSETPRIMARYCOMPUTERNAME *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+
+/********************************************************************
+ ********************************************************************/
+
+WERROR _WKSSVC_NETRENUMERATECOMPUTERNAMES( pipes_struct *p, struct WKSSVC_NETRENUMERATECOMPUTERNAMES *r )
+{
+       /* FIXME: Add implementation code here */
+       p->rng_fault_state = True;
+       return WERR_NOT_SUPPORTED;
+}
+