File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / ipsec-tools / src / racoon / nattraversal.h
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 22:39:10 2012 UTC (12 years, 5 months ago) by misho
Branches: ipsec-tools, MAIN
CVS tags: v0_8_2p2, v0_8_1p0, v0_8_1, v0_8_0p0, v0_8_0, HEAD
ipsec-tools

    1: /*	$NetBSD: nattraversal.h,v 1.7 2010/09/22 07:34:51 vanhu Exp $	*/
    2: 
    3: /*
    4:  * Copyright (C) 2004 SuSE Linux AG, Nuernberg, Germany.
    5:  * Contributed by: Michal Ludvig <mludvig@suse.cz>, SUSE Labs
    6:  * All rights reserved.
    7:  * 
    8:  * Redistribution and use in source and binary forms, with or without
    9:  * modification, are permitted provided that the following conditions
   10:  * are met:
   11:  * 1. Redistributions of source code must retain the above copyright
   12:  *    notice, this list of conditions and the following disclaimer.
   13:  * 2. Redistributions in binary form must reproduce the above copyright
   14:  *    notice, this list of conditions and the following disclaimer in the
   15:  *    documentation and/or other materials provided with the distribution.
   16:  * 3. Neither the name of the project nor the names of its contributors
   17:  *    may be used to endorse or promote products derived from this software
   18:  *    without specific prior written permission.
   19:  * 
   20:  * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
   21:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   22:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   23:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
   24:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   25:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   26:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   27:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   28:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   29:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   30:  * SUCH DAMAGE.
   31:  */
   32: 
   33: #ifndef _NATTRAVERSAL_H
   34: #define _NATTRAVERSAL_H
   35: 
   36: #include "vendorid.h"
   37: 
   38: #define	NAT_ANNOUNCED		(1L<<0)
   39: #define	NAT_DETECTED_ME		(1L<<1)
   40: #define	NAT_DETECTED_PEER	(1L<<2)
   41: #define	NAT_PORTS_CHANGED	(1L<<3)
   42: #define	NAT_KA_QUEUED		(1L<<4)
   43: #define	NAT_ADD_NON_ESP_MARKER	(1L<<5)
   44: 
   45: #define	NATT_AVAILABLE(_ph1)	((_ph1)->natt_flags & NAT_ANNOUNCED)
   46: 
   47: #define	NAT_DETECTED	(NAT_DETECTED_ME | NAT_DETECTED_PEER)
   48: 
   49: #define	NON_ESP_MARKER_LEN	sizeof(u_int32_t)
   50: #define	NON_ESP_MARKER_USE(_ph1)	((_ph1)->natt_flags & NAT_ADD_NON_ESP_MARKER)
   51: 
   52: /* These are the values from parsing "remote {}" 
   53:    block of the config file. */
   54: #define NATT_OFF	FLASE	/* = 0 */
   55: #define NATT_ON		TRUE	/* = 1 */
   56: #define NATT_FORCE	2
   57: 
   58: struct ph1natt_options {
   59:   int		version;
   60:   u_int16_t	float_port;
   61:   u_int16_t	mode_udp_tunnel;
   62:   u_int16_t	mode_udp_transport;
   63:   u_int16_t	encaps_type; /* ESPINUDP / ESPINUDP_NON_IKE */
   64:   u_int16_t	mode_udp_diff;
   65:   u_int16_t	payload_nat_d;
   66:   u_int16_t	payload_nat_oa;
   67: };
   68: 
   69: struct ph2natt {
   70:   u_int8_t	type;
   71:   u_int16_t	sport;
   72:   u_int16_t	dport;
   73:   struct sockaddr	*oa;
   74:   u_int16_t	frag;
   75: };
   76: 
   77: int natt_vendorid (int vid);
   78: vchar_t *natt_hash_addr (struct ph1handle *iph1, struct sockaddr *addr);
   79: int natt_compare_addr_hash (struct ph1handle *iph1, vchar_t *natd_received, int natd_seq);
   80: int natt_udp_encap (int encmode);
   81: int natt_fill_options (struct ph1natt_options *opts, int version);
   82: void natt_float_ports (struct ph1handle *iph1);
   83: void natt_handle_vendorid (struct ph1handle *iph1, int vid_numeric);
   84: 
   85: 
   86: struct payload_list *
   87: isakmp_plist_append_natt_vids (struct payload_list *plist, vchar_t *vid_natt[MAX_NATT_VID_COUNT]);
   88: 
   89: 
   90: /* NAT keepalive functions */
   91: void natt_keepalive_init (void);
   92: int natt_keepalive_add (struct sockaddr *src, struct sockaddr *dst);
   93: int natt_keepalive_add_ph1 (struct ph1handle *iph1);
   94: void natt_keepalive_remove (struct sockaddr *src, struct sockaddr *dst);
   95: 
   96: /* Walk through all rmconfigs and tell if NAT-T is enabled in at least one. */
   97: int natt_enabled_in_rmconf (void);
   98: 
   99: #endif /* _NATTRAVERSAL_H */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>