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.5 by pcg, Sat Apr 5 02:32:40 2003 UTC vs.
Revision 1.12 by pcg, Sat Jan 17 01:18:36 2004 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;
96//////////////////////////////////////////////////////////////////////////////////////// 97////////////////////////////////////////////////////////////////////////////////////////
97 98
98// a very simple fifo pkt-queue 99// a very simple fifo pkt-queue
99class pkt_queue 100class pkt_queue
100 { 101 {
101 tap_packet *queue[QUEUEDEPTH]; 102 net_packet *queue[QUEUEDEPTH];
102 int i, j; 103 int i, j;
103 104
104 public: 105 public:
105 106
106 void put (tap_packet *p); 107 void put (net_packet *p);
107 tap_packet *get (); 108 net_packet *get ();
108 109
109 pkt_queue (); 110 pkt_queue ();
110 ~pkt_queue (); 111 ~pkt_queue ();
111 }; 112 };
112 113
123 u32 oseqno; 124 u32 oseqno;
124 sliding_window iseqno; 125 sliding_window iseqno;
125 126
126 u8 protocol; 127 u8 protocol;
127 128
128 pkt_queue queue; 129 pkt_queue data_queue, vpn_queue;
129 130
130 crypto_ctx *octx, *ictx; 131 crypto_ctx *octx, *ictx;
131 132
132 enum conf_node::connectmode connectmode; 133 enum conf_node::connectmode connectmode;
133 u8 prot_minor; // minor number of other side 134 u8 prot_minor; // minor number of other side
134 135
135 void reset_dstaddr (); 136 void reset_si ();
137 const sockinfo &forward_si (const sockinfo &si) const;
136 138
137 void shutdown (); 139 void shutdown ();
140 void connection_established ();
138 void reset_connection (); 141 void reset_connection ();
142
139 void establish_connection_cb (time_watcher &w); time_watcher establish_connection; 143 void establish_connection_cb (time_watcher &w); time_watcher establish_connection;
140 void rekey_cb (time_watcher &w); time_watcher rekey; // next rekying (actually current reset + reestablishing) 144 void rekey_cb (time_watcher &w); time_watcher rekey; // next rekying (actually current reset + reestablishing)
141 void keepalive_cb (time_watcher &w); time_watcher keepalive; // next keepalive probe 145 void keepalive_cb (time_watcher &w); time_watcher keepalive; // next keepalive probe
142 146
147 void send_connect_request (int id);
143 void send_auth_request (const sockinfo &si, bool initiate); 148 void send_auth_request (const sockinfo &si, bool initiate);
144 void send_auth_response (const sockinfo &si, const rsaid &id, const rsachallenge &chg); 149 void send_auth_response (const sockinfo &si, const rsaid &id, const rsachallenge &chg);
145 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols); 150 void send_connect_info (int rid, const sockinfo &rsi, u8 rprotocols);
146 void send_reset (const sockinfo &dsi); 151 void send_reset (const sockinfo &dsi);
147 void send_ping (const sockinfo &dsi, u8 pong = 0); 152 void send_ping (const sockinfo &dsi, u8 pong = 0);
148 void send_data_packet (tap_packet *pkt, bool broadcast = false); 153 void send_data_packet (tap_packet *pkt);
154
149 void inject_data_packet (tap_packet *pkt, bool broadcast = false); 155 void inject_data_packet (tap_packet *pkt, bool broadcast = false);
150 void connect_request (int id); 156 void inject_vpn_packet (vpn_packet *pkt, int tos = 0); // for forwarding
151 157
158 void send_vpn_packet (vpn_packet *pkt, const sockinfo &si, int tos = 0);
152 void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi); 159 void recv_vpn_packet (vpn_packet *pkt, const sockinfo &rsi);
153 160
154 void script_node (); 161 void script_node ();
155 const char *script_node_up (); 162 const char *script_node_up ();
156 const char *script_node_down (); 163 const char *script_node_down ();

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines