2005-01-13 07:50:09 +00:00
/*
Samba Unix / Linux SMB client library
Distributed SMB / CIFS Server Management Utility
2005-01-15 22:13:18 +00:00
Copyright ( C ) 2004 Stefan Metzmacher < metze @ samba . org >
Copyright ( C ) 2005 Andrew Bartlett < abartlet @ samba . org >
2005-01-13 07:50:09 +00:00
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
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2005-01-13 07:50:09 +00:00
( 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
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-01-13 07:50:09 +00:00
*/
# include "includes.h"
# include "utils/net/net.h"
# include "libnet/libnet.h"
2006-04-29 17:34:49 +00:00
# include "libcli/security/security.h"
2007-09-08 12:42:09 +00:00
# include "param/param.h"
2005-01-13 07:50:09 +00:00
2005-01-15 22:13:18 +00:00
int net_join ( struct net_context * ctx , int argc , const char * * argv )
2005-01-13 07:50:09 +00:00
{
NTSTATUS status ;
struct libnet_context * libnetctx ;
2005-09-25 12:26:07 +00:00
struct libnet_Join * r ;
2005-01-13 07:50:09 +00:00
char * tmp ;
const char * domain_name ;
2005-01-15 22:13:18 +00:00
enum netr_SchannelType secure_channel_type = SEC_CHAN_WKSTA ;
2005-01-13 07:50:09 +00:00
switch ( argc ) {
case 0 : /* no args -> fail */
2005-02-15 01:11:20 +00:00
return net_join_usage ( ctx , argc , argv ) ;
2005-01-13 07:50:09 +00:00
case 1 : /* only DOMAIN */
tmp = talloc_strdup ( ctx - > mem_ctx , argv [ 0 ] ) ;
break ;
2005-01-15 22:13:18 +00:00
case 2 : /* DOMAIN and role */
tmp = talloc_strdup ( ctx - > mem_ctx , argv [ 0 ] ) ;
if ( strcasecmp ( argv [ 1 ] , " BDC " ) = = 0 ) {
secure_channel_type = SEC_CHAN_BDC ;
} else if ( strcasecmp ( argv [ 1 ] , " MEMBER " ) = = 0 ) {
secure_channel_type = SEC_CHAN_WKSTA ;
} else {
2006-10-23 06:05:41 +00:00
d_fprintf ( stderr , " net_join: Invalid 2nd argument (%s) must be MEMBER or BDC \n " , argv [ 1 ] ) ;
2005-02-15 01:11:20 +00:00
return net_join_usage ( ctx , argc , argv ) ;
2005-01-15 22:13:18 +00:00
}
break ;
default : /* too many args -> fail */
2005-02-15 01:11:20 +00:00
return net_join_usage ( ctx , argc , argv ) ;
2005-01-13 07:50:09 +00:00
}
domain_name = tmp ;
2007-12-07 02:37:04 +01:00
libnetctx = libnet_context_init ( NULL , ctx - > lp_ctx ) ;
2005-01-13 07:50:09 +00:00
if ( ! libnetctx ) {
return - 1 ;
}
2005-06-03 21:30:07 +00:00
libnetctx - > cred = ctx - > credentials ;
2005-09-25 12:26:07 +00:00
r = talloc ( ctx - > mem_ctx , struct libnet_Join ) ;
if ( ! r ) {
return - 1 ;
}
2005-12-22 06:58:26 +00:00
/* prepare parameters for the join */
2007-12-04 19:33:00 +01:00
r - > in . netbios_name = lp_netbios_name ( ctx - > lp_ctx ) ;
2005-09-25 12:26:07 +00:00
r - > in . domain_name = domain_name ;
2006-01-13 02:58:35 +00:00
r - > in . join_type = secure_channel_type ;
2005-09-25 12:26:07 +00:00
r - > in . level = LIBNET_JOIN_AUTOMATIC ;
r - > out . error_string = NULL ;
2005-01-13 07:50:09 +00:00
/* do the domain join */
2005-09-25 12:26:07 +00:00
status = libnet_Join ( libnetctx , r , r ) ;
2005-12-22 06:47:00 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2006-01-26 01:59:07 +00:00
d_fprintf ( stderr , " Joining domain failed: %s \n " ,
r - > out . error_string ? r - > out . error_string : nt_errstr ( status ) ) ;
2005-09-25 12:26:07 +00:00
talloc_free ( r ) ;
talloc_free ( libnetctx ) ;
2005-01-13 07:50:09 +00:00
return - 1 ;
}
2005-12-22 06:58:26 +00:00
d_printf ( " Joined domain %s (%s) \n " , r - > out . domain_name , dom_sid_string ( ctx - > mem_ctx , r - > out . domain_sid ) ) ;
2005-06-16 11:36:09 +00:00
talloc_free ( libnetctx ) ;
2005-01-13 07:50:09 +00:00
return 0 ;
}
int net_join_usage ( struct net_context * ctx , int argc , const char * * argv )
{
2005-02-15 01:11:20 +00:00
d_printf ( " net join <domain> [BDC | MEMBER] [options] \n " ) ;
2005-01-13 07:50:09 +00:00
return 0 ;
}
int net_join_help ( struct net_context * ctx , int argc , const char * * argv )
{
2005-02-15 01:11:20 +00:00
d_printf ( " Joins domain as either member or backup domain controller. \n " ) ;
2005-01-13 07:50:09 +00:00
return 0 ;
}
2008-04-09 14:59:32 +10:00
int net_vampire ( struct net_context * ctx , int argc , const char * * argv )
{
NTSTATUS status ;
struct libnet_context * libnetctx ;
struct libnet_Vampire * r ;
char * tmp , * targetdir = NULL ;
const char * domain_name ;
switch ( argc ) {
case 0 : /* no args -> fail */
return net_vampire_usage ( ctx , argc , argv ) ;
case 1 : /* only DOMAIN */
tmp = talloc_strdup ( ctx - > mem_ctx , argv [ 0 ] ) ;
break ;
case 2 : /* domain and target dir */
tmp = talloc_strdup ( ctx - > mem_ctx , argv [ 0 ] ) ;
targetdir = talloc_strdup ( ctx - > mem_ctx , argv [ 1 ] ) ;
break ;
default : /* too many args -> fail */
return net_vampire_usage ( ctx , argc , argv ) ;
}
domain_name = tmp ;
libnetctx = libnet_context_init ( NULL , ctx - > lp_ctx ) ;
if ( ! libnetctx ) {
return - 1 ;
}
libnetctx - > cred = ctx - > credentials ;
r = talloc ( ctx - > mem_ctx , struct libnet_Vampire ) ;
if ( ! r ) {
return - 1 ;
}
/* prepare parameters for the vampire */
r - > in . netbios_name = lp_netbios_name ( ctx - > lp_ctx ) ;
r - > in . domain_name = domain_name ;
r - > in . targetdir = targetdir ;
r - > out . error_string = NULL ;
/* do the domain vampire */
status = libnet_Vampire ( libnetctx , r , r ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_fprintf ( stderr , " Vampire of domain failed: %s \n " ,
r - > out . error_string ? r - > out . error_string : nt_errstr ( status ) ) ;
talloc_free ( r ) ;
talloc_free ( libnetctx ) ;
return - 1 ;
}
d_printf ( " Vampired domain %s (%s) \n " , r - > out . domain_name , dom_sid_string ( ctx - > mem_ctx , r - > out . domain_sid ) ) ;
talloc_free ( libnetctx ) ;
return 0 ;
}
int net_vampire_usage ( struct net_context * ctx , int argc , const char * * argv )
{
d_printf ( " net vampire <domain> [options] \n " ) ;
return 0 ;
}
int net_vampire_help ( struct net_context * ctx , int argc , const char * * argv )
{
d_printf ( " Vampires domain as either member or backup domain controller. \n " ) ;
return 0 ;
}