diff options
author | Gerald Carter <jerry@samba.org> | 2005-05-31 13:46:45 +0000 |
---|---|---|
committer | Gerald Carter <jerry@samba.org> | 2005-05-31 13:46:45 +0000 |
commit | a0ab7a47e277a4047d3daad43883dc6077979080 (patch) | |
tree | 31fc2c981f2de6044f41964d23a46ac51f82e419 /source/passdb | |
parent | 7e655eee5164362cb36d247d6251c848176c3a2f (diff) | |
download | samba-a0ab7a47e277a4047d3daad43883dc6077979080.tar.gz samba-a0ab7a47e277a4047d3daad43883dc6077979080.tar.xz samba-a0ab7a47e277a4047d3daad43883dc6077979080.zip |
r7139: trying to reduce the number of diffs between trunk and 3.0; changing version to 3.0.20pre1
Diffstat (limited to 'source/passdb')
-rw-r--r-- | source/passdb/secrets.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/source/passdb/secrets.c b/source/passdb/secrets.c index d1dcc694e87..6144037200f 100644 --- a/source/passdb/secrets.c +++ b/source/passdb/secrets.c @@ -540,6 +540,71 @@ BOOL secrets_store_ldap_pw(const char* dn, char* pw) return ret; } +/******************************************************************* + find the ldap password +******************************************************************/ +BOOL fetch_ldap_pw(char **dn, char** pw) +{ + char *key = NULL; + size_t size; + + *dn = smb_xstrdup(lp_ldap_admin_dn()); + + if (asprintf(&key, "%s/%s", SECRETS_LDAP_BIND_PW, *dn) < 0) { + SAFE_FREE(*dn); + DEBUG(0, ("fetch_ldap_pw: asprintf failed!\n")); + } + + *pw=secrets_fetch(key, &size); + SAFE_FREE(key); + + if (!size) { + /* Upgrade 2.2 style entry */ + char *p; + char* old_style_key = SMB_STRDUP(*dn); + char *data; + fstring old_style_pw; + + if (!old_style_key) { + DEBUG(0, ("fetch_ldap_pw: strdup failed!\n")); + return False; + } + + for (p=old_style_key; *p; p++) + if (*p == ',') *p = '/'; + + data=secrets_fetch(old_style_key, &size); + if (!size && size < sizeof(old_style_pw)) { + DEBUG(0,("fetch_ldap_pw: neither ldap secret retrieved!\n")); + SAFE_FREE(old_style_key); + SAFE_FREE(*dn); + return False; + } + + size = MIN(size, sizeof(fstring)-1); + strncpy(old_style_pw, data, size); + old_style_pw[size] = 0; + + SAFE_FREE(data); + + if (!secrets_store_ldap_pw(*dn, old_style_pw)) { + DEBUG(0,("fetch_ldap_pw: ldap secret could not be upgraded!\n")); + SAFE_FREE(old_style_key); + SAFE_FREE(*dn); + return False; + } + if (!secrets_delete(old_style_key)) { + DEBUG(0,("fetch_ldap_pw: old ldap secret could not be deleted!\n")); + } + + SAFE_FREE(old_style_key); + + *pw = smb_xstrdup(old_style_pw); + } + + return True; +} + /** * Get trusted domains info from secrets.tdb. |