diff options
author | Stefan Metzmacher <metze@samba.org> | 2013-06-05 09:35:42 +0200 |
---|---|---|
committer | Stefan Metzmacher <metze@samba.org> | 2013-07-30 08:36:51 +0200 |
commit | a796cad90f1028ccc54a3539e34dc0728b990a96 (patch) | |
tree | 32012c7e32e9b302f0b57e065fe9897a02857a3f /source4/dsdb/samdb | |
parent | d3aad891c5759f66bd891cb47866d908a0562a8a (diff) | |
download | samba-a796cad90f1028ccc54a3539e34dc0728b990a96.tar.gz samba-a796cad90f1028ccc54a3539e34dc0728b990a96.tar.bz2 samba-a796cad90f1028ccc54a3539e34dc0728b990a96.zip |
dsdb/repl_meta_data: split out replmd_deletion_state()
Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Diffstat (limited to 'source4/dsdb/samdb')
-rw-r--r-- | source4/dsdb/samdb/ldb_modules/repl_meta_data.c | 102 |
1 files changed, 71 insertions, 31 deletions
diff --git a/source4/dsdb/samdb/ldb_modules/repl_meta_data.c b/source4/dsdb/samdb/ldb_modules/repl_meta_data.c index 813438d739..5f15ece762 100644 --- a/source4/dsdb/samdb/ldb_modules/repl_meta_data.c +++ b/source4/dsdb/samdb/ldb_modules/repl_meta_data.c @@ -105,6 +105,70 @@ enum urgent_situation { REPL_URGENT_ON_DELETE = 4 }; +enum deletion_state { + OBJECT_NOT_DELETED=1, + OBJECT_DELETED=2, + OBJECT_RECYCLED=3, + OBJECT_TOMBSTONE=4, + OBJECT_REMOVED=5 +}; + +static void replmd_deletion_state(struct ldb_module *module, + const struct ldb_message *msg, + enum deletion_state *current_state, + enum deletion_state *next_state) +{ + int ret; + bool enabled = false; + + if (msg == NULL) { + *current_state = OBJECT_REMOVED; + if (next_state != NULL) { + *next_state = OBJECT_REMOVED; + } + return; + } + + ret = dsdb_recyclebin_enabled(module, &enabled); + if (ret != LDB_SUCCESS) { + enabled = false; + } + + if (ldb_msg_check_string_attribute(msg, "isDeleted", "TRUE")) { + if (!enabled) { + *current_state = OBJECT_TOMBSTONE; + if (next_state != NULL) { + *next_state = OBJECT_REMOVED; + } + return; + } + + if (ldb_msg_check_string_attribute(msg, "isRecycled", "TRUE")) { + *current_state = OBJECT_RECYCLED; + if (next_state != NULL) { + *next_state = OBJECT_REMOVED; + } + return; + } + + *current_state = OBJECT_DELETED; + if (next_state != NULL) { + *next_state = OBJECT_RECYCLED; + } + return; + } + + *current_state = OBJECT_NOT_DELETED; + if (next_state == NULL) { + return; + } + + if (enabled) { + *next_state = OBJECT_DELETED; + } else { + *next_state = OBJECT_TOMBSTONE; + } +} static const struct { const char *update_name; @@ -2852,8 +2916,6 @@ static int replmd_delete_internals(struct ldb_module *module, struct ldb_request "trustType", "trustAttributes", "userAccountControl", "uSNChanged", "uSNCreated", "whenCreated", "whenChanged", NULL}; unsigned int i, el_count = 0; - enum deletion_state { OBJECT_NOT_DELETED=1, OBJECT_DELETED=2, OBJECT_RECYCLED=3, - OBJECT_TOMBSTONE=4, OBJECT_REMOVED=5 }; enum deletion_state deletion_state, next_deletion_state; bool enabled; @@ -2893,36 +2955,14 @@ static int replmd_delete_internals(struct ldb_module *module, struct ldb_request } old_msg = res->msgs[0]; + replmd_deletion_state(module, old_msg, + &deletion_state, + &next_deletion_state); - ret = dsdb_recyclebin_enabled(module, &enabled); - if (ret != LDB_SUCCESS) { - enabled = false; - } - - if (ldb_msg_check_string_attribute(old_msg, "isDeleted", "TRUE")) { - if (!enabled) { - deletion_state = OBJECT_TOMBSTONE; - next_deletion_state = OBJECT_REMOVED; - } else if (ldb_msg_check_string_attribute(old_msg, "isRecycled", "TRUE")) { - deletion_state = OBJECT_RECYCLED; - next_deletion_state = OBJECT_REMOVED; - } else { - deletion_state = OBJECT_DELETED; - next_deletion_state = OBJECT_RECYCLED; - } - - /* This supports us noticing an incoming isDeleted and acting on it */ - if (re_delete) { - next_deletion_state = deletion_state; - } - } else { - SMB_ASSERT(!re_delete); - deletion_state = OBJECT_NOT_DELETED; - if (enabled) { - next_deletion_state = OBJECT_DELETED; - } else { - next_deletion_state = OBJECT_TOMBSTONE; - } + /* This supports us noticing an incoming isDeleted and acting on it */ + if (re_delete) { + SMB_ASSERT(deletion_state > OBJECT_NOT_DELETED); + next_deletion_state = deletion_state; } if (next_deletion_state == OBJECT_REMOVED) { |