Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2015 Cisco and/or its affiliates. |
| 3 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | * you may not use this file except in compliance with the License. |
| 5 | * You may obtain a copy of the License at: |
| 6 | * |
| 7 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | * |
| 9 | * Unless required by applicable law or agreed to in writing, software |
| 10 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | * See the License for the specific language governing permissions and |
| 13 | * limitations under the License. |
| 14 | */ |
| 15 | #ifndef __included_ikev2_priv_h__ |
| 16 | #define __included_ikev2_priv_h__ |
| 17 | |
| 18 | #include <vnet/vnet.h> |
| 19 | #include <vnet/ip/ip.h> |
| 20 | #include <vnet/ethernet/ethernet.h> |
| 21 | |
| 22 | #include <vnet/ipsec/ikev2.h> |
| 23 | |
| 24 | #include <vppinfra/hash.h> |
| 25 | #include <vppinfra/elog.h> |
| 26 | #include <vppinfra/error.h> |
| 27 | |
| 28 | #include <openssl/rand.h> |
| 29 | #include <openssl/dh.h> |
| 30 | #include <openssl/hmac.h> |
| 31 | #include <openssl/evp.h> |
| 32 | |
| 33 | #define IKEV2_DEBUG_PAYLOAD 1 |
| 34 | |
| 35 | #if IKEV2_DEBUG_PAYLOAD == 1 |
| 36 | #define DBG_PLD(my_args...) clib_warning(my_args) |
| 37 | #else |
| 38 | #define DBG_PLD(my_args...) |
| 39 | #endif |
| 40 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 41 | typedef enum |
| 42 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 43 | IKEV2_STATE_UNKNOWN, |
| 44 | IKEV2_STATE_SA_INIT, |
| 45 | IKEV2_STATE_DELETED, |
| 46 | IKEV2_STATE_AUTH_FAILED, |
| 47 | IKEV2_STATE_AUTHENTICATED, |
| 48 | IKEV2_STATE_NOTIFY_AND_DELETE, |
| 49 | IKEV2_STATE_TS_UNACCEPTABLE, |
| 50 | IKEV2_STATE_NO_PROPOSAL_CHOSEN, |
| 51 | } ikev2_state_t; |
| 52 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 53 | typedef struct |
| 54 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 55 | ikev2_auth_method_t method:8; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 56 | u8 *data; |
| 57 | u8 hex; /* hex encoding of the shared secret */ |
| 58 | EVP_PKEY *key; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 59 | } ikev2_auth_t; |
| 60 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 61 | typedef enum |
| 62 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 63 | IKEV2_DH_GROUP_MODP = 0, |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 64 | IKEV2_DH_GROUP_ECP = 1, |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 65 | } ikev2_dh_group_t; |
| 66 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 67 | typedef struct |
| 68 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 69 | ikev2_transform_type_t type; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 70 | union |
| 71 | { |
| 72 | u16 transform_id; |
| 73 | ikev2_transform_encr_type_t encr_type:16; |
| 74 | ikev2_transform_prf_type_t prf_type:16; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 75 | ikev2_transform_integ_type_t integ_type:16; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 76 | ikev2_transform_dh_type_t dh_type:16; |
| 77 | ikev2_transform_esn_type_t esn_type:16; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 78 | }; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 79 | u8 *attrs; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 80 | u16 key_len; |
| 81 | u16 key_trunc; |
| 82 | u16 block_size; |
| 83 | u8 dh_group; |
| 84 | int nid; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 85 | const char *dh_p; |
| 86 | const char *dh_g; |
| 87 | const void *md; |
| 88 | const void *cipher; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 89 | } ikev2_sa_transform_t; |
| 90 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 91 | typedef struct |
| 92 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 93 | u8 proposal_num; |
| 94 | ikev2_protocol_id_t protocol_id:8; |
| 95 | u32 spi; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 96 | ikev2_sa_transform_t *transforms; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 97 | } ikev2_sa_proposal_t; |
| 98 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 99 | typedef struct |
| 100 | { |
| 101 | u8 ts_type; |
| 102 | u8 protocol_id; |
| 103 | u16 selector_len; |
| 104 | u16 start_port; |
| 105 | u16 end_port; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 106 | ip4_address_t start_addr; |
| 107 | ip4_address_t end_addr; |
| 108 | } ikev2_ts_t; |
| 109 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 110 | typedef struct |
| 111 | { |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 112 | u32 sw_if_index; |
| 113 | ip4_address_t ip4; |
| 114 | } ikev2_responder_t; |
| 115 | |
| 116 | typedef struct |
| 117 | { |
| 118 | ikev2_transform_encr_type_t crypto_alg; |
| 119 | ikev2_transform_integ_type_t integ_alg; |
| 120 | ikev2_transform_dh_type_t dh_type; |
| 121 | u32 crypto_key_size; |
| 122 | } ikev2_transforms_set; |
| 123 | |
| 124 | |
| 125 | typedef struct |
| 126 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 127 | ikev2_id_type_t type:8; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 128 | u8 *data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 129 | } ikev2_id_t; |
| 130 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 131 | typedef struct |
| 132 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 133 | /* sa proposals vectors */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 134 | ikev2_sa_proposal_t *i_proposals; |
| 135 | ikev2_sa_proposal_t *r_proposals; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 136 | |
| 137 | /* Traffic Selectors */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 138 | ikev2_ts_t *tsi; |
| 139 | ikev2_ts_t *tsr; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 140 | |
| 141 | /* keys */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 142 | u8 *sk_ai; |
| 143 | u8 *sk_ar; |
| 144 | u8 *sk_ei; |
| 145 | u8 *sk_er; |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 146 | |
| 147 | /* lifetime data */ |
| 148 | f64 time_to_expiration; |
| 149 | u8 is_expired; |
| 150 | i8 rekey_retries; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 151 | } ikev2_child_sa_t; |
| 152 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 153 | typedef struct |
| 154 | { |
| 155 | u8 protocol_id; |
| 156 | u32 spi; /*for ESP and AH SPI size is 4, for IKE size is 0 */ |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 157 | } ikev2_delete_t; |
| 158 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 159 | typedef struct |
| 160 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 161 | u8 protocol_id; |
| 162 | u32 spi; |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 163 | u32 ispi; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 164 | ikev2_sa_proposal_t *i_proposal; |
| 165 | ikev2_sa_proposal_t *r_proposal; |
| 166 | ikev2_ts_t *tsi; |
| 167 | ikev2_ts_t *tsr; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 168 | } ikev2_rekey_t; |
| 169 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 170 | typedef struct |
| 171 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 172 | u16 msg_type; |
| 173 | u8 protocol_id; |
| 174 | u32 spi; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 175 | u8 *data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 176 | } ikev2_notify_t; |
| 177 | |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 178 | typedef struct |
| 179 | { |
| 180 | u8 *name; |
| 181 | u8 is_enabled; |
| 182 | |
| 183 | ikev2_auth_t auth; |
| 184 | ikev2_id_t loc_id; |
| 185 | ikev2_id_t rem_id; |
| 186 | ikev2_ts_t loc_ts; |
| 187 | ikev2_ts_t rem_ts; |
| 188 | ikev2_responder_t responder; |
| 189 | ikev2_transforms_set ike_ts; |
| 190 | ikev2_transforms_set esp_ts; |
| 191 | u64 lifetime; |
| 192 | u64 lifetime_maxdata; |
| 193 | u32 lifetime_jitter; |
| 194 | u32 handover; |
| 195 | } ikev2_profile_t; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 196 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 197 | typedef struct |
| 198 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 199 | ikev2_state_t state; |
| 200 | u8 unsupported_cp; |
| 201 | u8 initial_contact; |
| 202 | ip4_address_t iaddr; |
| 203 | ip4_address_t raddr; |
| 204 | u64 ispi; |
| 205 | u64 rspi; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 206 | u8 *i_nonce; |
| 207 | u8 *r_nonce; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 208 | |
| 209 | /* DH data */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 210 | u16 dh_group; |
| 211 | u8 *dh_shared_key; |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 212 | u8 *dh_private_key; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 213 | u8 *i_dh_data; |
| 214 | u8 *r_dh_data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 215 | |
| 216 | /* sa proposals vectors */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 217 | ikev2_sa_proposal_t *i_proposals; |
| 218 | ikev2_sa_proposal_t *r_proposals; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 219 | |
| 220 | /* keys */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 221 | u8 *sk_d; |
| 222 | u8 *sk_ai; |
| 223 | u8 *sk_ar; |
| 224 | u8 *sk_ei; |
| 225 | u8 *sk_er; |
| 226 | u8 *sk_pi; |
| 227 | u8 *sk_pr; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 228 | |
| 229 | /* auth */ |
| 230 | ikev2_auth_t i_auth; |
| 231 | ikev2_auth_t r_auth; |
| 232 | |
| 233 | /* ID */ |
| 234 | ikev2_id_t i_id; |
| 235 | ikev2_id_t r_id; |
| 236 | |
| 237 | /* pending deletes */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 238 | ikev2_delete_t *del; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 239 | |
| 240 | /* pending rekeyings */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 241 | ikev2_rekey_t *rekey; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 242 | |
| 243 | /* packet data */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 244 | u8 *last_sa_init_req_packet_data; |
| 245 | u8 *last_sa_init_res_packet_data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 246 | |
| 247 | /* retransmit */ |
| 248 | u32 last_msg_id; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 249 | u8 *last_res_packet_data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 250 | |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 251 | u8 is_initiator; |
| 252 | u32 last_init_msg_id; |
| 253 | ikev2_profile_t *profile; |
| 254 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 255 | ikev2_child_sa_t *childs; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 256 | } ikev2_sa_t; |
| 257 | |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 258 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 259 | typedef struct |
| 260 | { |
| 261 | /* pool of IKEv2 Security Associations */ |
| 262 | ikev2_sa_t *sas; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 263 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 264 | /* hash */ |
| 265 | uword *sa_by_rspi; |
Matthew Smith | 2838a23 | 2016-06-21 16:05:09 -0500 | [diff] [blame] | 266 | } ikev2_main_per_thread_data_t; |
| 267 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 268 | typedef struct |
| 269 | { |
| 270 | /* pool of IKEv2 profiles */ |
| 271 | ikev2_profile_t *profiles; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 272 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 273 | /* vector of supported transform types */ |
| 274 | ikev2_sa_transform_t *supported_transforms; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 275 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 276 | /* hash */ |
| 277 | mhash_t profile_index_by_name; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 278 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 279 | /* local private key */ |
| 280 | EVP_PKEY *pkey; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 281 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 282 | /* convenience */ |
| 283 | vlib_main_t *vlib_main; |
| 284 | vnet_main_t *vnet_main; |
Matthew Smith | 2838a23 | 2016-06-21 16:05:09 -0500 | [diff] [blame] | 285 | |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 286 | /* pool of IKEv2 Security Associations created in initiator mode */ |
| 287 | ikev2_sa_t *sais; |
| 288 | /* hash */ |
| 289 | uword *sa_by_ispi; |
| 290 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 291 | ikev2_main_per_thread_data_t *per_thread_data; |
Matthew Smith | 2838a23 | 2016-06-21 16:05:09 -0500 | [diff] [blame] | 292 | |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 293 | } ikev2_main_t; |
| 294 | |
Dave Wallace | 71612d6 | 2017-10-24 01:32:41 -0400 | [diff] [blame] | 295 | extern ikev2_main_t ikev2_main; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 296 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 297 | void ikev2_sa_free_proposal_vector (ikev2_sa_proposal_t ** v); |
| 298 | ikev2_sa_transform_t *ikev2_sa_get_td_for_type (ikev2_sa_proposal_t * p, |
| 299 | ikev2_transform_type_t type); |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 300 | |
| 301 | /* ikev2_crypto.c */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 302 | v8 *ikev2_calc_prf (ikev2_sa_transform_t * tr, v8 * key, v8 * data); |
| 303 | u8 *ikev2_calc_prfplus (ikev2_sa_transform_t * tr, u8 * key, u8 * seed, |
| 304 | int len); |
| 305 | v8 *ikev2_calc_integr (ikev2_sa_transform_t * tr, v8 * key, u8 * data, |
| 306 | int len); |
| 307 | v8 *ikev2_decrypt_data (ikev2_sa_t * sa, u8 * data, int len); |
| 308 | int ikev2_encrypt_data (ikev2_sa_t * sa, v8 * src, u8 * dst); |
| 309 | void ikev2_generate_dh (ikev2_sa_t * sa, ikev2_sa_transform_t * t); |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 310 | void ikev2_complete_dh (ikev2_sa_t * sa, ikev2_sa_transform_t * t); |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 311 | int ikev2_verify_sign (EVP_PKEY * pkey, u8 * sigbuf, u8 * data); |
| 312 | u8 *ikev2_calc_sign (EVP_PKEY * pkey, u8 * data); |
| 313 | EVP_PKEY *ikev2_load_cert_file (u8 * file); |
| 314 | EVP_PKEY *ikev2_load_key_file (u8 * file); |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 315 | void ikev2_crypto_init (ikev2_main_t * km); |
| 316 | |
| 317 | /* ikev2_payload.c */ |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 318 | typedef struct |
| 319 | { |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 320 | u8 first_payload_type; |
| 321 | u16 last_hdr_off; |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 322 | u8 *data; |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 323 | } ikev2_payload_chain_t; |
| 324 | |
| 325 | #define ikev2_payload_new_chain(V) vec_validate (V, 0) |
| 326 | #define ikev2_payload_destroy_chain(V) do { \ |
| 327 | vec_free((V)->data); \ |
| 328 | vec_free(V); \ |
| 329 | } while (0) |
| 330 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 331 | void ikev2_payload_add_notify (ikev2_payload_chain_t * c, u16 msg_type, |
| 332 | u8 * data); |
Radu Nicolau | cb33dc2 | 2017-02-16 16:49:46 +0000 | [diff] [blame] | 333 | void ikev2_payload_add_notify_2 (ikev2_payload_chain_t * c, u16 msg_type, |
| 334 | u8 * data, ikev2_notify_t * notify); |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 335 | void ikev2_payload_add_sa (ikev2_payload_chain_t * c, |
| 336 | ikev2_sa_proposal_t * proposals); |
| 337 | void ikev2_payload_add_ke (ikev2_payload_chain_t * c, u16 dh_group, |
| 338 | u8 * dh_data); |
| 339 | void ikev2_payload_add_nonce (ikev2_payload_chain_t * c, u8 * nonce); |
| 340 | void ikev2_payload_add_id (ikev2_payload_chain_t * c, ikev2_id_t * id, |
| 341 | u8 type); |
| 342 | void ikev2_payload_add_auth (ikev2_payload_chain_t * c, ikev2_auth_t * auth); |
| 343 | void ikev2_payload_add_ts (ikev2_payload_chain_t * c, ikev2_ts_t * ts, |
| 344 | u8 type); |
| 345 | void ikev2_payload_add_delete (ikev2_payload_chain_t * c, ikev2_delete_t * d); |
| 346 | void ikev2_payload_chain_add_padding (ikev2_payload_chain_t * c, int bs); |
| 347 | void ikev2_parse_vendor_payload (ike_payload_header_t * ikep); |
| 348 | ikev2_sa_proposal_t *ikev2_parse_sa_payload (ike_payload_header_t * ikep); |
| 349 | ikev2_ts_t *ikev2_parse_ts_payload (ike_payload_header_t * ikep); |
| 350 | ikev2_delete_t *ikev2_parse_delete_payload (ike_payload_header_t * ikep); |
| 351 | ikev2_notify_t *ikev2_parse_notify_payload (ike_payload_header_t * ikep); |
Ed Warnicke | cb9cada | 2015-12-08 15:45:58 -0700 | [diff] [blame] | 352 | |
| 353 | #endif /* __included_ikev2_priv_h__ */ |
| 354 | |
Keith Burns (alagalah) | 166a9d4 | 2016-08-06 11:00:56 -0700 | [diff] [blame] | 355 | |
| 356 | /* |
| 357 | * fd.io coding-style-patch-verification: ON |
| 358 | * |
| 359 | * Local Variables: |
| 360 | * eval: (c-set-style "gnu") |
| 361 | * End: |
| 362 | */ |