oakley.h revision 1.1.1.1
1217044Snwhitehorn/* 2217044Snwhitehorn * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. 3217044Snwhitehorn * All rights reserved. 4217044Snwhitehorn * 5217044Snwhitehorn * Redistribution and use in source and binary forms, with or without 6217044Snwhitehorn * modification, are permitted provided that the following conditions 7217044Snwhitehorn * are met: 8217044Snwhitehorn * 1. Redistributions of source code must retain the above copyright 9217044Snwhitehorn * notice, this list of conditions and the following disclaimer. 10217044Snwhitehorn * 2. Redistributions in binary form must reproduce the above copyright 11217044Snwhitehorn * notice, this list of conditions and the following disclaimer in the 12217044Snwhitehorn * documentation and/or other materials provided with the distribution. 13217044Snwhitehorn * 3. Neither the name of the project nor the names of its contributors 14223460Snwhitehorn * may be used to endorse or promote products derived from this software 15223460Snwhitehorn * without specific prior written permission. 16223460Snwhitehorn * 17223460Snwhitehorn * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND 18223460Snwhitehorn * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19223460Snwhitehorn * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20223460Snwhitehorn * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE 21223460Snwhitehorn * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22223460Snwhitehorn * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23223460Snwhitehorn * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24223460Snwhitehorn * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25223460Snwhitehorn * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26223460Snwhitehorn * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27223460Snwhitehorn * SUCH DAMAGE. 28223460Snwhitehorn */ 29223460Snwhitehorn/* YIPS @(#)Id: oakley.h,v 1.4 2002-12-11 07:13:56 guy Exp */ 30223460Snwhitehorn 31223460Snwhitehorn/* refer to RFC 2409 */ 32223460Snwhitehorn 33223460Snwhitehorn#if !defined(_ISAKMP_OAKLEY_H_) 34223460Snwhitehorn#define _ISAKMP_OAKLEY_H_ 35223460Snwhitehorn 36223460Snwhitehorn/* Attribute Classes */ 37223460Snwhitehorn#define OAKLEY_ATTR_ENC_ALG 1 /* B */ 38223460Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_DES 1 39223460Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_IDEA 2 40223460Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_BL 3 41223460Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_RC5 4 42217044Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_3DES 5 43217044Snwhitehorn#define OAKLEY_ATTR_ENC_ALG_CAST 6 44217044Snwhitehorn#define OAKLEY_ATTR_HASH_ALG 2 /* B */ 45217044Snwhitehorn#define OAKLEY_ATTR_HASH_ALG_MD5 1 46217044Snwhitehorn#define OAKLEY_ATTR_HASH_ALG_SHA 2 47217044Snwhitehorn#define OAKLEY_ATTR_HASH_ALG_TIGER 3 48217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD 3 /* B */ 49217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD_PSKEY 1 50217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD_DSS 2 51217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD_RSA 3 52217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD_RSAENC 4 53217044Snwhitehorn#define OAKLEY_ATTR_AUTH_METHOD_RSAREV 5 54217044Snwhitehorn#define OAKLEY_ATTR_GRP_DESC 4 /* B */ 55217044Snwhitehorn#define OAKLEY_ATTR_GRP_DESC_MODP768 1 56217044Snwhitehorn#define OAKLEY_ATTR_GRP_DESC_MODP1024 2 57217044Snwhitehorn#define OAKLEY_ATTR_GRP_DESC_EC2N155 3 58217044Snwhitehorn#define OAKLEY_ATTR_GRP_DESC_EC2N185 4 59217044Snwhitehorn#define OAKLEY_ATTR_GRP_TYPE 5 /* B */ 60217044Snwhitehorn#define OAKLEY_ATTR_GRP_TYPE_MODP 1 61217044Snwhitehorn#define OAKLEY_ATTR_GRP_TYPE_ECP 2 62217044Snwhitehorn#define OAKLEY_ATTR_GRP_TYPE_EC2N 3 63217044Snwhitehorn#define OAKLEY_ATTR_GRP_PI 6 /* V */ 64217044Snwhitehorn#define OAKLEY_ATTR_GRP_GEN_ONE 7 /* V */ 65217044Snwhitehorn#define OAKLEY_ATTR_GRP_GEN_TWO 8 /* V */ 66217044Snwhitehorn#define OAKLEY_ATTR_GRP_CURVE_A 9 /* V */ 67217044Snwhitehorn#define OAKLEY_ATTR_GRP_CURVE_B 10 /* V */ 68217044Snwhitehorn#define OAKLEY_ATTR_SA_LTYPE 11 /* B */ 69217044Snwhitehorn#define OAKLEY_ATTR_SA_LTYPE_DEFAULT 1 70217044Snwhitehorn#define OAKLEY_ATTR_SA_LTYPE_SEC 1 71217044Snwhitehorn#define OAKLEY_ATTR_SA_LTYPE_KB 2 72217044Snwhitehorn#define OAKLEY_ATTR_SA_LDUR 12 /* V */ 73217044Snwhitehorn#define OAKLEY_ATTR_SA_LDUR_DEFAULT 28800 /* 8 hours */ 74217044Snwhitehorn#define OAKLEY_ATTR_PRF 13 /* B */ 75217044Snwhitehorn#define OAKLEY_ATTR_KEY_LEN 14 /* B */ 76217044Snwhitehorn#define OAKLEY_ATTR_FIELD_SIZE 15 /* B */ 77217044Snwhitehorn#define OAKLEY_ATTR_GRP_ORDER 16 /* V */ 78217044Snwhitehorn 79217044Snwhitehorn#define OAKLEY_ID_IPV4_ADDR 0 80217044Snwhitehorn#define OAKLEY_ID_IPV4_ADDR_SUBNET 1 81217044Snwhitehorn#define OAKLEY_ID_IPV6_ADDR 2 82217044Snwhitehorn#define OAKLEY_ID_IPV6_ADDR_SUBNET 3 83217044Snwhitehorn 84217044Snwhitehorn/* Additional Exchange Type */ 85217044Snwhitehorn#define ISAKMP_ETYPE_QUICK 32 86217044Snwhitehorn#define ISAKMP_ETYPE_NEWGRP 33 87217044Snwhitehorn 88217044Snwhitehorn/* The use for checking proposal payload. This is not exchange type. */ 89217044Snwhitehorn#define OAKLEY_MAIN_MODE 0 90217044Snwhitehorn#define OAKLEY_QUICK_MODE 1 91217044Snwhitehorn 92217044Snwhitehorn#define OAKLEY_PRIME_MODP768 "\ 93217044Snwhitehorn FFFFFFFF FFFFFFFF C90FDAA2 2168C234 C4C6628B 80DC1CD1 \ 94217044Snwhitehorn 29024E08 8A67CC74 020BBEA6 3B139B22 514A0879 8E3404DD \ 95217044Snwhitehorn EF9519B3 CD3A431B 302B0A6D F25F1437 4FE1356D 6D51C245 \ 96217044Snwhitehorn E485B576 625E7EC6 F44C42E9 A63A3620 FFFFFFFF FFFFFFFF" 97217044Snwhitehorn 98217044Snwhitehorn#define OAKLEY_PRIME_MODP1024 "\ 99217044Snwhitehorn FFFFFFFF FFFFFFFF C90FDAA2 2168C234 C4C6628B 80DC1CD1 \ 100217044Snwhitehorn 29024E08 8A67CC74 020BBEA6 3B139B22 514A0879 8E3404DD \ 101217044Snwhitehorn EF9519B3 CD3A431B 302B0A6D F25F1437 4FE1356D 6D51C245 \ 102217044Snwhitehorn E485B576 625E7EC6 F44C42E9 A637ED6B 0BFF5CB6 F406B7ED \ 103217044Snwhitehorn EE386BFB 5A899FA5 AE9F2411 7C4B1FE6 49286651 ECE65381 \ 104217044Snwhitehorn FFFFFFFF FFFFFFFF" 105217044Snwhitehorn 106217044Snwhitehorn#define DEFAULTSECRETSIZE ( 128 / 8 ) /* 128 bits */ 107217044Snwhitehorn#define DEFAULTNONCESIZE ( 128 / 8 ) /* 128 bits */ 108217044Snwhitehorn 109217044Snwhitehorn#define MAXPADLWORD 20 110217044Snwhitehorn 111217044Snwhitehorn#if 0 112217044Snwhitehorn/* isakmp sa structure */ 113217044Snwhitehornstruct oakley_sa { 114217044Snwhitehorn u_int8_t proto_id; /* OAKLEY */ 115217044Snwhitehorn vchar_t *spi; /* spi */ 116217044Snwhitehorn u_int8_t dhgrp; /* DH; group */ 117217044Snwhitehorn u_int8_t auth_t; /* method of authentication */ 118217044Snwhitehorn u_int8_t prf_t; /* type of prf */ 119217044Snwhitehorn u_int8_t hash_t; /* type of hash */ 120217044Snwhitehorn u_int8_t enc_t; /* type of cipher */ 121217044Snwhitehorn u_int8_t life_t; /* type of duration of lifetime */ 122217044Snwhitehorn u_int32_t ldur; /* life duration */ 123217044Snwhitehorn}; 124217044Snwhitehorn#endif 125217044Snwhitehorn 126217044Snwhitehorn#endif /* !defined(_ISAKMP_OAKLEY_H_) */ 127228689Snwhitehorn