--- gvpe/src/vpn.h 2003/04/02 03:25:17 1.1 +++ gvpe/src/vpn.h 2008/08/07 17:54:27 1.28 @@ -1,71 +1,115 @@ /* vpn.h -- header for vpn.C + Copyright (C) 2003-2008 Marc Lehmann - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc. 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + This file is part of GVPE. + + GVPE is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by the + Free Software Foundation; either version 3 of the License, or (at your + option) any later version. + + This program is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General + Public License for more details. + + You should have received a copy of the GNU General Public License along + with this program; if not, see . + + Additional permission under GNU GPL version 3 section 7 + + If you modify this Program, or any covered work, by linking or + combining it with the OpenSSL project's OpenSSL library (or a modified + version of that library), containing parts covered by the terms of the + OpenSSL or SSLeay licenses, the licensors of this Program grant you + additional permission to convey the resulting work. Corresponding + Source for a non-source form of such a combination shall include the + source code for the parts of OpenSSL used as well as that of the + covered work. */ -#ifndef VPE_VPN_H__ -#define VPE_VPN_H__ +#ifndef GVPE_VPN_H__ +#define GVPE_VPN_H__ +#include "global.h" #include "conf.h" #include "device.h" #include "connection.h" struct vpn - { - int udpv4_fd; - int ipv4_fd; +{ + int udpv4_fd , tcpv4_fd, ipv4_fd , icmpv4_fd , dnsv4_fd; + int udpv4_tos, ipv4_tos, icmpv4_tos, dnsv4_tos; + + int events; + + enum { + EVENT_RECONNECT = 1, + EVENT_SHUTDOWN = 2, + }; - int events; + void event_cb (ev::timer &w, int revents); ev::timer event; - enum { - EVENT_RECONNECT = 1, - EVENT_SHUTDOWN = 2, - }; + tap_device *tap; - void event_cb (tstamp &ts); time_watcher event; + typedef vector conns_vector; + conns_vector conns; - tap_device *tap; + connection *find_router (); + connection *find_forwarder (); - typedef vector conns_vector; - conns_vector conns; + void reconnect_all (); + void shutdown_all (); - connection *find_router (); + void tap_ev (ev::io &w, int revents); ev::io tap_ev_watcher; + void inject_data_packet (tap_packet *pkt, int dst); - void reconnect_all (); - void shutdown_all (); - void connect_request (int id); + void send_connect_request (int id); - void tap_ev (short revents); io_watcher tap_ev_watcher; - void ipv4_ev (short revents); io_watcher ipv4_ev_watcher; - void udpv4_ev (short revents); io_watcher udpv4_ev_watcher; + void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi); + bool send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = 0); - void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi); +#if ENABLE_TCP + void tcpv4_ev (ev::io &w, int revents); ev::io tcpv4_ev_watcher; + bool send_tcpv4_packet (vpn_packet *pkt, const sockinfo &si, int tos); +#endif - void send_udpv4_packet (vpn_packet *pkt, const sockinfo &si, int tos = IPTOS_RELIABILITY); - void send_ipv4_packet (vpn_packet *pkt, const sockinfo &si, int tos = IPTOS_RELIABILITY); +#if ENABLE_ICMP + void icmpv4_ev (ev::io &w, int revents); ev::io icmpv4_ev_watcher; + bool send_icmpv4_packet (vpn_packet *pkt, const sockinfo &si, int tos); +#endif - vpn (); - ~vpn (); +#if ENABLE_DNS + vector dns_sndpq; + sockinfo dns_forwarder; + + void dnsv4_ev (ev::io &w, int revents); ev::io dnsv4_ev_watcher; + void dnsv4_server (struct dns_packet &pkt); + void dnsv4_client (struct dns_packet &pkt); - int setup (); + bool send_dnsv4_packet (vpn_packet *pkt, const sockinfo &si, int tos); +#endif - void dump_status (); + void udpv4_ev (ev::io &w, int revents); ev::io udpv4_ev_watcher; + bool send_udpv4_packet (vpn_packet *pkt, const sockinfo &si, int tos); - const char *script_if_up (int); - }; + void ipv4_ev (ev::io &w, int revents); ev::io ipv4_ev_watcher; + bool send_ipv4_packet (vpn_packet *pkt, const sockinfo &si, int tos); + + vpn (); + ~vpn (); + + int setup (); + + void dump_status (); + + void script_init_env (); + const char *script_if_init (); + const char *script_if_up (); +}; + +extern vpn network; // THE vpn #endif