Prevent looping DEL_NODE/ADD_NODE messages after a node disconnects.
[tinc] / src / node.h
1 /*
2     node.h -- header for node.c
3     Copyright (C) 2001-2002 Guus Sliepen <guus@sliepen.eu.org>,
4                   2001-2002 Ivo Timmermans <ivo@o2w.nl>
5
6     This program is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     This program is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with this program; if not, write to the Free Software
18     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19
20     $Id: node.h,v 1.1.2.18 2002/09/04 08:33:08 guus Exp $
21 */
22
23 #ifndef __TINC_NODE_H__
24 #define __TINC_NODE_H__
25
26 #ifdef HAVE_INTTYPES_H
27  #include <inttypes.h>
28 #endif
29
30 #include <avl_tree.h>
31
32 #include "subnet.h"
33 #include "connection.h"
34
35 typedef struct node_status_t {
36   int active:1;                    /* 1 if active.. */
37   int validkey:1;                  /* 1 if we currently have a valid key for him */
38   int waitingforkey:1;             /* 1 if we already sent out a request */
39   int visited:1;                   /* 1 if this node has been visited by one of the graph algorithms */
40   int reachable:1;                 /* 1 if this node is reachable in the graph */
41   int indirect:1;                  /* 1 if this node is not directly reachable by us */
42   int unused:26;
43 } node_status_t;
44
45 typedef struct node_t {
46   char *name;                      /* name of this node */
47   long int options;                /* options turned on for this node */
48
49   sockaddr_t address;              /* his real (internet) ip to send UDP packets to */
50   char *hostname;                  /* the hostname of its real ip */
51
52   struct node_status_t status;
53
54   int distance;                    /* Distance from us to that node */
55   
56   const EVP_CIPHER *cipher;        /* Cipher type for UDP packets */ 
57   char *key;                       /* Cipher key and iv */
58   int keylength;                   /* Cipher key and iv length*/
59
60   const EVP_MD *digest;            /* Digest type for MAC */
61   int maclength;                   /* Length of MAC */
62
63   int compression;                 /* Compressionlevel, 0 = no compression */
64
65   list_t *queue;                   /* Queue for packets awaiting to be encrypted */
66
67   struct node_t *nexthop;          /* nearest node from us to him */
68   struct node_t *prevhop;          /* nearest node from him to us */
69   struct node_t *via;              /* next hop for UDP packets */
70   
71   avl_tree_t *subnet_tree;         /* Pointer to a tree of subnets belonging to this node */
72
73   struct connection_t *connection; /* Connection associated with this node (if a direct connection exists) */
74
75   uint32_t sent_seqno;         /* Sequence number last sent to this node */
76   uint32_t received_seqno;     /* Sequence number last received from this node */
77 } node_t;
78
79 extern struct node_t *myself;
80 extern avl_tree_t *node_tree;
81 extern avl_tree_t *node_udp_tree;
82
83 extern void init_nodes(void);
84 extern void exit_nodes(void);
85 extern node_t *new_node(void);
86 extern void free_node(node_t *);
87 extern void node_add(node_t *);
88 extern void node_del(node_t *);
89 extern node_t *lookup_node(char *);
90 extern node_t *lookup_node_udp(sockaddr_t *);
91 extern void dump_nodes(void);
92
93 #endif /* __TINC_NODE_H__ */