diff options
author | Andrew Bartlett <abartlet@samba.org> | 2012-08-27 21:01:10 +1000 |
---|---|---|
committer | Andrew Bartlett <abartlet@samba.org> | 2012-08-28 07:57:29 +1000 |
commit | e66fa2c8134a886f52419f4a33992b200b00ff49 (patch) | |
tree | a8da6e538189bc07fb54f2c853d59cc3a76d2a37 /auth | |
parent | 43904cb4f5e775a5ba72553d1a59ffd30204a83d (diff) | |
download | samba-e66fa2c8134a886f52419f4a33992b200b00ff49.tar.gz samba-e66fa2c8134a886f52419f4a33992b200b00ff49.tar.bz2 samba-e66fa2c8134a886f52419f4a33992b200b00ff49.zip |
auth/credentials: Expand secrets.tdb fetch of secrets to preserve workstation and realm
These would otherwise be set during the fetch from the secrets.ldb, but are wiped when that fails.
Andrew Bartlett
Diffstat (limited to 'auth')
-rw-r--r-- | auth/credentials/credentials_secrets.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/auth/credentials/credentials_secrets.c b/auth/credentials/credentials_secrets.c index ab7f5e8405..dc31f9d8ca 100644 --- a/auth/credentials/credentials_secrets.c +++ b/auth/credentials/credentials_secrets.c @@ -203,6 +203,7 @@ _PUBLIC_ NTSTATUS cli_credentials_set_machine_account(struct cli_credentials *cr char *filter; char *error_string; const char *domain; + const char *realm; /* Bleh, nasty recursion issues: We are setting a machine * account here, so we don't want the 'pending' flag around * any more */ @@ -211,6 +212,7 @@ _PUBLIC_ NTSTATUS cli_credentials_set_machine_account(struct cli_credentials *cr /* We have to do this, as the fallback in * cli_credentials_set_secrets is to run as anonymous, so the domain is wiped */ domain = cli_credentials_get_domain(cred); + realm = cli_credentials_get_realm(cred); filter = talloc_asprintf(cred, SECRETS_PRIMARY_DOMAIN_FILTER, domain); status = cli_credentials_set_secrets(cred, lp_ctx, NULL, @@ -238,6 +240,8 @@ _PUBLIC_ NTSTATUS cli_credentials_set_machine_account(struct cli_credentials *cr char *machine_account = talloc_asprintf(cred, "%s$", lpcfg_netbios_name(lp_ctx)); cli_credentials_set_password(cred, (const char *)dbuf.dptr, CRED_SPECIFIED); cli_credentials_set_domain(cred, domain, CRED_SPECIFIED); + cli_credentials_set_realm(cred, domain, CRED_SPECIFIED); + cli_credentials_set_workstation(cred, lpcfg_netbios_name(lp_ctx), CRED_SPECIFIED); cli_credentials_set_username(cred, machine_account, CRED_SPECIFIED); TALLOC_FREE(machine_account); TALLOC_FREE(dbuf.dptr); |