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