diff options
Diffstat (limited to 'source4/torture/rpc')
-rw-r--r-- | source4/torture/rpc/dssync.c | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/source4/torture/rpc/dssync.c b/source4/torture/rpc/dssync.c index c601b08248..eb90871c0e 100644 --- a/source4/torture/rpc/dssync.c +++ b/source4/torture/rpc/dssync.c @@ -417,10 +417,15 @@ static void test_analyse_objects(struct DsSyncTest *ctx, const DATA_BLOB *gensec_skey, struct drsuapi_DsReplicaObjectListItemEx *cur) { - if (!lp_parm_bool(-1,"dssync","print_pwd_blobs",False)) { + static uint32_t object_id; + const char *save_values_dir; + + if (!lp_parm_bool(-1,"dssync","print_pwd_blobs", false)) { return; } + save_values_dir = lp_parm_string(-1,"dssync","save_pwd_blobs_dir"); + for (; cur; cur = cur->next_object) { const char *dn; struct dom_sid *sid = NULL; @@ -497,13 +502,28 @@ static void test_analyse_objects(struct DsSyncTest *ctx, cur->object.identifier, rid, enc_data); if (!dn_printed) { - DEBUG(0,("DN: %s\n", dn)); + object_id++; + DEBUG(0,("DN[%u] %s\n", object_id, dn)); dn_printed = True; } DEBUGADD(0,("ATTR: %s enc.length=%lu plain.length=%lu\n", name, (long)enc_data->length, (long)plain_data.length)); if (plain_data.length) { dump_data(0, plain_data.data, plain_data.length); + if (save_values_dir) { + char *fname; + fname = talloc_asprintf(ctx, "%s/%s%02d", + save_values_dir, + name, object_id); + if (fname) { + bool ok; + ok = file_save(fname, plain_data.data, plain_data.length); + if (!ok) { + DEBUGADD(0,("Failed to save '%s'\n", fname)); + } + } + talloc_free(fname); + } } else { dump_data(0, enc_data->data, enc_data->length); } |