summaryrefslogtreecommitdiff
path: root/source3
diff options
context:
space:
mode:
Diffstat (limited to 'source3')
-rw-r--r--source3/lib/netapi/joindomain.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/source3/lib/netapi/joindomain.c b/source3/lib/netapi/joindomain.c
index 7c71276de6..29766e5994 100644
--- a/source3/lib/netapi/joindomain.c
+++ b/source3/lib/netapi/joindomain.c
@@ -35,6 +35,8 @@ WERROR NetJoinDomain(const char *server_name,
WERROR werr;
unsigned int old_timeout;
+ ZERO_STRUCT(encrypted_password);
+
mem_ctx = talloc_init("NetJoinDomain");
if (!mem_ctx) {
werr = WERR_NOMEM;
@@ -68,10 +70,12 @@ WERROR NetJoinDomain(const char *server_name,
goto done;
};
- encode_wkssvc_join_password_buffer(mem_ctx,
- password,
- &cli->user_session_key,
- &encrypted_password);
+ if (password) {
+ encode_wkssvc_join_password_buffer(mem_ctx,
+ password,
+ &cli->user_session_key,
+ &encrypted_password);
+ }
old_timeout = cli_set_timeout(cli, 60000);
@@ -82,13 +86,16 @@ WERROR NetJoinDomain(const char *server_name,
join_flags);
if (!NT_STATUS_IS_OK(status)) {
werr = ntstatus_to_werror(status);
+ goto done;
}
werr = WERR_OK;
done:
- cli_set_timeout(cli, old_timeout);
- cli_shutdown(cli);
+ if (cli) {
+ cli_set_timeout(cli, old_timeout);
+ cli_shutdown(cli);
+ }
TALLOC_FREE(mem_ctx);
return werr;