summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRich Megginson <rmeggins@redhat.com>2011-06-24 19:42:47 -0600
committerRob Crittenden <rcritten@redhat.com>2011-06-28 00:11:04 -0400
commit89c67c3ad97f858ebde38a34a7b106379371c125 (patch)
tree04d2f76f73e8a7d355a514a5a28e93cab8f7d3a5
parentd43e87e10c9ebe8ee1bc6a1481c0f238b1defc37 (diff)
downloadfreeipa-89c67c3ad97f858ebde38a34a7b106379371c125.tar.gz
freeipa-89c67c3ad97f858ebde38a34a7b106379371c125.tar.xz
freeipa-89c67c3ad97f858ebde38a34a7b106379371c125.zip
modify user deleted in AD crashes winsync
https://fedorahosted.org/freeipa/ticket/1382 crash in winsync if replaying a MOD and user does not exist in AD If the AD entry is deleted before the deletion can be synced back to IPA, and in the meantime an operation is performed on the corresponding entry in IPA that should be synced to AD, winsync attempts to get the AD entry and it is empty. This just means the operation will not go through, and the entry will be deleted when the sync from AD happens. The IPA winsync plugin needs to handle the case when the ad_entry is NULL.
-rw-r--r--daemons/ipa-slapi-plugins/ipa-winsync/ipa-winsync.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/daemons/ipa-slapi-plugins/ipa-winsync/ipa-winsync.c b/daemons/ipa-slapi-plugins/ipa-winsync/ipa-winsync.c
index 5a27321fb..4b81a2eab 100644
--- a/daemons/ipa-slapi-plugins/ipa-winsync/ipa-winsync.c
+++ b/daemons/ipa-slapi-plugins/ipa-winsync/ipa-winsync.c
@@ -787,6 +787,13 @@ sync_acct_disable(
return; /* not supported */
}
+ if (!ad_entry) {
+ LOG("<-- sync_acct_disable - the AD entry corresponding to [%s] "
+ "is NULL - skipping\n",
+ slapi_entry_get_dn_const(ds_entry));
+ return;
+ }
+
/* get the account lock state of the ds entry */
if (0 == ipa_check_account_lock(ds_entry, &isvirt)) {
ds_is_enabled = 0;
@@ -1113,7 +1120,7 @@ do_force_sync(
LOG("do_force_sync - forcing sync of AD entry [%s] "
"with DS entry [%s]\n",
- slapi_entry_get_dn_const(ad_entry),
+ ad_entry ? slapi_entry_get_dn_const(ad_entry) : "(none)",
slapi_entry_get_dn_const(ds_entry));
find_and_add_mod(ds_entry, smods, "objectClass", "ntUser", (size_t)6, do_modify);