1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-10 01:18:15 +03:00
samba-mirror/source4
Tim Beale 22208f52e6 dbchecker: Fixing up incorrect DNs wasn't working
dbcheck would fail to fix up attributes where the extended DN's GUID is
correct, but the DN itself is incorrect. The code failed attempting to
remove the old/incorrect DN, e.g.

 NOTE: old (due to rename or delete) DN string component for
 objectCategory in object CN=alice,CN=Users,DC=samba,DC=example,DC=com -
 <GUID=7bfdf9d8-62f9-420c-8a71-e3d3e931c91e>;
   CN=Person,CN=Schema,CN=Configuration,DC=samba,DC=bad,DC=com
 Change DN to <GUID=7bfdf9d8-62f9-420c-8a71-e3d3e931c91e>;
   CN=Person,CN=Schema,CN=Configuration,DC=samba,DC=example,DC=com?
 [y/N/all/none] y
 Failed to fix old DN string on attribute objectCategory : (16,
 "attribute 'objectCategory': no matching attribute value while deleting
 attribute on 'CN=alice,CN=Users,DC=samba,DC=example,DC=com'")

The problem was the LDB message specified the value to delete with its
full DN, including the GUID. The LDB code then helpfully corrected this
value on the way through, so that the DN got updated to reflect the
correct DN (i.e. 'DC=example,DC=com') of the object matching that GUID,
rather than the incorrect DN (i.e. 'DC=bad,DC=com') that we were trying
to remove. Because the requested value and the existing DB value didn't
match, the operation failed.

We can avoid this problem by passing down just the DN (not the extended
DN) of the value we want to delete. Without the GUID portion of the DN,
the LDB code will no longer try to correct it on the way through, and
the dbcheck operation will succeed.

BUG: https://bugzilla.samba.org/show_bug.cgi?id=13495

Signed-off-by: Tim Beale <timbeale@catalyst.net.nz>
Signed-off-by: Andrew Bartlett <abartlet@samba.org>
Reviewed-by: Gary Lockyer <gary@catalyst.net.nz>
Pair-programmed-with: Andrew Bartlett <abartlet@samba.org>
2018-07-03 05:24:13 +02:00
..
auth auth: For NTLM and KDC authentication, log the authentication duration 2018-06-25 08:32:14 +02:00
build/pasn1
cldap_server cldap: clear remote address after cldap_dse_fill 2018-05-31 09:54:18 +02:00
client s4:client: Fix size types and loop 2018-04-03 20:20:10 +02:00
cluster dbwrap: Remove calls to loadparm 2018-04-24 01:53:19 +02:00
dns_server dsdb: add defines for sessionInfo and networkSessionInfo 2018-06-09 15:02:11 +02:00
dsdb dbchecker: Fixing up incorrect DNs wasn't working 2018-07-03 05:24:13 +02:00
echo_server source4/smbd: Do not overstamp the process model with "single" 2017-10-19 05:33:10 +02:00
heimdal auth: For NTLM and KDC authentication, log the authentication duration 2018-06-25 08:32:14 +02:00
heimdal_build heimdal_build: use closefrom from libreplace 2018-02-21 14:19:19 +01:00
include lib: Remove global xfile.h includes 2016-11-20 06:23:19 +01:00
kdc auth: For NTLM and KDC authentication, log the authentication duration 2018-06-25 08:32:14 +02:00
ldap_server ldap_server: Fix CID 1435721 Unchecked return value 2018-05-24 03:35:00 +02:00
lib s4/lib/py-registry: initialize optional parameters for open_* functions 2018-04-13 07:27:14 +02:00
libcli pysmb: add py_smb_unlink and test 2018-06-28 09:25:08 +02:00
libnet FIXUP: Improve memory handling on py_net_change_password 2018-05-17 14:28:19 +02:00
librpc s4/librpc: Additionally accept unicode as string param in Py2 2018-04-30 15:43:19 +02:00
nbt_server samdb: Add remote address to connect 2018-05-10 20:02:23 +02:00
ntp_signd samdb: Add remote address to connect 2018-05-10 20:02:23 +02:00
ntvfs s4:ntvfs: Fix string copy of share_name 2018-05-17 17:30:09 +02:00
param param: Add non-global smb.cfg option (support 2 different smb.confs) 2018-06-28 03:34:27 +02:00
rpc_server auth: For NTLM and KDC authentication, log the authentication duration 2018-06-25 08:32:14 +02:00
script s4/script: convert print func to be py2/py3 compatible 2018-03-23 07:28:24 +01:00
scripting provision: set 'binddns dir' when making new smb.conf 2018-06-28 06:22:16 +02:00
selftest dbchecker: Fixing up incorrect DNs wasn't working 2018-07-03 05:24:13 +02:00
setup tests: Add test that Samba cannot be started with a backup DB 2018-06-28 03:34:26 +02:00
smb_server samdb: Add remote address to connect 2018-05-10 20:02:23 +02:00
smbd samba: read backup date field on init and fail if present 2018-06-28 03:34:26 +02:00
torture samba-tool showrepl tests: test all-good with --pull-summary 2018-06-28 09:23:09 +02:00
utils tests/demote: replace demote test bash script to python 2018-06-07 04:21:17 +02:00
web_server s4/webserver: initialise optional parameter 2018-04-13 07:27:14 +02:00
winbind samdb: Add remote address to connect 2018-05-10 20:02:23 +02:00
wrepl_server source4/smbd: Do not overstamp the process model with "single" 2017-10-19 05:33:10 +02:00
.clang_complete
.valgrind_suppressions
wscript_build Do not install smbclient4 and nmblookup4 2014-04-15 03:25:13 +02:00