Annotation of embedaddon/strongswan/src/libtls/tls_alert.h, revision 1.1

1.1     ! misho       1: /*
        !             2:  * Copyright (C) 2010 Martin Willi
        !             3:  * Copyright (C) 2010 revosec AG
        !             4:  *
        !             5:  * This program is free software; you can redistribute it and/or modify it
        !             6:  * under the terms of the GNU General Public License as published by the
        !             7:  * Free Software Foundation; either version 2 of the License, or (at your
        !             8:  * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
        !             9:  *
        !            10:  * This program is distributed in the hope that it will be useful, but
        !            11:  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
        !            12:  * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
        !            13:  * for more details.
        !            14:  */
        !            15: 
        !            16: /**
        !            17:  * @defgroup tls_alert tls_alert
        !            18:  * @{ @ingroup libtls
        !            19:  */
        !            20: 
        !            21: #ifndef TLS_ALERT_H_
        !            22: #define TLS_ALERT_H_
        !            23: 
        !            24: #include <library.h>
        !            25: 
        !            26: typedef struct tls_alert_t tls_alert_t;
        !            27: typedef enum tls_alert_level_t tls_alert_level_t;
        !            28: typedef enum tls_alert_desc_t tls_alert_desc_t;
        !            29: 
        !            30: /**
        !            31:  * Level of a TLS alert
        !            32:  */
        !            33: enum tls_alert_level_t {
        !            34:        TLS_WARNING = 1,
        !            35:        TLS_FATAL = 2,
        !            36: };
        !            37: 
        !            38: /**
        !            39:  * Description of a TLS alert
        !            40:  */
        !            41: enum tls_alert_desc_t {
        !            42:        TLS_CLOSE_NOTIFY = 0,
        !            43:        TLS_UNEXPECTED_MESSAGE = 10,
        !            44:        TLS_BAD_RECORD_MAC = 20,
        !            45:        TLS_DECRYPTION_FAILED = 21,
        !            46:        TLS_RECORD_OVERFLOW = 22,
        !            47:        TLS_DECOMPRESSION_FAILURE = 30,
        !            48:        TLS_HANDSHAKE_FAILURE = 40,
        !            49:        TLS_NO_CERTIFICATE = 41,
        !            50:        TLS_BAD_CERTIFICATE = 42,
        !            51:        TLS_UNSUPPORTED_CERTIFICATE = 43,
        !            52:        TLS_CERTIFICATE_REVOKED = 44,
        !            53:        TLS_CERTIFICATE_EXPIRED = 45,
        !            54:        TLS_CERTIFICATE_UNKNOWN = 46,
        !            55:        TLS_ILLEGAL_PARAMETER = 47,
        !            56:        TLS_UNKNOWN_CA = 48,
        !            57:        TLS_ACCESS_DENIED = 49,
        !            58:        TLS_DECODE_ERROR = 50,
        !            59:        TLS_DECRYPT_ERROR = 51,
        !            60:        TLS_EXPORT_RESTRICTION = 60,
        !            61:        TLS_PROTOCOL_VERSION = 70,
        !            62:        TLS_INSUFFICIENT_SECURITY = 71,
        !            63:        TLS_INTERNAL_ERROR = 80,
        !            64:        TLS_USER_CANCELED = 90,
        !            65:        TLS_NO_RENEGOTIATION = 100,
        !            66:        TLS_UNSUPPORTED_EXTENSION = 110,
        !            67: };
        !            68: 
        !            69: /**
        !            70:  * Enum names for alert descriptions
        !            71:  */
        !            72: extern enum_name_t *tls_alert_desc_names;
        !            73: 
        !            74: /**
        !            75:  * TLS alert handling.
        !            76:  */
        !            77: struct tls_alert_t {
        !            78: 
        !            79:        /**
        !            80:         * Add an alert to the TLS alert queue, will be sent.
        !            81:         *
        !            82:         * @param level                 level of TLS alert
        !            83:         * @param description   description of alert
        !            84:         */
        !            85:        void (*add)(tls_alert_t *this, tls_alert_level_t level,
        !            86:                                tls_alert_desc_t description);
        !            87: 
        !            88:        /**
        !            89:         * Get an alert pushed to the alert queue, to send.
        !            90:         *
        !            91:         * @param level                 receives TLS alert level
        !            92:         * @param description   receives TLS alert description
        !            93:         * @return                              TRUE if returned an alert
        !            94:         */
        !            95:        bool (*get)(tls_alert_t *this, tls_alert_level_t *level,
        !            96:                                tls_alert_desc_t *description);
        !            97: 
        !            98:        /**
        !            99:         * Did a fatal alert occur?.
        !           100:         *
        !           101:         * @return                              TRUE if a fatal alert has occurred
        !           102:         */
        !           103:        bool (*fatal)(tls_alert_t *this);
        !           104: 
        !           105:        /**
        !           106:         * Process a received TLS alert.
        !           107:         *
        !           108:         * @param level                 level of received alert
        !           109:         * @param description   alert description
        !           110:         * @return                              status to pass down to TLS stack
        !           111:         */
        !           112:        status_t (*process)(tls_alert_t *this, tls_alert_level_t level,
        !           113:                                                tls_alert_desc_t description);
        !           114: 
        !           115:        /**
        !           116:         * Destroy a tls_alert_t.
        !           117:         */
        !           118:        void (*destroy)(tls_alert_t *this);
        !           119: };
        !           120: 
        !           121: /**
        !           122:  * Create a tls_alert instance.
        !           123:  */
        !           124: tls_alert_t *tls_alert_create();
        !           125: 
        !           126: #endif /** TLS_ALERT_H_ @}*/

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>