diff options
author | Rafal Szczesniak <mimir@samba.org> | 2006-09-05 18:45:03 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:17:17 -0500 |
commit | 0f0879eacfbef649509f3e2e56d445f1f8efecef (patch) | |
tree | 8c88c527b714ac2ed962a5e343e5af97b3d805da | |
parent | 6d362bdb7cdbd6fb062b1b8697b5fa00dc88f631 (diff) | |
download | samba-0f0879eacfbef649509f3e2e56d445f1f8efecef.tar.gz samba-0f0879eacfbef649509f3e2e56d445f1f8efecef.tar.bz2 samba-0f0879eacfbef649509f3e2e56d445f1f8efecef.zip |
r18104: A couple of important fixes to samr domain open so that
the corresponding test may pass.
rafal
(This used to be commit f0eb209e8478f08e36fa38ae199cfa753f9a8255)
-rw-r--r-- | source4/libnet/libnet_domain.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/source4/libnet/libnet_domain.c b/source4/libnet/libnet_domain.c index 806d9d0fd1..57c0ce6571 100644 --- a/source4/libnet/libnet_domain.c +++ b/source4/libnet/libnet_domain.c @@ -267,7 +267,7 @@ struct composite_context *libnet_DomainOpenSamr_send(struct libnet_context *ctx, s->ctx = ctx; s->pipe = ctx->samr.pipe; s->access_mask = io->in.access_mask; - s->domain_name.string = io->in.domain_name; + s->domain_name.string = talloc_strdup(c, io->in.domain_name); /* check, if there's samr pipe opened already, before opening a domain */ if (ctx->samr.pipe == NULL) { @@ -360,7 +360,7 @@ NTSTATUS libnet_DomainOpenSamr_recv(struct composite_context *c, struct libnet_c /* store the resulting handle and related data for use by other libnet functions */ ctx->samr.handle = s->domain_handle; - ctx->samr.name = talloc_strdup(ctx, s->domain_name.string); + ctx->samr.name = talloc_steal(ctx, s->domain_name.string); ctx->samr.access_mask = s->access_mask; } @@ -739,6 +739,7 @@ NTSTATUS libnet_DomainCloseLsa_recv(struct composite_context *c, struct libnet_c struct domain_close_samr_state { struct samr_Close close; + struct policy_handle handle; void (*monitor_fn)(struct monitor_msg*); }; @@ -773,7 +774,9 @@ struct composite_context* libnet_DomainCloseSamr_send(struct libnet_context *ctx } /* prepare close domain handle call arguments */ - s->close.in.handle = &ctx->samr.handle; + ZERO_STRUCT(s->close); + s->close.in.handle = &ctx->samr.handle; + s->close.out.handle = &s->handle; /* send the request */ close_req = dcerpc_samr_Close_send(ctx->samr.pipe, ctx, &s->close); |