summaryrefslogtreecommitdiff
path: root/source3/lib/netapi
diff options
context:
space:
mode:
authorGünther Deschner <gd@samba.org>2007-11-30 18:49:21 +0100
committerVolker Lendecke <vl@sernet.de>2007-11-30 22:25:01 +0100
commita51e682a21b42cc518e9f3fdbcfa86a9a881ead0 (patch)
tree9cb06f8717315ad65d5c31eda7f7d541228af347 /source3/lib/netapi
parent4b9f336a62cd4992956a68c8a17764a3f768b3f1 (diff)
downloadsamba-a51e682a21b42cc518e9f3fdbcfa86a9a881ead0.tar.gz
samba-a51e682a21b42cc518e9f3fdbcfa86a9a881ead0.tar.bz2
samba-a51e682a21b42cc518e9f3fdbcfa86a9a881ead0.zip
Add NetJoinDomain call.
Guenther (This used to be commit 08a5a036ba97d1f4830d73e95b8369aa9e6683e8)
Diffstat (limited to 'source3/lib/netapi')
-rw-r--r--source3/lib/netapi/joindomain.c84
1 files changed, 84 insertions, 0 deletions
diff --git a/source3/lib/netapi/joindomain.c b/source3/lib/netapi/joindomain.c
new file mode 100644
index 0000000000..fe05297ee1
--- /dev/null
+++ b/source3/lib/netapi/joindomain.c
@@ -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;
+}