diff options
-rw-r--r-- | source4/libnet/libnet_become_dc.c | 59 |
1 files changed, 58 insertions, 1 deletions
diff --git a/source4/libnet/libnet_become_dc.c b/source4/libnet/libnet_become_dc.c index 3bf4d38335..5cbb50055f 100644 --- a/source4/libnet/libnet_become_dc.c +++ b/source4/libnet/libnet_become_dc.c @@ -22,14 +22,69 @@ #include "libnet/libnet.h" #include "libcli/composite/composite.h" +struct libnet_BecomeDC_state { + struct libnet_context *libnet; + + struct becomeDC_ldap { + struct ldb_context *ldb; + struct ldb_message *rootdse; + } ldap1; + + struct { + const char *dns_name; + const char *netbios_name; + const char *domain_dn_str; + const char *config_dn_str; + const char *schema_dn_str; + } domain_info; + + struct { + const char *dns_name; + const char *netbios_name; + const char *address; + const char *server_dn_str; + const char *ntds_dn_str; + } source_dsa; + + struct { + const char *hostname; + } dest_dsa; +}; + + +static NTSTATUS becomeDC_ldap_connect(struct libnet_BecomeDC_state *s, struct becomeDC_ldap *ldap) +{ + return NT_STATUS_NOT_IMPLEMENTED; +} + +static NTSTATUS becomeDC_ldap1_requests(struct libnet_BecomeDC_state *s) +{ + return NT_STATUS_NOT_IMPLEMENTED; +} + struct composite_context *libnet_BecomeDC_send(struct libnet_context *ctx, TALLOC_CTX *mem_ctx, struct libnet_BecomeDC *r) { struct composite_context *c; + struct libnet_BecomeDC_state *s; c = composite_create(mem_ctx, ctx->event_ctx); if (c == NULL) return NULL; - composite_error(c, NT_STATUS_NOT_IMPLEMENTED); + s = talloc_zero(c, struct libnet_BecomeDC_state); + if (composite_nomem(s, c)) return c; + c->private_data = s; + + s->libnet = ctx; + + s->source_dsa.address = talloc_strdup(s, r->in.dest_address); + if (composite_nomem(s->source_dsa.address, c)) return c; + + c->status = becomeDC_ldap_connect(s, &s->ldap1); + if (!composite_is_ok(c)) return c; + + c->status = becomeDC_ldap1_requests(s); + if (!composite_is_ok(c)) return c; + return c; } @@ -39,6 +94,8 @@ NTSTATUS libnet_BecomeDC_recv(struct composite_context *c, TALLOC_CTX *mem_ctx, status = composite_wait(c); + ZERO_STRUCT(r->out); + talloc_free(c); return status; } |