]> git.ipfire.org Git - thirdparty/openssl.git/blobdiff - include/internal/quic_error.h
Copyright year updates
[thirdparty/openssl.git] / include / internal / quic_error.h
index 9495c3e67d9341e93538fd1a5e18d10d99cacf70..86d1c692b4f03a33bdd7e9a7cefd6f8c14e540a7 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright 2022 The OpenSSL Project Authors. All Rights Reserved.
+ * Copyright 2022-2024 The OpenSSL Project Authors. All Rights Reserved.
  *
  * Licensed under the Apache License 2.0 (the "License").  You may not use
  * this file except in compliance with the License.  You can obtain a copy
 # define OSSL_QUIC_ERROR_H
 
 # include <openssl/ssl.h>
+# include <openssl/quic.h>
 
 # ifndef OPENSSL_NO_QUIC
 
-/* RFC 9000 Section 20.1 */
-#  define QUIC_ERR_NO_ERROR                  0x00
-#  define QUIC_ERR_INTERNAL_ERROR            0x01
-#  define QUIC_ERR_CONNECTION_REFUSED        0x02
-#  define QUIC_ERR_FLOW_CONTROL_ERROR        0x03
-#  define QUIC_ERR_STREAM_LIMIT_ERROR        0x04
-#  define QUIC_ERR_STREAM_STATE_ERROR        0x05
-#  define QUIC_ERR_FINAL_SIZE_ERROR          0x06
-#  define QUIC_ERR_FRAME_ENCODING_ERROR      0x07
-#  define QUIC_ERR_TRANSPORT_PARAMETER_ERROR 0x08
-#  define QUIC_ERR_CONNECTION_ID_LIMIT_ERROR 0x09
-#  define QUIC_ERR_PROTOCOL_VIOLATION        0x0A
-#  define QUIC_ERR_INVALID_TOKEN             0x0B
-#  define QUIC_ERR_APPLICATION_ERROR         0x0C
-#  define QUIC_ERR_CRYPTO_BUFFER_EXCEEDED    0x0D
-#  define QUIC_ERR_KEY_UPDATE_ERROR          0x0E
-#  define QUIC_ERR_AEAD_LIMIT_REACHED        0x0F
-#  define QUIC_ERR_NO_VIABLE_PATH            0x10
+#  define OSSL_QUIC_ERR_CRYPTO_UNEXPECTED_MESSAGE \
+    OSSL_QUIC_ERR_CRYPTO_ERR(SSL3_AD_UNEXPECTED_MESSAGE)
 
-/* Inclusive range for handshake-specific errors. */
-#  define QUIC_ERR_CRYPTO_ERR_BEGIN          0x0100
-#  define QUIC_ERR_CRYPTO_ERR_END            0x01FF
+#  define OSSL_QUIC_ERR_CRYPTO_MISSING_EXT \
+    OSSL_QUIC_ERR_CRYPTO_ERR(TLS13_AD_MISSING_EXTENSION)
 
-#  define QUIC_ERR_CRYPTO_ERR(X) \
-    (QUIC_ERR_CRYPTO_ERR_BEGIN + (X))
+#  define OSSL_QUIC_ERR_CRYPTO_NO_APP_PROTO \
+    OSSL_QUIC_ERR_CRYPTO_ERR(TLS1_AD_NO_APPLICATION_PROTOCOL)
 
-#  define QUIC_ERR_CRYPTO_MISSING_EXT \
-    QUIC_ERR_CRYPTO_ERR(TLS13_AD_MISSING_EXTENSION)
-
-#  define QUIC_ERR_CRYPTO_NO_APP_PROTO \
-    QUIC_ERR_CRYPTO_ERR(TLS1_AD_NO_APPLICATION_PROTOCOL)
-
-static ossl_inline ossl_unused const char *
-ossl_quic_err_to_string(uint64_t error_code)
-{
-    switch (error_code) {
-#define X(name) case QUIC_ERR_##name: return #name;
-    X(NO_ERROR)
-    X(INTERNAL_ERROR)
-    X(CONNECTION_REFUSED)
-    X(FLOW_CONTROL_ERROR)
-    X(STREAM_LIMIT_ERROR)
-    X(STREAM_STATE_ERROR)
-    X(FINAL_SIZE_ERROR)
-    X(FRAME_ENCODING_ERROR)
-    X(TRANSPORT_PARAMETER_ERROR)
-    X(CONNECTION_ID_LIMIT_ERROR)
-    X(PROTOCOL_VIOLATION)
-    X(INVALID_TOKEN)
-    X(APPLICATION_ERROR)
-    X(CRYPTO_BUFFER_EXCEEDED)
-    X(KEY_UPDATE_ERROR)
-    X(AEAD_LIMIT_REACHED)
-    X(NO_VIABLE_PATH)
-#undef X
-    default:
-        return NULL;
-    }
-}
+const char *ossl_quic_err_to_string(uint64_t error_code);
 
 # endif