2021-07-19 21:55:20 +00:00
|
|
|
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:4;tab-width:4;coding:utf-8 -*-│
|
2021-06-24 19:31:26 +00:00
|
|
|
│vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi│
|
|
|
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
2021-07-19 21:55:20 +00:00
|
|
|
│ Copyright The Mbed TLS Contributors │
|
2021-06-24 19:31:26 +00:00
|
|
|
│ │
|
2021-07-19 21:55:20 +00:00
|
|
|
│ Licensed under the Apache License, Version 2.0 (the "License"); │
|
|
|
|
│ you may not use this file except in compliance with the License. │
|
|
|
|
│ You may obtain a copy of the License at │
|
2021-06-24 19:31:26 +00:00
|
|
|
│ │
|
2021-07-19 21:55:20 +00:00
|
|
|
│ http://www.apache.org/licenses/LICENSE-2.0 │
|
|
|
|
│ │
|
|
|
|
│ Unless required by applicable law or agreed to in writing, software │
|
|
|
|
│ distributed under the License is distributed on an "AS IS" BASIS, │
|
|
|
|
│ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. │
|
|
|
|
│ See the License for the specific language governing permissions and │
|
|
|
|
│ limitations under the License. │
|
2021-06-24 19:31:26 +00:00
|
|
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
|
|
|
#include "libc/fmt/itoa.h"
|
|
|
|
#include "third_party/mbedtls/iana.h"
|
|
|
|
#include "third_party/mbedtls/ssl.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns SSL fatal alert description.
|
|
|
|
* @see RFC5246 §7.2
|
|
|
|
*/
|
|
|
|
const char *GetAlertDescription(unsigned char x) {
|
2021-06-26 01:41:02 +00:00
|
|
|
static char buf[21];
|
2021-06-24 19:31:26 +00:00
|
|
|
switch (x) {
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_CLOSE_NOTIFY: /* 0 */
|
|
|
|
return "close_notify";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_UNEXPECTED_MESSAGE: /* 10 */
|
|
|
|
return "unexpected_message";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_BAD_RECORD_MAC: /* 20 */
|
|
|
|
return "bad_record_mac";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_DECRYPTION_FAILED: /* 21 */
|
|
|
|
return "decryption_failed";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_RECORD_OVERFLOW: /* 22 */
|
|
|
|
return "record_overflow";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_DECOMPRESSION_FAILURE: /* 30 */
|
|
|
|
return "decompression_failure";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_HANDSHAKE_FAILURE: /* 40 */
|
|
|
|
return "handshake_failure";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_NO_CERT: /* 41 */
|
|
|
|
return "no_cert";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_BAD_CERT: /* 42 */
|
|
|
|
return "bad_cert";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_UNSUPPORTED_CERT: /* 43 */
|
|
|
|
return "unsupported_cert";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_CERT_REVOKED: /* 44 */
|
|
|
|
return "cert_revoked";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_CERT_EXPIRED: /* 45 */
|
|
|
|
return "cert_expired";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_CERT_UNKNOWN: /* 46 */
|
|
|
|
return "cert_unknown";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_ILLEGAL_PARAMETER: /* 47 */
|
|
|
|
return "illegal_parameter";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_UNKNOWN_CA: /* 48 */
|
|
|
|
return "unknown_ca";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_ACCESS_DENIED: /* 49 */
|
|
|
|
return "access_denied";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_DECODE_ERROR: /* 50 */
|
|
|
|
return "decode_error";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_DECRYPT_ERROR: /* 51 */
|
|
|
|
return "decrypt_error";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_EXPORT_RESTRICTION: /* 60 */
|
|
|
|
return "export_restriction";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_PROTOCOL_VERSION: /* 70 */
|
|
|
|
return "protocol_version";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_INSUFFICIENT_SECURITY: /* 71 */
|
|
|
|
return "insufficient_security";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_INTERNAL_ERROR: /* 80 */
|
|
|
|
return "internal_error";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_USER_CANCELED: /* 90 */
|
|
|
|
return "user_canceled";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_NO_RENEGOTIATION: /* 100 */
|
|
|
|
return "no_renegotiation";
|
|
|
|
case MBEDTLS_SSL_ALERT_MSG_UNSUPPORTED_EXT: /* 110 */
|
|
|
|
return "unsupported_extension";
|
|
|
|
default:
|
2022-04-22 22:03:32 +00:00
|
|
|
FormatUint32(buf, x);
|
2021-06-24 19:31:26 +00:00
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
}
|