/**
* Creates new dsdb_schema_info object using
* invocationId from supplied ldb
+ * @param check_invocation_id Error out if invocationId is not yet set
*/
-WERROR dsdb_schema_info_create(struct ldb_context *ldb, TALLOC_CTX *mem_ctx, struct dsdb_schema_info **_schema_info)
+WERROR dsdb_schema_info_create(struct ldb_context *ldb, bool check_invocation_id,
+ TALLOC_CTX *mem_ctx, struct dsdb_schema_info **_schema_info)
{
const struct GUID *invocation_id;
struct dsdb_schema_info *schema_info;
/* try to determine invocationId from ldb */
invocation_id = samdb_ntds_invocation_id(ldb);
+ if (check_invocation_id && !invocation_id) {
+ return WERR_INTERNAL_DB_CORRUPTION;
+ }
schema_info = talloc(mem_ctx, struct dsdb_schema_info);
if (!schema_info) {
if (!info_val) {
struct dsdb_schema_info *schema_info;
- status = dsdb_schema_info_create(ldb, mem_ctx, &schema_info);
+ status = dsdb_schema_info_create(ldb, false, mem_ctx, &schema_info);
if (!W_ERROR_IS_OK(status)) {
*error_string = talloc_asprintf(mem_ctx,
"schema_fsmo_init: dsdb_schema_info_create() failed - %s",
info_val = ldb_msg_find_ldb_val(msg, "schemaInfo");
if (!info_val) {
- status = dsdb_schema_info_create(ldb, mem_ctx, &schema_info);
+ status = dsdb_schema_info_create(ldb, false, mem_ctx, &schema_info);
W_ERROR_NOT_OK_GOTO(status, failed);
status = dsdb_blob_from_schema_info(schema_info, mem_ctx, &info_val_default);
W_ERROR_NOT_OK_GOTO(status, failed);
WERROR werr;
struct dsdb_schema_info *schema_info = NULL;
- werr = dsdb_schema_info_create(priv->ldb, priv, &schema_info);
+ werr = dsdb_schema_info_create(priv->ldb, true, priv, &schema_info);
torture_assert_werr_ok(tctx, werr, "dsdb_schema_info_create() failed");
torture_assert(tctx, schema_info, "schema_info is NULL after dsdb_schema_info_create()");