156893Sfenner/*
256893Sfenner * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
356893Sfenner * All rights reserved.
4127668Sbms *
556893Sfenner * Redistribution and use in source and binary forms, with or without
656893Sfenner * modification, are permitted provided that the following conditions
756893Sfenner * are met:
856893Sfenner * 1. Redistributions of source code must retain the above copyright
956893Sfenner *    notice, this list of conditions and the following disclaimer.
1056893Sfenner * 2. Redistributions in binary form must reproduce the above copyright
1156893Sfenner *    notice, this list of conditions and the following disclaimer in the
1256893Sfenner *    documentation and/or other materials provided with the distribution.
1356893Sfenner * 3. Neither the name of the project nor the names of its contributors
1456893Sfenner *    may be used to endorse or promote products derived from this software
1556893Sfenner *    without specific prior written permission.
16127668Sbms *
1756893Sfenner * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
1856893Sfenner * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1956893Sfenner * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2056893Sfenner * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
2156893Sfenner * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2256893Sfenner * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2356893Sfenner * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2456893Sfenner * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2556893Sfenner * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2656893Sfenner * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2756893Sfenner * SUCH DAMAGE.
2856893Sfenner */
29190207Srpaulo/* YIPS @(#)$Id: oakley.h,v 1.4 2002-12-11 07:13:56 guy Exp $ */
3056893Sfenner
3156893Sfenner/* refer to RFC 2409 */
3256893Sfenner
3356893Sfenner#if !defined(_ISAKMP_OAKLEY_H_)
3456893Sfenner#define _ISAKMP_OAKLEY_H_
3556893Sfenner
3656893Sfenner/* Attribute Classes */
3756893Sfenner#define OAKLEY_ATTR_ENC_ALG                   1 /* B */
3856893Sfenner#define   OAKLEY_ATTR_ENC_ALG_DES               1
3956893Sfenner#define   OAKLEY_ATTR_ENC_ALG_IDEA              2
4056893Sfenner#define   OAKLEY_ATTR_ENC_ALG_BL                3
4156893Sfenner#define   OAKLEY_ATTR_ENC_ALG_RC5               4
4256893Sfenner#define   OAKLEY_ATTR_ENC_ALG_3DES              5
4356893Sfenner#define   OAKLEY_ATTR_ENC_ALG_CAST              6
4456893Sfenner#define OAKLEY_ATTR_HASH_ALG                  2 /* B */
4556893Sfenner#define   OAKLEY_ATTR_HASH_ALG_MD5              1
4656893Sfenner#define   OAKLEY_ATTR_HASH_ALG_SHA              2
4756893Sfenner#define   OAKLEY_ATTR_HASH_ALG_TIGER            3
4856893Sfenner#define OAKLEY_ATTR_AUTH_METHOD               3 /* B */
4956893Sfenner#define   OAKLEY_ATTR_AUTH_METHOD_PSKEY         1
5056893Sfenner#define   OAKLEY_ATTR_AUTH_METHOD_DSS           2
5156893Sfenner#define   OAKLEY_ATTR_AUTH_METHOD_RSA           3
5256893Sfenner#define   OAKLEY_ATTR_AUTH_METHOD_RSAENC        4
5356893Sfenner#define   OAKLEY_ATTR_AUTH_METHOD_RSAREV        5
5456893Sfenner#define OAKLEY_ATTR_GRP_DESC                  4 /* B */
5556893Sfenner#define   OAKLEY_ATTR_GRP_DESC_MODP768          1
5656893Sfenner#define   OAKLEY_ATTR_GRP_DESC_MODP1024         2
5756893Sfenner#define   OAKLEY_ATTR_GRP_DESC_EC2N155          3
5856893Sfenner#define   OAKLEY_ATTR_GRP_DESC_EC2N185          4
5956893Sfenner#define OAKLEY_ATTR_GRP_TYPE                  5 /* B */
6056893Sfenner#define   OAKLEY_ATTR_GRP_TYPE_MODP             1
6156893Sfenner#define   OAKLEY_ATTR_GRP_TYPE_ECP              2
6256893Sfenner#define   OAKLEY_ATTR_GRP_TYPE_EC2N             3
6356893Sfenner#define OAKLEY_ATTR_GRP_PI                    6 /* V */
6456893Sfenner#define OAKLEY_ATTR_GRP_GEN_ONE               7 /* V */
6556893Sfenner#define OAKLEY_ATTR_GRP_GEN_TWO               8 /* V */
6656893Sfenner#define OAKLEY_ATTR_GRP_CURVE_A               9 /* V */
6756893Sfenner#define OAKLEY_ATTR_GRP_CURVE_B              10 /* V */
6856893Sfenner#define OAKLEY_ATTR_SA_LTYPE                 11 /* B */
6956893Sfenner#define   OAKLEY_ATTR_SA_LTYPE_DEFAULT          1
7056893Sfenner#define   OAKLEY_ATTR_SA_LTYPE_SEC              1
7156893Sfenner#define   OAKLEY_ATTR_SA_LTYPE_KB               2
7256893Sfenner#define OAKLEY_ATTR_SA_LDUR                  12 /* V */
7356893Sfenner#define   OAKLEY_ATTR_SA_LDUR_DEFAULT           28800 /* 8 hours */
7456893Sfenner#define OAKLEY_ATTR_PRF                      13 /* B */
7556893Sfenner#define OAKLEY_ATTR_KEY_LEN                  14 /* B */
7656893Sfenner#define OAKLEY_ATTR_FIELD_SIZE               15 /* B */
7756893Sfenner#define OAKLEY_ATTR_GRP_ORDER                16 /* V */
7856893Sfenner
7956893Sfenner#define OAKLEY_ID_IPV4_ADDR          0
8056893Sfenner#define OAKLEY_ID_IPV4_ADDR_SUBNET   1
8156893Sfenner#define OAKLEY_ID_IPV6_ADDR          2
8256893Sfenner#define OAKLEY_ID_IPV6_ADDR_SUBNET   3
8356893Sfenner
8456893Sfenner/* Additional Exchange Type */
8556893Sfenner#define ISAKMP_ETYPE_QUICK    32
8656893Sfenner#define ISAKMP_ETYPE_NEWGRP   33
8756893Sfenner
8856893Sfenner/* The use for checking proposal payload. This is not exchange type. */
8956893Sfenner#define OAKLEY_MAIN_MODE    0
9056893Sfenner#define OAKLEY_QUICK_MODE   1
9156893Sfenner
9256893Sfenner#define OAKLEY_PRIME_MODP768 "\
9356893Sfenner	FFFFFFFF FFFFFFFF C90FDAA2 2168C234 C4C6628B 80DC1CD1 \
9456893Sfenner	29024E08 8A67CC74 020BBEA6 3B139B22 514A0879 8E3404DD \
9556893Sfenner	EF9519B3 CD3A431B 302B0A6D F25F1437 4FE1356D 6D51C245 \
9656893Sfenner	E485B576 625E7EC6 F44C42E9 A63A3620 FFFFFFFF FFFFFFFF"
9756893Sfenner
9856893Sfenner#define OAKLEY_PRIME_MODP1024 "\
9956893Sfenner	FFFFFFFF FFFFFFFF C90FDAA2 2168C234 C4C6628B 80DC1CD1 \
10056893Sfenner	29024E08 8A67CC74 020BBEA6 3B139B22 514A0879 8E3404DD \
10156893Sfenner	EF9519B3 CD3A431B 302B0A6D F25F1437 4FE1356D 6D51C245 \
10256893Sfenner	E485B576 625E7EC6 F44C42E9 A637ED6B 0BFF5CB6 F406B7ED \
10356893Sfenner	EE386BFB 5A899FA5 AE9F2411 7C4B1FE6 49286651 ECE65381 \
10456893Sfenner	FFFFFFFF FFFFFFFF"
10556893Sfenner
10656893Sfenner#define DEFAULTSECRETSIZE ( 128 / 8 ) /* 128 bits */
10756893Sfenner#define DEFAULTNONCESIZE  ( 128 / 8 ) /* 128 bits */
10856893Sfenner
10956893Sfenner#define MAXPADLWORD 20
11056893Sfenner
11156893Sfenner#if 0
11256893Sfenner/* isakmp sa structure */
11356893Sfennerstruct oakley_sa {
11456893Sfenner	u_int8_t  proto_id;            /* OAKLEY */
11556893Sfenner	vchar_t   *spi;                /* spi */
11656893Sfenner	u_int8_t  dhgrp;               /* DH; group */
11756893Sfenner	u_int8_t  auth_t;              /* method of authentication */
11856893Sfenner	u_int8_t  prf_t;               /* type of prf */
11956893Sfenner	u_int8_t  hash_t;              /* type of hash */
12056893Sfenner	u_int8_t  enc_t;               /* type of cipher */
12156893Sfenner	u_int8_t  life_t;              /* type of duration of lifetime */
12256893Sfenner	u_int32_t ldur;                /* life duration */
12356893Sfenner};
12456893Sfenner#endif
12556893Sfenner
12656893Sfenner#endif /* !defined(_ISAKMP_OAKLEY_H_) */
127