Add NetJoinDomain call.
authorGünther Deschner <gd@samba.org>
Fri, 30 Nov 2007 17:49:21 +0000 (18:49 +0100)
committerVolker Lendecke <vl@sernet.de>
Fri, 30 Nov 2007 21:25:01 +0000 (22:25 +0100)
Guenther
(This used to be commit 08a5a036ba97d1f4830d73e95b8369aa9e6683e8)

source3/Makefile.in
source3/lib/netapi/joindomain.c [new file with mode: 0644]

index 307eabe201789178ac1481290b655934a8c4cedc..b26766958e214e82317c43d2e81aa19b90a679f2 100644 (file)
@@ -706,6 +706,8 @@ REG_API_OBJ = registry/reg_api.o \
              $(UTIL_REG_API_OBJ) \
              $(UTIL_REG_SMBCONF_OBJ)
 
+NETAPI_OBJ = lib/netapi/joindomain.o
+
 NET_OBJ1 = utils/net.o utils/net_ads.o utils/net_domain.o utils/net_help.o \
           utils/net_rap.o utils/net_rpc.o utils/net_rpc_samsync.o \
           utils/net_rpc_join.o utils/net_time.o utils/net_lookup.o \
@@ -715,7 +717,7 @@ NET_OBJ1 = utils/net.o utils/net_ads.o utils/net_domain.o utils/net_help.o \
           utils/netlookup.o utils/net_sam.o utils/net_rpc_shell.o \
           utils/net_util.o utils/net_rpc_sh_acct.o utils/net_rpc_audit.o \
           $(PASSWD_UTIL_OBJ) utils/net_dns.o utils/net_ads_gpo.o \
-          utils/net_conf.o auth/token_util.o
+          utils/net_conf.o auth/token_util.o $(NETAPI_OBJ)
 
 NET_OBJ = $(NET_OBJ1) $(PARAM_WITHOUT_REG_OBJ) $(SECRETS_OBJ) $(LIBSMB_OBJ) \
          $(RPC_PARSE_OBJ) $(PASSDB_OBJ) $(GROUPDB_OBJ) \
diff --git a/source3/lib/netapi/joindomain.c b/source3/lib/netapi/joindomain.c
new file mode 100644 (file)
index 0000000..fe05297
--- /dev/null
@@ -0,0 +1,84 @@
+/*
+ *  Unix SMB/CIFS implementation.
+ *  NetApi Join Support
+ *  Copyright (C) Guenther Deschner 2007
+ *
+ *  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 3 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "includes.h"
+#include "utils/net.h"
+
+WERROR NetJoinDomain(const char *server_name,
+                    const char *domain_name,
+                    const char *account_ou,
+                    const char *Account,
+                    const char *password,
+                    uint32_t join_flags)
+{
+       TALLOC_CTX *mem_ctx = NULL;
+       struct cli_state *cli = NULL;
+       struct rpc_pipe_client *pipe_cli = NULL;
+       struct wkssvc_PasswordBuffer encrypted_password;
+       NTSTATUS status;
+       WERROR werr;
+
+       mem_ctx = talloc_init("NetJoinDomain");
+       if (!mem_ctx) {
+               werr = WERR_NOMEM;
+               goto done;
+       }
+
+       if (!server_name || is_myname_or_ipaddr(server_name)) {
+               werr = WERR_NOT_SUPPORTED;
+               goto done;
+       }
+
+       status = net_make_ipc_connection_ex(domain_name,
+                                           server_name,
+                                           NULL, 0, &cli);
+       if (!NT_STATUS_IS_OK(status)) {
+               werr = ntstatus_to_werror(status);
+               goto done;
+       }
+
+       pipe_cli = cli_rpc_pipe_open_noauth(cli, PI_WKSSVC,
+                                           &status);
+       if (!pipe_cli) {
+               werr = ntstatus_to_werror(status);
+               goto done;
+       };
+
+       encode_wkssvc_join_password_buffer(mem_ctx,
+                                          password,
+                                          &cli->user_session_key,
+                                          &encrypted_password);
+
+       status = rpccli_wkssvc_NetrJoinDomain2(pipe_cli, mem_ctx,
+                                              server_name, domain_name,
+                                              account_ou, Account,
+                                              &encrypted_password,
+                                              join_flags);
+       if (!NT_STATUS_IS_OK(status)) {
+               werr = ntstatus_to_werror(status);
+       }
+
+       werr = WERR_OK;
+
+ done:
+       cli_shutdown(cli);
+       TALLOC_FREE(mem_ctx);
+
+       return werr;
+}