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.8 by pcg, Sun Apr 13 16:53:36 2003 UTC vs.
Revision 1.16 by pcg, Wed Mar 2 05:49:31 2005 UTC

1/* 1/*
2 connection.h -- header for connection.C 2 connection.h -- header for connection.C
3 Copyright (C) 2003-2004 Marc Lehmann <pcg@goof.com>
3 4
4 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by 6 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 7 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version. 8 (at your option) any later version.
34 35
35struct rsaid { 36struct rsaid {
36 u8 id[RSA_IDLEN]; // the challenge id 37 u8 id[RSA_IDLEN]; // the challenge id
37}; 38};
38 39
39typedef u8 rsachallenge[RSA_KEYLEN - RSA_OVERHEAD]; // challenge data; 40typedef rsaclear rsachallenge; // challenge data;
40typedef u8 rsaencrdata[RSA_KEYLEN]; // encrypted challenge 41typedef rsacrypt rsaencrdata; // encrypted challenge
41typedef u8 rsaresponse[RSA_RESLEN]; // the encrypted ripemd160 hash 42typedef u8 rsaresponse[RSA_RESLEN]; // the encrypted ripemd160 hash
42 43
43//////////////////////////////////////////////////////////////////////////////////////// 44////////////////////////////////////////////////////////////////////////////////////////
44 45
45struct crypto_ctx; 46struct crypto_ctx;
46 47
47struct hmac_packet:net_packet 48struct hmac_packet : net_packet
48{ 49{
49 u8 hmac[HMACLENGTH]; // each and every packet has a hmac field, but that is not (yet) checked everywhere 50 u8 hmac[HMACLENGTH]; // each and every packet has a hmac field, but that is not (yet) checked everywhere
50 51
51 void hmac_set (crypto_ctx * ctx); 52 void hmac_set (crypto_ctx * ctx);
52 bool hmac_chk (crypto_ctx * ctx); 53 bool hmac_chk (crypto_ctx * ctx);
108 109
109 pkt_queue (); 110 pkt_queue ();
110 ~pkt_queue (); 111 ~pkt_queue ();
111 }; 112 };
112 113
114enum
115 {
116 FEATURE_COMPRESSION = 0x01,
117 FEATURE_ROHC = 0x02,
118 };
119
113struct connection 120struct connection
114 { 121 {
115 conf_node *conf; 122 conf_node *conf;
116 struct vpn *vpn; 123 struct vpn *vpn;
117 124
122 129
123 u32 oseqno; 130 u32 oseqno;
124 sliding_window iseqno; 131 sliding_window iseqno;
125 132
126 u8 protocol; 133 u8 protocol;
134 u8 features;
127 135
128 pkt_queue data_queue, vpn_queue; 136 pkt_queue data_queue, vpn_queue;
129 137
130 crypto_ctx *octx, *ictx; 138 crypto_ctx *octx, *ictx;
139
140#if ENABLE_DNS
141 sockinfo dns_si;
142
143 struct byte_stream *dns_rcvdq; int dns_rcvseq;
144 struct byte_stream *dns_snddq; int dns_sndseq;
145
146 void dnsv4_cb (time_watcher &w); time_watcher dnsv4_tw;
147 bool send_dnsv4_packet (vpn_packet *pkt, const sockinfo &si, int tos);
148#endif
131 149
132 enum conf_node::connectmode connectmode; 150 enum conf_node::connectmode connectmode;
133 u8 prot_minor; // minor number of other side 151 u8 prot_minor; // minor number of other side
134 152
135 void reset_si (); 153 void reset_si ();
147 void send_auth_request (const sockinfo &si, bool initiate); 165 void send_auth_request (const sockinfo &si, bool initiate);
148 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);
149 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols); 167 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols);
150 void send_reset (const sockinfo &dsi); 168 void send_reset (const sockinfo &dsi);
151 void send_ping (const sockinfo &dsi, u8 pong = 0); 169 void send_ping (const sockinfo &dsi, u8 pong = 0);
152 void send_data_packet (tap_packet *pkt, bool broadcast = false); 170 void send_data_packet (tap_packet *pkt);
153 171
154 void inject_data_packet (tap_packet *pkt, bool broadcast = false); 172 void inject_data_packet (tap_packet *pkt, bool broadcast = false);
155 void inject_vpn_packet (vpn_packet *pkt, int tos = 0); // for forwarding 173 void inject_vpn_packet (vpn_packet *pkt, int tos = 0); // for forwarding
156 174
157 void send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = 0); 175 void send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = 0);
161 const char *script_node_up (); 179 const char *script_node_up ();
162 const char *script_node_down (); 180 const char *script_node_down ();
163 181
164 void dump_status (); 182 void dump_status ();
165 183
166 connection(struct vpn *vpn_); 184 connection (struct vpn *vpn, conf_node *conf);
167 ~connection (); 185 ~connection ();
168 }; 186 };
169 187
170#endif 188#endif
171 189

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines