diff options
author | Andrew Bartlett <abartlet@samba.org> | 2005-01-13 07:50:09 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 13:08:48 -0500 |
commit | 335a277662d28b935c9d84a3d7a98276afdffd3e (patch) | |
tree | ed2c17f2a44168c1e39fa63c6530eee875e41500 /source4/utils | |
parent | 025bf43aa001ef30c106a33124148c3085f96122 (diff) | |
download | samba-335a277662d28b935c9d84a3d7a98276afdffd3e.tar.gz samba-335a277662d28b935c9d84a3d7a98276afdffd3e.tar.bz2 samba-335a277662d28b935c9d84a3d7a98276afdffd3e.zip |
r4722: Start to add 'net join' to Samba4.
Andrew Bartlett
(This used to be commit a9b960609142e15ba5950eb1b22944eb6df18d9c)
Diffstat (limited to 'source4/utils')
-rw-r--r-- | source4/utils/net/config.mk | 3 | ||||
-rw-r--r-- | source4/utils/net/net.c | 2 | ||||
-rw-r--r-- | source4/utils/net/net_join.c | 108 |
3 files changed, 111 insertions, 2 deletions
diff --git a/source4/utils/net/config.mk b/source4/utils/net/config.mk index f1f6646e9c..e1bc813bec 100644 --- a/source4/utils/net/config.mk +++ b/source4/utils/net/config.mk @@ -6,7 +6,8 @@ OBJ_FILES = \ utils/net/net.o \ utils/net/net_password.o \ - utils/net/net_time.o + utils/net/net_time.o \ + utils/net/net_join.o REQUIRED_SUBSYSTEMS = \ CONFIG \ LIBCMDLINE \ diff --git a/source4/utils/net/net.c b/source4/utils/net/net.c index 022bb9225e..350ec251d9 100644 --- a/source4/utils/net/net.c +++ b/source4/utils/net/net.c @@ -139,7 +139,7 @@ static int net_help_usage(struct net_context *ctx, int argc, const char **argv) static const struct net_functable net_functable[] = { {"password", net_password, net_password_usage, net_password_help}, {"time", net_time, net_time_usage, net_time_help}, - + {"join", net_join, net_join_usage, net_join_help}, {"help", net_help, net_help_usage, net_help}, {NULL, NULL} }; diff --git a/source4/utils/net/net_join.c b/source4/utils/net/net_join.c new file mode 100644 index 0000000000..81e795a3ce --- /dev/null +++ b/source4/utils/net/net_join.c @@ -0,0 +1,108 @@ +/* + Samba Unix/Linux SMB client library + Distributed SMB/CIFS Server Management Utility + + Copyright (C) 2004 Stefan Metzmacher (metze@samba.org) + + 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. +*/ + +#include "includes.h" +#include "utils/net/net.h" +#include "libnet/libnet.h" +#include "librpc/gen_ndr/ndr_samr.h" + +static int net_join_domain(struct net_context *ctx, int argc, const char **argv) +{ + NTSTATUS status; + struct libnet_context *libnetctx; + union libnet_JoinDomain r; + char *tmp; + const char *domain_name; + + switch (argc) { + case 0: /* no args -> fail */ + DEBUG(0,("net_join_domain: no args\n")); + return -1; + case 1: /* only DOMAIN */ + tmp = talloc_strdup(ctx->mem_ctx, argv[0]); + break; + default: /* too mayn args -> fail */ + DEBUG(0,("net_join_domain: too many args [%d]\n",argc)); + return -1; + } + + domain_name = tmp; + + libnetctx = libnet_context_init(); + if (!libnetctx) { + return -1; + } + libnetctx->user.account_name = ctx->user.account_name; + libnetctx->user.domain_name = ctx->user.domain_name; + libnetctx->user.password = ctx->user.password; + + /* prepare password change */ + r.generic.level = LIBNET_JOIN_DOMAIN_GENERIC; + r.generic.in.domain_name = domain_name; + r.generic.in.account_name = talloc_asprintf(ctx->mem_ctx, "%s$", lp_netbios_name()); + r.generic.in.acct_type = ACB_SVRTRUST; + + /* do the domain join */ + status = libnet_JoinDomain(libnetctx, ctx->mem_ctx, &r); + if (!NT_STATUS_IS_OK(status)) { + DEBUG(0,("net_join_domain: %s\n",r.generic.out.error_string)); + return -1; + } + + libnet_context_destroy(&libnetctx); + + return 0; +} + +static int net_join_domain_usage(struct net_context *ctx, int argc, const char **argv) +{ + d_printf("net_join_domain_usage: TODO\n"); + return 0; +} + +static int net_join_domain_help(struct net_context *ctx, int argc, const char **argv) +{ + d_printf("net_join_domain_help: TODO\n"); + return 0; +} + +static const struct net_functable net_password_functable[] = { + {"domain", net_join_domain, net_join_domain_usage, net_join_domain_help}, + {NULL, NULL} +}; + +int net_join(struct net_context *ctx, int argc, const char **argv) +{ + + return net_run_function(ctx, argc, argv, net_password_functable, net_password_usage); +} + +int net_join_usage(struct net_context *ctx, int argc, const char **argv) +{ + d_printf("net_password_usage: TODO\n"); + return 0; +} + +int net_join_help(struct net_context *ctx, int argc, const char **argv) +{ + d_printf("net_password_help: TODO\n"); + return 0; +} |