blob: eb66c43728661db293877b94f5988bdc956a2f08 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
/*
* 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_Server.h
* @brief SIP header 'Security-Server' as per RFC 3329.
*
*/
#ifndef _TSIP_HEADER_SECURITY_SERVER_H_
#define _TSIP_HEADER_SECURITY_SERVER_H_
#include "tinysip_config.h"
#include "tinysip/headers/tsip_header.h"
#include "tnet_types.h"
TSIP_BEGIN_DECLS
#define TSIP_HEADER_SECURITY_SERVER_VA_ARGS() tsip_header_Security_Server_def_t
////////////////////////////////////////////////////////////////////////////////////////////////////
///
/// @brief SIP header 'Security-Server' as per RFC 3329.
///
/// @par ABNF : Security-Server = "Security-Server" 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_Server_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_Server_t;
typedef tsk_list_t tsip_header_Security_Servers_L_t;
TINYSIP_API tsip_header_Security_Server_t* tsip_header_Security_Server_create();
TINYSIP_API tsip_header_Security_Server_t* tsip_header_Security_Server_create_null();
TINYSIP_API tsip_header_Security_Servers_L_t *tsip_header_Security_Server_parse(const char *data, tsk_size_t size);
TINYSIP_GEXTERN const tsk_object_def_t *tsip_header_Security_Server_def_t;
TSIP_END_DECLS
#endif /* _TSIP_HEADER_SECURITY_SERVER_H_ */
|