]> git.meshlink.io Git - meshlink/blob - src/node.h
Merging of the entire pre5 branch.
[meshlink] / src / node.h
1 /*
2     node.h -- header for node.c
3     Copyright (C) 2001-2002 Guus Sliepen <guus@sliepen.warande.net>,
4                   2001-2002 Ivo Timmermans <itimmermans@bigfoot.com>
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.10 2002/02/10 21:57:54 guus Exp $
21 */
22
23 #ifndef __TINC_NODE_H__
24 #define __TINC_NODE_H__
25
26 #include <avl_tree.h>
27
28 #include "subnet.h"
29 #include "connection.h"
30
31 typedef struct node_status_t {
32   int active:1;                    /* 1 if active.. */
33   int validkey:1;                  /* 1 if we currently have a valid key for him */
34   int waitingforkey:1;             /* 1 if we already sent out a request */
35   int visited:1;                   /* 1 if this node has been visited by one of the graph algorithms */
36   int reachable:1;                 /* 1 if this node is reachable in the graph */
37   int unused:27;
38 } node_status_t;
39
40 typedef struct node_t {
41   char *name;                      /* name of this node */
42   long int options;                /* options turned on for this node */
43
44   ipv4_t address;                  /* his real (internet) ip to send UDP packets to */
45   port_t port;                     /* port number of UDP connection */
46   char *hostname;                  /* the hostname of its real ip */
47
48   struct node_status_t status;
49
50   const EVP_CIPHER *cipher;        /* Cipher type for UDP packets */ 
51   char *key;                       /* Cipher key and iv */
52   int keylength;                   /* Cipher key and iv length*/
53
54   const EVP_MD *digest;            /* Digest type for MAC */
55   int maclength;                   /* Length of MAC */
56
57   list_t *queue;                   /* Queue for packets awaiting to be encrypted */
58
59   struct node_t *nexthop;          /* nearest node from us to him */
60   struct node_t *via;              /* next hop for UDP packets */
61   
62   avl_tree_t *subnet_tree;         /* Pointer to a tree of subnets belonging to this node */
63
64   avl_tree_t *edge_tree;           /* Edges with this node as one of the endpoints */
65
66   struct connection_t *connection; /* Connection associated with this node (if a direct connection exists) */
67
68   unsigned int sent_seqno;         /* Sequence number last sent to this node */
69   unsigned int received_seqno;     /* Sequence number last received from this node */
70 } node_t;
71
72 extern struct node_t *myself;
73 extern avl_tree_t *node_tree;
74 extern avl_tree_t *node_udp_tree;
75
76 extern void init_nodes(void);
77 extern void exit_nodes(void);
78 extern node_t *new_node(void);
79 extern void free_node(node_t *n);
80 extern void node_add(node_t *n);
81 extern void node_del(node_t *n);
82 extern node_t *lookup_node(char *);
83 extern node_t *lookup_node_udp(ipv4_t, port_t);
84 extern void dump_nodes(void);
85
86 #endif /* __TINC_NODE_H__ */