ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/gvpe/src/connection.h
(Generate patch)

Comparing gvpe/src/connection.h (file contents):
Revision 1.3 by pcg, Wed Apr 2 05:15:00 2003 UTC vs.
Revision 1.27 by pcg, Mon Dec 5 12:58:09 2005 UTC

1/* 1/*
2 connection.h -- header for connection.C 2 connection.h -- header for connection.C
3 Copyright (C) 2003-2005 Marc Lehmann <gvpe@schmorp.de>
3 4
5 This file is part of GVPE.
6
4 This program is free software; you can redistribute it and/or modify 7 GVPE is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by 8 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or 9 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version. 10 (at your option) any later version.
8 11
9 This program is distributed in the hope that it will be useful, 12 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of 13 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details. 15 GNU General Public License for more details.
13 16
14 You should have received a copy of the GNU General Public License 17 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software 18 along with gvpe; if not, write to the Free Software
16 Foundation, Inc. 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 19 Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17*/ 20*/
18 21
19#ifndef VPE_CONNECTION_H__ 22#ifndef GVPE_CONNECTION_H__
20#define VPE_CONNECTION_H__ 23#define GVPE_CONNECTION_H__
21
22#include <netinet/ip.h> // for tos etc.
23 24
24#include <openssl/hmac.h> 25#include <openssl/hmac.h>
25 26
26#include "global.h" 27#include "global.h"
27#include "conf.h" 28#include "conf.h"
36 37
37struct rsaid { 38struct rsaid {
38 u8 id[RSA_IDLEN]; // the challenge id 39 u8 id[RSA_IDLEN]; // the challenge id
39}; 40};
40 41
41typedef u8 rsachallenge[RSA_KEYLEN - RSA_OVERHEAD]; // challenge data; 42typedef rsaclear rsachallenge; // challenge data;
42typedef u8 rsaencrdata[RSA_KEYLEN]; // encrypted challenge 43typedef rsacrypt rsaencrdata; // encrypted challenge
43typedef u8 rsaresponse[RSA_RESLEN]; // the encrypted ripemd160 hash 44typedef u8 rsaresponse[RSA_RESLEN]; // the encrypted ripemd160 hash
44 45
45//////////////////////////////////////////////////////////////////////////////////////// 46////////////////////////////////////////////////////////////////////////////////////////
46 47
47struct crypto_ctx; 48struct crypto_ctx;
48 49
49struct hmac_packet:net_packet 50struct hmac_packet : net_packet
50{ 51{
51 u8 hmac[HMACLENGTH]; // each and every packet has a hmac field, but that is not (yet) checked everywhere 52 u8 hmac[HMACLENGTH]; // each and every packet has a hmac field, but that is not (yet) checked everywhere
52 53
53 void hmac_set (crypto_ctx * ctx); 54 void hmac_set (crypto_ctx * ctx);
54 bool hmac_chk (crypto_ctx * ctx); 55 bool hmac_chk (crypto_ctx * ctx);
67 PT_DATA_UNCOMPRESSED, 68 PT_DATA_UNCOMPRESSED,
68 PT_DATA_COMPRESSED, 69 PT_DATA_COMPRESSED,
69 PT_PING, PT_PONG, // wasting namespace space? ;) 70 PT_PING, PT_PONG, // wasting namespace space? ;)
70 PT_AUTH_REQ, // authentification request 71 PT_AUTH_REQ, // authentification request
71 PT_AUTH_RES, // authentification response 72 PT_AUTH_RES, // authentification response
72 PT_CONNECT_REQ, // want other host to contact me 73 PT_CONNECT_REQ, // want other node to contact me
73 PT_CONNECT_INFO, // request connection to some node 74 PT_CONNECT_INFO, // request connection to some node
75 PT_DATA_BRIDGED, // uncompressed packet with foreign mac pot. larger than path mtu
74 PT_MAX 76 PT_MAX
75 }; 77 };
76 78
77 u8 type; 79 u8 type;
78 u8 srcdst, src1, dst1; 80 u8 srcdst, src1, dst1;
79 81
80 void set_hdr (ptype type, unsigned int dst); 82 void set_hdr (ptype type_, unsigned int dst);
81 83
82 unsigned int src () const 84 unsigned int src () const
83 { 85 {
84 return src1 | ((srcdst >> 4) << 8); 86 return src1 | ((srcdst >> 4) << 8);
85 } 87 }
98//////////////////////////////////////////////////////////////////////////////////////// 100////////////////////////////////////////////////////////////////////////////////////////
99 101
100// a very simple fifo pkt-queue 102// a very simple fifo pkt-queue
101class pkt_queue 103class pkt_queue
102 { 104 {
103 tap_packet *queue[QUEUEDEPTH]; 105 net_packet *queue[QUEUEDEPTH];
104 int i, j; 106 int i, j;
105 107
106 public: 108 public:
107 109
108 void put (tap_packet *p); 110 void put (net_packet *p);
109 tap_packet *get (); 111 net_packet *get ();
110 112
111 pkt_queue (); 113 pkt_queue ();
112 ~pkt_queue (); 114 ~pkt_queue ();
115 };
116
117enum
118 {
119 FEATURE_COMPRESSION = 0x01,
120 FEATURE_ROHC = 0x02,
121 FEATURE_BRIDGING = 0x04,
113 }; 122 };
114 123
115struct connection 124struct connection
116 { 125 {
117 conf_node *conf; 126 conf_node *conf;
124 133
125 u32 oseqno; 134 u32 oseqno;
126 sliding_window iseqno; 135 sliding_window iseqno;
127 136
128 u8 protocol; 137 u8 protocol;
138 u8 features;
129 139
130 pkt_queue queue; 140 pkt_queue data_queue, vpn_queue;
131 141
132 crypto_ctx *octx, *ictx; 142 crypto_ctx *octx, *ictx;
143
144#if ENABLE_DNS
145 struct dns_connection *dns;
146
147 void dnsv4_reset_connection ();
148#endif
133 149
134 enum conf_node::connectmode connectmode; 150 enum conf_node::connectmode connectmode;
135 u8 prot_minor; // minor number of other side 151 u8 prot_minor; // minor number of other side
136 152
137 void reset_dstaddr (); 153 void reset_si ();
154 const sockinfo &forward_si (const sockinfo &si) const;
138 155
139 void shutdown (); 156 void shutdown ();
157 void connection_established ();
140 void reset_connection (); 158 void reset_connection ();
141 void establish_connection_cb (tstamp &ts); time_watcher establish_connection;
142 void rekey_cb (tstamp &ts); time_watcher rekey; // next rekying (actually current reset + reestablishing)
143 void keepalive_cb (tstamp &ts); time_watcher keepalive; // next keepalive probe
144 159
160 void establish_connection_cb (time_watcher &w); time_watcher establish_connection;
161 void rekey_cb (time_watcher &w); time_watcher rekey; // next rekying (actually current reset + reestablishing)
162 void keepalive_cb (time_watcher &w); time_watcher keepalive; // next keepalive probe
163
164 void send_connect_request (int id);
145 void send_auth_request (const sockinfo &si, bool initiate); 165 void send_auth_request (const sockinfo &si, bool initiate);
146 void send_auth_response (const sockinfo &si, const rsaid &id, const rsachallenge &chg); 166 void send_auth_response (const sockinfo &si, const rsaid &id, const rsachallenge &chg);
147 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols); 167 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols);
148 void send_reset (const sockinfo &dsi); 168 void send_reset (const sockinfo &dsi);
149 void send_ping (const sockinfo &dsi, u8 pong = 0); 169 void send_ping (const sockinfo &dsi, u8 pong = 0);
150 void send_data_packet (tap_packet *pkt, bool broadcast = false); 170 void send_data_packet (tap_packet *pkt);
171
151 void inject_data_packet (tap_packet *pkt, bool broadcast = false); 172 void inject_data_packet (tap_packet *pkt, bool broadcast = false);
152 void connect_request (int id); 173 void inject_vpn_packet (vpn_packet *pkt, int tos = 0); // for forwarding
153 174
154 void send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = IPTOS_RELIABILITY);
155 void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi); 175 void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi);
176 void send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = 0);
156 177
178 void script_init_env (const char *ext);
157 void script_node (); 179 void script_init_connect_env ();
158 const char *script_node_up (); 180 const char *script_node_up ();
159 const char *script_node_down (); 181 const char *script_node_down ();
160 182
161 void dump_status (); 183 void dump_status ();
162 184
163 connection(struct vpn *vpn_); 185 connection (struct vpn *vpn, conf_node *conf);
164 ~connection (); 186 ~connection ();
165 }; 187 };
166 188
167#endif 189#endif
168 190

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines