summaryrefslogtreecommitdiff
path: root/src/providers/krb5/krb5_auth.c
diff options
context:
space:
mode:
authorJakub Hrozek <jhrozek@redhat.com>2013-10-08 18:25:20 +0200
committerJakub Hrozek <jhrozek@redhat.com>2013-10-17 13:38:51 +0200
commit2105a6a63cb74bf009fb6e723e74f6ec075e1238 (patch)
tree377e16606c23fbcfbaea6c3c8535aa95fa0ae3cd /src/providers/krb5/krb5_auth.c
parent569bbc59e4060160a986d0fea31601a7b7d998fe (diff)
downloadsssd-2105a6a63cb74bf009fb6e723e74f6ec075e1238.tar.gz
sssd-2105a6a63cb74bf009fb6e723e74f6ec075e1238.tar.bz2
sssd-2105a6a63cb74bf009fb6e723e74f6ec075e1238.zip
KRB5: Return PAM_ACCT_EXPIRED when logging in as expired AD userHEADmaster
If an expired AD user logs in, the SSSD receives KRB5KDC_ERR_CLIENT_REVOKED from the KDC. This error code was not handled by the SSSD which resulted in System Error being returned to the PAM stack.
Diffstat (limited to 'src/providers/krb5/krb5_auth.c')
-rw-r--r--src/providers/krb5/krb5_auth.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/providers/krb5/krb5_auth.c b/src/providers/krb5/krb5_auth.c
index a4183dca..b4c20578 100644
--- a/src/providers/krb5/krb5_auth.c
+++ b/src/providers/krb5/krb5_auth.c
@@ -1006,6 +1006,12 @@ static void krb5_auth_done(struct tevent_req *subreq)
ret = EOK;
goto done;
+ case ERR_ACCOUNT_EXPIRED:
+ state->pam_status = PAM_ACCT_EXPIRED;
+ state->dp_err = DP_ERR_OK;
+ ret = EOK;
+ goto done;
+
case ERR_NO_CREDS:
state->pam_status = PAM_CRED_UNAVAIL;
state->dp_err = DP_ERR_OK;