summaryrefslogtreecommitdiff
path: root/source4/nsswitch/winbind_nss_linux.c
diff options
context:
space:
mode:
authorAndrew Kroeger <andrew@sprocks.gotdns.com>2008-01-18 02:51:51 +0100
committerJelmer Vernooij <jelmer@samba.org>2008-01-18 03:41:59 +0100
commite490415e2e300452e152373eb79fb437fb11449d (patch)
tree9199d5e1043bf892d282307dc5904e8f3e2f1e48 /source4/nsswitch/winbind_nss_linux.c
parent85d60d2d091a2eb6bd4c73c87c94b10ee93167ee (diff)
downloadsamba-e490415e2e300452e152373eb79fb437fb11449d.tar.gz
samba-e490415e2e300452e152373eb79fb437fb11449d.tar.bz2
samba-e490415e2e300452e152373eb79fb437fb11449d.zip
When Windows attempts to create a new key, it looks for an available key name
starting with "New Key #1" and iterating up to "New Key #99" before giving up. ldb_open_key() calls reg_path_to_ldb() to build the appropriate dn from the key name. reg_path_to_ldb() was not catching the error returned by ldb_dn_add_base_fmt() due to the unescaped '#' character, causing the returned dn to be that of the parent key, not the potential new key. Additionally, Windows expects a return value of WERR_BADFILE when a key does not exist, but WERR_NOT_FOUND was being returned instead. Correcting the building of the dn and the providing the expected return value allows new key creation to succeed. When attempting to delete a key, Windows passes the complete path to the key, not just the name of the child key to be deleted. Using reg_path_to_ldb() to build the correct dn allows key deletion to succeed. (This used to be commit d57792d67b865ef43e7f21640b158862627f4b45)
Diffstat (limited to 'source4/nsswitch/winbind_nss_linux.c')
0 files changed, 0 insertions, 0 deletions