From a7ba9064d6e5446cb3d0a8d773c8f31b95667134 Mon Sep 17 00:00:00 2001 From: Michael Adam Date: Wed, 23 Jun 2010 12:18:35 +0200 Subject: s3:idmap_ldap: add idmap_rw_ops to idmap_ldap_context and init in db_init() --- source3/Makefile.in | 4 ++-- source3/winbindd/idmap_ldap.c | 11 +++++++++++ 2 files changed, 13 insertions(+), 2 deletions(-) (limited to 'source3') diff --git a/source3/Makefile.in b/source3/Makefile.in index 9feabfbced..1eb1dbb59a 100644 --- a/source3/Makefile.in +++ b/source3/Makefile.in @@ -2689,9 +2689,9 @@ bin/tdb2.@SHLIBEXT@: $(BINARY_PREREQS) winbindd/idmap_tdb2.o $(IDMAP_RW_OBJ) @echo "Building plugin $@" @$(SHLD_MODULE) winbindd/idmap_tdb2.o $(IDMAP_RW_OBJ) -bin/ldap.@SHLIBEXT@: $(BINARY_PREREQS) winbindd/idmap_ldap.o +bin/ldap.@SHLIBEXT@: $(BINARY_PREREQS) winbindd/idmap_ldap.o $(IDMAP_RW_OBJ) @echo "Building plugin $@" - @$(SHLD_MODULE) winbindd/idmap_ldap.o + @$(SHLD_MODULE) winbindd/idmap_ldap.o $(IDMAP_RW_OBJ) bin/weird.@SHLIBEXT@: $(BINARY_PREREQS) $(DEVEL_HELP_WEIRD_OBJ) @echo "Building plugin $@" diff --git a/source3/winbindd/idmap_ldap.c b/source3/winbindd/idmap_ldap.c index 995471f2b8..3223e7d223 100644 --- a/source3/winbindd/idmap_ldap.c +++ b/source3/winbindd/idmap_ldap.c @@ -26,6 +26,7 @@ #include "includes.h" #include "winbindd.h" #include "secrets.h" +#include "idmap_rw.h" #undef DBGC_CLASS #define DBGC_CLASS DBGC_IDMAP @@ -72,6 +73,7 @@ struct idmap_ldap_context { char *user_dn; bool anon; struct idmap_ldap_alloc_context *alloc; + struct idmap_rw_ops *rw_ops; }; #define CHECK_ALLOC_DONE(mem) do { \ @@ -540,6 +542,9 @@ static int idmap_ldap_close_destructor(struct idmap_ldap_context *ctx) Initialise idmap database. ********************************/ +static NTSTATUS idmap_ldap_set_mapping(struct idmap_domain *dom, + const struct id_map *map); + static NTSTATUS idmap_ldap_db_init(struct idmap_domain *dom, const char *params) { @@ -601,6 +606,12 @@ static NTSTATUS idmap_ldap_db_init(struct idmap_domain *dom, ctx->suffix = talloc_strdup(ctx, tmp); CHECK_ALLOC_DONE(ctx->suffix); + ctx->rw_ops = talloc_zero(ctx, struct idmap_rw_ops); + CHECK_ALLOC_DONE(ctx->rw_ops); + + ctx->rw_ops->get_new_id = idmap_ldap_get_new_id; + ctx->rw_ops->set_mapping = idmap_ldap_set_mapping; + ret = smbldap_init(ctx, winbind_event_context(), ctx->url, &ctx->smbldap_state); if (!NT_STATUS_IS_OK(ret)) { -- cgit