diff options
author | Andreas Schneider <asn@samba.org> | 2019-06-24 13:14:12 +0200 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2019-06-27 12:54:22 +0000 |
commit | d1641f3e6a7a760a669ff2d9aa45dc2f4c61071b (patch) | |
tree | 97b98509e2803fd08b2d3dae1c278bf62a62681e /lib/crypto | |
parent | 8f4c30f785cd012597883016e35f794e9a800404 (diff) | |
download | samba-d1641f3e6a7a760a669ff2d9aa45dc2f4c61071b.tar.gz |
libcli:util: Add gnutls_error_to_werror()
Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Diffstat (limited to 'lib/crypto')
-rw-r--r-- | lib/crypto/gnutls_error.c | 48 | ||||
-rw-r--r-- | lib/crypto/gnutls_helpers.h | 8 |
2 files changed, 56 insertions, 0 deletions
diff --git a/lib/crypto/gnutls_error.c b/lib/crypto/gnutls_error.c index 9e124c20c68..764e2175328 100644 --- a/lib/crypto/gnutls_error.c +++ b/lib/crypto/gnutls_error.c @@ -67,3 +67,51 @@ NTSTATUS _gnutls_error_to_ntstatus(int gnutls_rc, return status; } + +WERROR _gnutls_error_to_werror(int gnutls_rc, + WERROR blocked_werr, + const char *function, + const char *location) +{ + WERROR werr; + + if (gnutls_rc == GNUTLS_E_SUCCESS) { + return WERR_OK; + } + + switch (gnutls_rc) { + case GNUTLS_E_UNWANTED_ALGORITHM: + werr = blocked_werr; + break; + case GNUTLS_E_MEMORY_ERROR: + werr = WERR_NOT_ENOUGH_MEMORY; + break; + case GNUTLS_E_INVALID_REQUEST: + werr = WERR_INVALID_VARIANT; + break; + case GNUTLS_E_DECRYPTION_FAILED: + werr = WERR_DECRYPTION_FAILED; + break; + case GNUTLS_E_ENCRYPTION_FAILED: + werr = WERR_ENCRYPTION_FAILED; + break; + case GNUTLS_E_SHORT_MEMORY_BUFFER: + werr = WERR_INVALID_PARAMETER; + break; + case GNUTLS_E_BASE64_DECODING_ERROR: + case GNUTLS_E_HASH_FAILED: + case GNUTLS_E_LIB_IN_ERROR_STATE: + case GNUTLS_E_INTERNAL_ERROR: + default: + werr = WERR_INTERNAL_ERROR; + break; + } + + D_WARNING("%s: GNUTLS ERROR: %s, WERROR: %s at %s\n", + function, + gnutls_strerror_name(gnutls_rc), + win_errstr(werr), + location); + + return werr; +} diff --git a/lib/crypto/gnutls_helpers.h b/lib/crypto/gnutls_helpers.h index 3e7300ea2c0..e1a17168297 100644 --- a/lib/crypto/gnutls_helpers.h +++ b/lib/crypto/gnutls_helpers.h @@ -19,6 +19,7 @@ #define _GNUTLS_HELPERS_H #include "ntstatus.h" +#include "werror.h" NTSTATUS _gnutls_error_to_ntstatus(int gnutls_rc, NTSTATUS blocked_status, @@ -28,4 +29,11 @@ NTSTATUS _gnutls_error_to_ntstatus(int gnutls_rc, _gnutls_error_to_ntstatus(gnutls_rc, blocked_status, \ __FUNCTION__, __location__) +WERROR _gnutls_error_to_werror(int gnutls_rc, + WERROR blocked_werr, + const char *function, + const char *location); +#define gnutls_error_to_werror(gnutls_rc, blocked_werr) \ + _gnutls_error_to_werror(gnutls_rc, blocked_werr, \ + __FUNCTION__, __location__) #endif /* _GNUTLS_HELPERS_H */ |