2019-08-26 11:44:48 +00:00
|
|
|
#ifndef TINC_PROTOCOL_H
|
|
|
|
#define TINC_PROTOCOL_H
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
/*
|
|
|
|
protocol.h -- header for protocol.c
|
2019-08-26 11:44:37 +00:00
|
|
|
Copyright (C) 1999-2005 Ivo Timmermans,
|
2019-08-26 11:44:46 +00:00
|
|
|
2000-2015 Guus Sliepen <guus@tinc-vpn.org>
|
2019-08-26 11:44:36 +00:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2019-08-26 11:44:38 +00:00
|
|
|
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.,
|
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2019-08-26 11:44:36 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* Protocol version. Different versions are incompatible,
|
|
|
|
incompatible version have different protocols.
|
|
|
|
*/
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
#define PROT_CURRENT 17
|
|
|
|
|
|
|
|
/* Silly Windows */
|
|
|
|
|
|
|
|
#ifdef ERROR
|
|
|
|
#undef ERROR
|
|
|
|
#endif
|
2019-08-26 11:44:36 +00:00
|
|
|
|
|
|
|
/* Request numbers */
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
typedef enum request_t {
|
2019-08-26 11:44:46 +00:00
|
|
|
PROXY = -2,
|
2019-08-26 11:44:48 +00:00
|
|
|
ALL = -1, /* Guardian for allow_request */
|
2019-08-26 11:44:36 +00:00
|
|
|
ID = 0, METAKEY, CHALLENGE, CHAL_REPLY, ACK,
|
|
|
|
STATUS, ERROR, TERMREQ,
|
|
|
|
PING, PONG,
|
|
|
|
ADD_SUBNET, DEL_SUBNET,
|
|
|
|
ADD_EDGE, DEL_EDGE,
|
|
|
|
KEY_CHANGED, REQ_KEY, ANS_KEY,
|
|
|
|
PACKET,
|
2019-08-26 11:44:48 +00:00
|
|
|
LAST /* Guardian for the highest request number */
|
2019-08-26 11:44:36 +00:00
|
|
|
} request_t;
|
2019-08-26 11:44:36 +00:00
|
|
|
|
|
|
|
typedef struct past_request_t {
|
2019-08-26 11:44:36 +00:00
|
|
|
char *request;
|
|
|
|
time_t firstseen;
|
2019-08-26 11:44:36 +00:00
|
|
|
} past_request_t;
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
extern bool tunnelserver;
|
2019-08-26 11:44:40 +00:00
|
|
|
extern bool strictsubnets;
|
2019-08-26 11:44:36 +00:00
|
|
|
|
2019-08-26 11:44:37 +00:00
|
|
|
/* Maximum size of strings in a request.
|
|
|
|
* scanf terminates %2048s with a NUL character,
|
|
|
|
* but the NUL character can be written after the 2048th non-NUL character.
|
|
|
|
*/
|
2019-08-26 11:44:36 +00:00
|
|
|
|
2019-08-26 11:44:37 +00:00
|
|
|
#define MAX_STRING_SIZE 2049
|
2019-08-26 11:44:36 +00:00
|
|
|
#define MAX_STRING "%2048s"
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
#include "edge.h"
|
|
|
|
#include "net.h"
|
|
|
|
#include "node.h"
|
|
|
|
#include "subnet.h"
|
|
|
|
|
2019-08-26 11:44:36 +00:00
|
|
|
/* Basic functions */
|
|
|
|
|
2019-08-26 11:44:48 +00:00
|
|
|
extern bool send_request(struct connection_t *c, const char *format, ...) __attribute__((__format__(printf, 2, 3)));
|
|
|
|
extern void forward_request(struct connection_t *c);
|
|
|
|
extern bool receive_request(struct connection_t *c);
|
|
|
|
extern bool check_id(const char *name);
|
2019-08-26 11:44:36 +00:00
|
|
|
|
|
|
|
extern void init_requests(void);
|
|
|
|
extern void exit_requests(void);
|
2019-08-26 11:44:48 +00:00
|
|
|
extern bool seen_request(char *request);
|
2019-08-26 11:44:36 +00:00
|
|
|
extern void age_past_requests(void);
|
|
|
|
|
|
|
|
/* Requests */
|
|
|
|
|
2019-08-26 11:44:48 +00:00
|
|
|
extern bool send_id(struct connection_t *c);
|
|
|
|
extern bool send_metakey(struct connection_t *c);
|
|
|
|
extern bool send_challenge(struct connection_t *c);
|
|
|
|
extern bool send_chal_reply(struct connection_t *c);
|
|
|
|
extern bool send_ack(struct connection_t *c);
|
|
|
|
extern bool send_ping(struct connection_t *c);
|
|
|
|
extern bool send_pong(struct connection_t *c);
|
|
|
|
extern bool send_add_subnet(struct connection_t *c, const struct subnet_t *subnet);
|
|
|
|
extern bool send_del_subnet(struct connection_t *c, const struct subnet_t *subnet);
|
|
|
|
extern bool send_add_edge(struct connection_t *c, const struct edge_t *e);
|
|
|
|
extern bool send_del_edge(struct connection_t *c, const struct edge_t *e);
|
2019-08-26 11:44:41 +00:00
|
|
|
extern void send_key_changed(void);
|
2019-08-26 11:44:48 +00:00
|
|
|
extern bool send_req_key(struct node_t *n);
|
|
|
|
extern bool send_ans_key(struct node_t *n);
|
|
|
|
extern bool send_tcppacket(struct connection_t *c, const struct vpn_packet_t *packet);
|
2019-08-26 11:44:36 +00:00
|
|
|
|
|
|
|
/* Request handlers */
|
|
|
|
|
2019-08-26 11:44:48 +00:00
|
|
|
extern bool id_h(struct connection_t *c);
|
|
|
|
extern bool metakey_h(struct connection_t *c);
|
|
|
|
extern bool challenge_h(struct connection_t *c);
|
|
|
|
extern bool chal_reply_h(struct connection_t *c);
|
|
|
|
extern bool ack_h(struct connection_t *c);
|
|
|
|
extern bool ping_h(struct connection_t *c);
|
|
|
|
extern bool pong_h(struct connection_t *c);
|
|
|
|
extern bool add_subnet_h(struct connection_t *c);
|
|
|
|
extern bool del_subnet_h(struct connection_t *c);
|
|
|
|
extern bool add_edge_h(struct connection_t *c);
|
|
|
|
extern bool del_edge_h(struct connection_t *c);
|
|
|
|
extern bool key_changed_h(struct connection_t *c);
|
|
|
|
extern bool req_key_h(struct connection_t *c);
|
|
|
|
extern bool ans_key_h(struct connection_t *c);
|
|
|
|
extern bool tcppacket_h(struct connection_t *c);
|
|
|
|
|
|
|
|
#endif
|