diff options
-rw-r--r-- | source3/libads/ads_status.c | 2 | ||||
-rw-r--r-- | source3/libads/krb5_errs.c | 1 | ||||
-rw-r--r-- | source3/libsmb/errormap.c | 37 |
3 files changed, 2 insertions, 38 deletions
diff --git a/source3/libads/ads_status.c b/source3/libads/ads_status.c index 00427936ad..07c60c5ac0 100644 --- a/source3/libads/ads_status.c +++ b/source3/libads/ads_status.c @@ -83,7 +83,7 @@ NTSTATUS ads_ntstatus(ADS_STATUS status) #endif #ifdef HAVE_KRB5 case ENUM_ADS_ERROR_KRB5: - return krb5_to_ntstatus(status.err.rc); + return krb5_to_nt_status(status.err.rc); #endif default: break; diff --git a/source3/libads/krb5_errs.c b/source3/libads/krb5_errs.c index e73482522b..38d34f8676 100644 --- a/source3/libads/krb5_errs.c +++ b/source3/libads/krb5_errs.c @@ -55,6 +55,7 @@ static const struct { #if defined(KRB5KRB_ERR_RESPONSE_TOO_BIG) {KRB5KRB_ERR_RESPONSE_TOO_BIG, NT_STATUS_PROTOCOL_UNREACHABLE}, #endif + {KRB5KDC_ERR_NONE, NT_STATUS_OK}, {0, NT_STATUS_OK} }; diff --git a/source3/libsmb/errormap.c b/source3/libsmb/errormap.c index 7758246929..cb5e8311ca 100644 --- a/source3/libsmb/errormap.c +++ b/source3/libsmb/errormap.c @@ -1566,40 +1566,3 @@ NTSTATUS map_nt_error_from_unix(int unix_error) /* Default return */ return NT_STATUS_ACCESS_DENIED; } - -#ifdef HAVE_KRB5 -/********************************************************************* - Map a krb5 error code to an NT error code -*********************************************************************/ - -struct krb5_error_map { - int krb5_error; - NTSTATUS nt_error; -}; - -const struct krb5_error_map krb5_nt_errmap[] = { - { KRB5KDC_ERR_PREAUTH_FAILED, NT_STATUS_LOGON_FAILURE }, - { KRB5_KDC_UNREACH, NT_STATUS_NO_LOGON_SERVERS }, - { KRB5KRB_AP_ERR_SKEW, NT_STATUS_TIME_DIFFERENCE_AT_DC }, - /* not sure if this mapping is appropriate */ - { KRB5KDC_ERR_C_PRINCIPAL_UNKNOWN, NT_STATUS_NO_TRUST_SAM_ACCOUNT }, - { KRB5KDC_ERR_NONE, NT_STATUS_OK }, - /* end of array flag - not used as error code... */ - { 0, NT_STATUS_OK } -}; - -NTSTATUS krb5_to_ntstatus(int error) -{ - int i = 0; - - while (krb5_nt_errmap[i].krb5_error != 0) { - if (krb5_nt_errmap[i].krb5_error == error) { - return krb5_nt_errmap[i].nt_error; - } - i++; - } - - return NT_STATUS_ACCESS_DENIED; -} -#endif - |