123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- /*
- * Copyright (C) 2010-2011 Mamadou Diop.
- *
- * Contact: Mamadou Diop <diopmamadou(at)doubango[dot]org>
- *
- * This file is part of Open Source Doubango Framework.
- *
- * DOUBANGO is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * DOUBANGO is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with DOUBANGO.
- *
- */
- /**@file tsip_header_Security_Verify.h
- * @brief SIP header 'Security-Client' as per RFC 3329.
- *
- */
- #ifndef _TSIP_HEADER_SECURITY_VERIFY_H_
- #define _TSIP_HEADER_SECURITY_VERIFY_H_
- #include "tinysip_config.h"
- #include "tinysip/headers/tsip_header.h"
- #include "tnet_types.h"
- TSIP_BEGIN_DECLS
- #define TSIP_HEADER_SECURITY_VERIFY_VA_ARGS() tsip_header_Security_Verify_def_t
- ////////////////////////////////////////////////////////////////////////////////////////////////////
- ///
- /// @brief SIP header 'Security-Client' as per RFC 3329.
- ///
- /// @par ABNF : Security-Client = "Security-Client" HCOLON sec-mechanism *(COMMA sec-mechanism)
- /// sec-mechanism = mechanism-name *( SEMI mech-parameters )
- /// mechanism-name = ( "digest" / "tls" / "ipsec-ike" / "ipsec-man" / token )
- /// mech-parameters = ( preference / digest-algorithm / digest-qop / digest-verify / mech-extension )
- /// preference = "q" EQUAL qvalue
- /// digest-algorithm = "d-alg" EQUAL token
- /// digest-qop = "d-qop" EQUAL token
- /// digest-verify = "d-ver" EQUAL LDQUOT 32LHEX RDQUOT
- /// mech-extension = generic-param
- ///
- /// mechanism-name = ( "ipsec-3gpp" )
- /// mech-parameters = ( algorithm / protocol /mode /
- /// encrypt-algorithm / spi /
- /// port1 / port2 )
- /// algorithm = "alg" EQUAL ( "hmac-md5-96" /
- /// "hmac-sha-1-96" )
- /// protocol = "prot" EQUAL ( "ah" / "esp" )
- /// mode = "mod" EQUAL ( "trans" / "tun" )
- /// encrypt-algorithm = "ealg" EQUAL ( "des-ede3-cbc" / "null" )
- /// spi = "spi" EQUAL spivalue
- /// spivalue = 10DIGIT; 0 to 4294967295
- /// port1 = "port1" EQUAL port
- /// port2 = "port2" EQUAL port
- /// port = 1*DIGIT
- ///
- ///
- ////////////////////////////////////////////////////////////////////////////////////////////////////
- typedef struct tsip_header_Security_Verify_s {
- TSIP_DECLARE_HEADER;
- //! sec-mechanism (e.g. "digest" / "tls" / "ipsec-3gpp")
- char* mech;
- //! algorithm (e.g. "hmac-md5-96" / "hmac-sha-1-96")
- char* alg;
- //! protocol (e.g. "ah" / "esp")
- char* prot;
- //! mode (e.g. "trans" / "tun")
- char* mod;
- //! encrypt-algorithm (e.g. "des-ede3-cbc" / "null")
- char* ealg;
- //! client port
- tnet_port_t port_c;
- //! server port
- tnet_port_t port_s;
- //! client spi
- uint32_t spi_c;
- //! server spi
- uint32_t spi_s;
- //! preference
- double q;
- }
- tsip_header_Security_Verify_t;
- typedef tsk_list_t tsip_header_Security_Verifies_L_t;
- TINYSIP_API tsip_header_Security_Verify_t* tsip_header_Security_Verify_create();
- TINYSIP_API tsip_header_Security_Verify_t* tsip_header_Security_Verify_create_null();
- TINYSIP_API tsip_header_Security_Verifies_L_t *tsip_header_Security_Verify_parse(const char *data, tsk_size_t size);
- TINYSIP_GEXTERN const tsk_object_def_t *tsip_header_Security_Verify_def_t;
- TSIP_END_DECLS
- #endif /* _TSIP_HEADER_SECURITY_VERIFY_H_ */
|