Initial revision
[tinc] / src / protocol.h
1 /*
2     protocol.h -- header for protocol.c
3     Copyright (C) 1999 Ivo Timmermans <zarq@iname.com>
4
5     This program is free software; you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation; either version 2 of the License, or
8     (at your option) any later version.
9
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14
15     You should have received a copy of the GNU General Public License
16     along with this program; if not, write to the Free Software
17     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 */
19
20 #ifndef __TINC_PROTOCOL_H__
21 #define __TINC_PROTOCOL_H__
22
23 #include "net.h"
24
25 enum {
26   PROT_RESERVED = 0,                 /* reserved: do not use. */
27   PROT_NOT_IN_USE,
28   PROT_TOO_OLD = 2,
29   PROT_3,
30   PROT_CURRENT,                      /* protocol currently in use */
31 };
32
33 enum {
34   ACK = 1,              /* acknowledged */
35   AUTH_S_INIT = 10,     /* initiate authentication */
36   AUTH_C_INIT,
37   AUTH_S_SPP,           /* send passphrase */
38   AUTH_C_SPP,
39   AUTH_S_SKEY,          /* send g^k */
40   AUTH_C_SKEY,
41   AUTH_S_SACK,          /* send ack */
42   AUTH_C_RACK,          /* waiting for ack */
43   TERMREQ = 30,         /* terminate connection */
44   PINGTIMEOUT,          /* terminate due to ping t.o. */
45   DEL_HOST,             /* forward a termreq to others */
46   PING = 40,            /* ping */
47   PONG,
48   ADD_HOST = 60,        /* Add new given host to connection list */
49   BASIC_INFO,           /* some basic info follows */
50   PASSPHRASE,           /* encrypted passphrase */
51   PUBLIC_KEY,           /* public key in base-36 */
52   HOLD = 80,            /* don't send any data */
53   RESUME,               /* resume dataflow with new encryption key */
54   CALCULATE = 100,      /* calculate the following numer^privkey and send me the result */  
55   CALC_RES,             /* result of the above */
56   ALMOST_KEY,           /* this number^privkey is the shared key */
57   REQ_KEY = 160,        /* request public key */
58   ANS_KEY,              /* answer to such request */
59   KEY_CHANGED,          /* public key has changed */
60 };
61
62 typedef struct add_host_t {
63   unsigned char type;
64   ip_t real_ip;
65   ip_t vpn_ip;
66   ip_t vpn_mask;
67   unsigned short portnr;
68 } add_host_t;
69
70 typedef struct termreq_t {
71   unsigned char type;
72   ip_t vpn_ip;
73 } termreq_t;
74
75 typedef struct basic_info_t {
76   unsigned char type;
77   unsigned char protocol;
78   unsigned short portnr;
79   ip_t vpn_ip;
80   ip_t vpn_mask;
81 } basic_info_t;
82
83 typedef struct calculate_t {
84   unsigned char type;
85   unsigned short len;
86   char key;
87 } calculate_t;
88
89 typedef struct public_key_t {
90   unsigned char type;
91   unsigned short len;
92   char key;
93 } public_key_t;
94
95 typedef struct key_req_t {
96   unsigned char type;
97   ip_t from;
98   ip_t to;
99   time_t expiry;
100   short int len; /* 0 if requesting */
101   char key;
102 } key_req_t;
103
104 typedef struct key_changed_t {
105   unsigned char type;
106   ip_t from;
107 } key_changed_t;
108
109 typedef struct del_host_t {
110   unsigned char type;
111   ip_t vpn_ip;
112 } del_host_t;
113
114 extern int (*request_handlers[256])(conn_list_t*, unsigned char*, int);
115
116 extern int send_ping(conn_list_t*);
117 extern int send_basic_info(conn_list_t *);
118 extern int send_termreq(conn_list_t *);
119 extern int send_timeout(conn_list_t *);
120 extern int send_key_request(ip_t);
121 extern void send_key_changed2(void);
122
123 #endif /* __TINC_PROTOCOL_H__ */
124