ns_turn_msg_defs.h 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. /*
  2. * Copyright (C) 2011, 2012, 2013 Citrix Systems
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * 3. Neither the name of the project nor the names of its contributors
  15. * may be used to endorse or promote products derived from this software
  16. * without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
  19. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  20. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  21. * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
  22. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  23. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  24. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  25. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  26. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  27. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. */
  30. #ifndef __LIB_TURN_MSG_DEFS__
  31. #define __LIB_TURN_MSG_DEFS__
  32. #include "ns_turn_msg_defs_experimental.h"
  33. ///////////////////////////////////////////
  34. // http://www.iana.org/assignments/stun-parameters/stun-parameters.xhtml
  35. ///////////////////////////////////////////
  36. #define STUN_HEADER_LENGTH (20)
  37. #define STUN_CHANNEL_HEADER_LENGTH (4)
  38. #define STUN_MAX_USERNAME_SIZE (512)
  39. #define STUN_MAX_REALM_SIZE (127)
  40. #define STUN_MAX_NONCE_SIZE (127)
  41. #define STUN_MAX_SERVER_NAME_SIZE (1025)
  42. #define STUN_MAX_PWD_SIZE (256)
  43. #define AUTH_SECRET_SIZE STUN_MAX_PWD_SIZE
  44. #define STUN_MAGIC_COOKIE (0x2112A442)
  45. #define IS_STUN_REQUEST(msg_type) (((msg_type)&0x0110) == 0x0000)
  46. #define IS_STUN_INDICATION(msg_type) (((msg_type)&0x0110) == 0x0010)
  47. #define IS_STUN_SUCCESS_RESP(msg_type) (((msg_type)&0x0110) == 0x0100)
  48. #define IS_STUN_ERR_RESP(msg_type) (((msg_type)&0x0110) == 0x0110)
  49. #define GET_STUN_REQUEST(msg_type) (msg_type & 0xFEEF)
  50. #define GET_STUN_INDICATION(msg_type) ((msg_type & 0xFEEF) | 0x0010)
  51. #define GET_STUN_SUCCESS_RESP(msg_type) ((msg_type & 0xFEEF) | 0x0100)
  52. #define GET_STUN_ERR_RESP(msg_type) (msg_type | 0x0110)
  53. /* Lifetimes: */
  54. #define STUN_DEFAULT_ALLOCATE_LIFETIME (600)
  55. #define STUN_MIN_ALLOCATE_LIFETIME STUN_DEFAULT_ALLOCATE_LIFETIME
  56. #define STUN_DEFAULT_MAX_ALLOCATE_LIFETIME (3600)
  57. #define STUN_DEFAULT_CHANNEL_LIFETIME (600)
  58. #define STUN_DEFAULT_NONCE_EXPIRATION_TIME (600)
  59. #define STUN_DEFAULT_PERMISSION_LIFETIME (300)
  60. /**/
  61. #define STUN_METHOD_BINDING (0x0001)
  62. #define STUN_METHOD_ALLOCATE (0x0003)
  63. #define STUN_METHOD_REFRESH (0x0004)
  64. #define STUN_METHOD_SEND (0x0006)
  65. #define STUN_METHOD_DATA (0x0007)
  66. #define STUN_METHOD_CREATE_PERMISSION (0x0008)
  67. #define STUN_METHOD_CHANNEL_BIND (0x0009)
  68. /* RFC 6062 ==>>*/
  69. #define STUN_METHOD_CONNECT (0x000a)
  70. #define STUN_METHOD_CONNECTION_BIND (0x000b)
  71. #define STUN_METHOD_CONNECTION_ATTEMPT (0x000c)
  72. /* <<== RFC 6062 */
  73. #define STUN_ATTRIBUTE_MAPPED_ADDRESS (0x0001)
  74. #define OLD_STUN_ATTRIBUTE_RESPONSE_ADDRESS (0x0002)
  75. #define STUN_ATTRIBUTE_CHANGE_REQUEST (0x0003)
  76. #define OLD_STUN_ATTRIBUTE_SOURCE_ADDRESS (0x0004)
  77. #define OLD_STUN_ATTRIBUTE_CHANGED_ADDRESS (0x0005)
  78. #define STUN_ATTRIBUTE_USERNAME (0x0006)
  79. #define OLD_STUN_ATTRIBUTE_PASSWORD (0x0007)
  80. #define STUN_ATTRIBUTE_MESSAGE_INTEGRITY (0x0008)
  81. #define STUN_ATTRIBUTE_ERROR_CODE (0x0009)
  82. #define STUN_ATTRIBUTE_UNKNOWN_ATTRIBUTES (0x000A)
  83. #define OLD_STUN_ATTRIBUTE_REFLECTED_FROM (0x000B)
  84. #define STUN_ATTRIBUTE_REALM (0x0014)
  85. #define STUN_ATTRIBUTE_NONCE (0x0015)
  86. #define STUN_ATTRIBUTE_REQUESTED_ADDRESS_FAMILY (0x0017)
  87. #define STUN_ATTRIBUTE_XOR_MAPPED_ADDRESS (0x0020)
  88. #define OLD_STUN_ATTRIBUTE_XOR_MAPPED_ADDRESS (0x8020)
  89. #define STUN_ATTRIBUTE_SOFTWARE (0x8022)
  90. #define OLD_STUN_ATTRIBUTE_SERVER STUN_ATTRIBUTE_SOFTWARE
  91. #define STUN_ATTRIBUTE_ALTERNATE_SERVER (0x8023)
  92. #define STUN_ATTRIBUTE_FINGERPRINT (0x8028)
  93. #define STUN_ATTRIBUTE_CHANNEL_NUMBER (0x000C)
  94. #define STUN_ATTRIBUTE_LIFETIME (0x000D)
  95. #define STUN_ATTRIBUTE_BANDWIDTH (0x0010)
  96. #define STUN_ATTRIBUTE_XOR_PEER_ADDRESS (0x0012)
  97. #define STUN_ATTRIBUTE_DATA (0x0013)
  98. #define STUN_ATTRIBUTE_XOR_RELAYED_ADDRESS (0x0016)
  99. #define STUN_ATTRIBUTE_EVEN_PORT (0x0018)
  100. #define STUN_ATTRIBUTE_REQUESTED_TRANSPORT (0x0019)
  101. #define STUN_ATTRIBUTE_DONT_FRAGMENT (0x001A)
  102. #define STUN_ATTRIBUTE_TIMER_VAL (0x0021)
  103. #define STUN_ATTRIBUTE_RESERVATION_TOKEN (0x0022)
  104. /* ICE */
  105. #define STUN_ATTRIBUTE_PRIORITY (0x0024)
  106. #define STUN_ATTRIBUTE_ICE_CONTROLLED (0x8029)
  107. /* RFC 5780 */
  108. #define STUN_ATTRIBUTE_PADDING (0x0026)
  109. #define STUN_ATTRIBUTE_RESPONSE_PORT (0x0027)
  110. #define STUN_ATTRIBUTE_RESPONSE_ORIGIN (0x802B)
  111. #define STUN_ATTRIBUTE_OTHER_ADDRESS (0x802C)
  112. /* RFC 6062 ==>> */
  113. #define STUN_ATTRIBUTE_CONNECTION_ID (0x002A)
  114. /* <<== RFC 6062 */
  115. #define STUN_VALID_CHANNEL(chn) ((chn) >= 0x4000 && (chn) <= 0x7FFF)
  116. ///////// extra values //////////////////
  117. /* RFC 6156 ==>> */
  118. #define STUN_ATTRIBUTE_REQUESTED_ADDRESS_FAMILY_VALUE_IPV4 (0x01)
  119. #define STUN_ATTRIBUTE_REQUESTED_ADDRESS_FAMILY_VALUE_IPV6 (0x02)
  120. #define STUN_ATTRIBUTE_REQUESTED_ADDRESS_FAMILY_VALUE_DEFAULT (0x00)
  121. #define STUN_ATTRIBUTE_REQUESTED_ADDRESS_FAMILY_VALUE_INVALID (-1)
  122. /* <<== RFC 6156 */
  123. /* RFC 6062 ==>> */
  124. #define STUN_ATTRIBUTE_TRANSPORT_TCP_VALUE (6)
  125. #define STUN_ATTRIBUTE_TRANSPORT_UDP_VALUE (17)
  126. #define STUN_ATTRIBUTE_TRANSPORT_TLS_VALUE (56)
  127. #define STUN_ATTRIBUTE_TRANSPORT_DTLS_VALUE (250)
  128. /* <<== RFC 6062 */
  129. /* SHA ==>> */
  130. #define SHA1SIZEBYTES (20)
  131. #define SHA256SIZEBYTES (32)
  132. #define SHA384SIZEBYTES (48)
  133. #define SHA512SIZEBYTES (64)
  134. #define MAXSHASIZE (128)
  135. enum _SHATYPE {
  136. SHATYPE_ERROR = -1,
  137. SHATYPE_DEFAULT = 0,
  138. SHATYPE_SHA1 = SHATYPE_DEFAULT,
  139. SHATYPE_SHA256,
  140. SHATYPE_SHA384,
  141. SHATYPE_SHA512
  142. };
  143. typedef enum _SHATYPE SHATYPE;
  144. #define shatype_name(sht) \
  145. ((sht == SHATYPE_SHA1) ? "SHA1" \
  146. : ((sht == SHATYPE_SHA256) ? "SHA256" : ((sht == SHATYPE_SHA384) ? "SHA384" : "SHA512")))
  147. /* <<== SHA */
  148. /* OAUTH TOKEN ENC ALG ==> */
  149. enum _ENC_ALG {
  150. ENC_ALG_ERROR = -1,
  151. #if !defined(TURN_NO_GCM)
  152. ENC_ALG_DEFAULT = 0,
  153. A256GCM = ENC_ALG_DEFAULT,
  154. A128GCM,
  155. #endif
  156. ENC_ALG_NUM
  157. };
  158. typedef enum _ENC_ALG ENC_ALG;
  159. /* <<== OAUTH TOKEN ENC ALG */
  160. /**
  161. * oAuth struct
  162. */
  163. #define STUN_ATTRIBUTE_THIRD_PARTY_AUTHORIZATION (0x802E)
  164. #define STUN_ATTRIBUTE_OAUTH_ACCESS_TOKEN (0x001B)
  165. #define OAUTH_KID_SIZE (128)
  166. #define OAUTH_HASH_FUNC_SIZE (64)
  167. #define OAUTH_ALG_SIZE (64)
  168. #define OAUTH_KEY_SIZE (256)
  169. #define OAUTH_GCM_NONCE_SIZE (12)
  170. #define OAUTH_MAX_NONCE_SIZE (256)
  171. #define OAUTH_GCM_TAG_SIZE (16)
  172. #define OAUTH_ENC_ALG_BLOCK_SIZE (16)
  173. #define OAUTH_DEFAULT_LIFETIME (0)
  174. #define OAUTH_DEFAULT_TIMESTAMP (turn_time())
  175. #define OAUTH_TIME_DELTA (5)
  176. struct _oauth_key_data {
  177. char kid[OAUTH_KID_SIZE + 1];
  178. char ikm_key[OAUTH_KEY_SIZE + 1];
  179. size_t ikm_key_size;
  180. turn_time_t timestamp;
  181. turn_time_t lifetime;
  182. char as_rs_alg[OAUTH_ALG_SIZE + 1];
  183. };
  184. typedef struct _oauth_key_data oauth_key_data;
  185. struct _oauth_key {
  186. char kid[OAUTH_KID_SIZE + 1];
  187. char ikm_key[OAUTH_KEY_SIZE + 1];
  188. size_t ikm_key_size;
  189. turn_time_t timestamp;
  190. turn_time_t lifetime;
  191. ENC_ALG as_rs_alg;
  192. char as_rs_key[OAUTH_KEY_SIZE + 1];
  193. size_t as_rs_key_size;
  194. char auth_key[OAUTH_KEY_SIZE + 1];
  195. size_t auth_key_size;
  196. };
  197. typedef struct _oauth_key oauth_key;
  198. struct _oauth_encrypted_block {
  199. uint16_t nonce_length;
  200. uint8_t nonce[OAUTH_MAX_NONCE_SIZE];
  201. uint16_t key_length;
  202. uint8_t mac_key[MAXSHASIZE];
  203. uint64_t timestamp;
  204. uint32_t lifetime;
  205. };
  206. typedef struct _oauth_encrypted_block oauth_encrypted_block;
  207. struct _oauth_token {
  208. oauth_encrypted_block enc_block;
  209. };
  210. typedef struct _oauth_token oauth_token;
  211. #define MAX_ENCODED_OAUTH_TOKEN_SIZE (1024)
  212. struct _encoded_oauth_token {
  213. char token[MAX_ENCODED_OAUTH_TOKEN_SIZE];
  214. size_t size;
  215. };
  216. typedef struct _encoded_oauth_token encoded_oauth_token;
  217. ////////////////////////////////////////////////
  218. #endif //__LIB_TURN_MSG_DEFS__