s4:dsdb/schema: pass and remember the schema_dn in dsdb_set_schema_from_ldif()
authorStefan Metzmacher <metze@samba.org>
Fri, 11 Nov 2011 15:35:59 +0000 (16:35 +0100)
committerStefan Metzmacher <metze@samba.org>
Tue, 15 Nov 2011 08:46:27 +0000 (09:46 +0100)
metze

source4/dsdb/pydsdb.c
source4/dsdb/schema/schema_set.c

index 62b5c8db838f18c3bc29bcc335bcb545ec6bdeb9..3c7c8bfaa12c439a153453d1d4a03bed32812ac9 100644 (file)
@@ -838,7 +838,7 @@ static PyObject *py_dsdb_set_schema_from_ldif(PyObject *self, PyObject *args)
 
        PyErr_LDB_OR_RAISE(py_ldb, ldb);
 
-       result = dsdb_set_schema_from_ldif(ldb, pf, df);
+       result = dsdb_set_schema_from_ldif(ldb, pf, df, dn);
        PyErr_WERROR_IS_ERR_RAISE(result);
 
        Py_RETURN_NONE;
index 18f3ab7b7cc79f895a6fa7b8bf0362a27d8314f9..6f735db48629edca286fa9175bbf599c8f408e32 100644 (file)
@@ -683,7 +683,9 @@ WERROR dsdb_schema_set_el_from_ldb_msg(struct ldb_context *ldb, struct dsdb_sche
  * schema itself to the directory.
  */
 
-WERROR dsdb_set_schema_from_ldif(struct ldb_context *ldb, const char *pf, const char *df)
+WERROR dsdb_set_schema_from_ldif(struct ldb_context *ldb,
+                                const char *pf, const char *df,
+                                const char *dn)
 {
        struct ldb_ldif *ldif;
        struct ldb_message *msg;
@@ -702,9 +704,15 @@ WERROR dsdb_set_schema_from_ldif(struct ldb_context *ldb, const char *pf, const
        }
 
        schema = dsdb_new_schema(mem_ctx);
-
+       if (!schema) {
+               goto nomem;
+       }
+       schema->base_dn = ldb_dn_new(schema, ldb, dn);
+       if (!schema->base_dn) {
+               goto nomem;
+       }
        schema->fsmo.we_are_master = true;
-       schema->fsmo.master_dn = ldb_dn_new_fmt(schema, ldb, "@PROVISION_SCHEMA_MASTER");
+       schema->fsmo.master_dn = ldb_dn_new(schema, ldb, "@PROVISION_SCHEMA_MASTER");
        if (!schema->fsmo.master_dn) {
                goto nomem;
        }