Add configuration details for NetBSD and Darwin (MacOS/X).
[tinc] / 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.15 2002/06/08 13:46:07 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   const EVP_CIPHER *cipher;        /* Cipher type for UDP packets */ 
55   char *key;                       /* Cipher key and iv */
56   int keylength;                   /* Cipher key and iv length*/
57
58   const EVP_MD *digest;            /* Digest type for MAC */
59   int maclength;                   /* Length of MAC */
60
61   int compression;                 /* Compressionlevel, 0 = no compression */
62
63   list_t *queue;                   /* Queue for packets awaiting to be encrypted */
64
65   struct node_t *nexthop;          /* nearest node from us to him */
66   struct node_t *via;              /* next hop for UDP packets */
67   
68   avl_tree_t *subnet_tree;         /* Pointer to a tree of subnets belonging to this node */
69
70   avl_tree_t *edge_tree;           /* Edges with this node as one of the endpoints */
71
72   struct connection_t *connection; /* Connection associated with this node (if a direct connection exists) */
73
74   uint32_t sent_seqno;         /* Sequence number last sent to this node */
75   uint32_t received_seqno;     /* Sequence number last received from this node */
76 } node_t;
77
78 extern struct node_t *myself;
79 extern avl_tree_t *node_tree;
80 extern avl_tree_t *node_udp_tree;
81
82 extern void init_nodes(void);
83 extern void exit_nodes(void);
84 extern node_t *new_node(void);
85 extern void free_node(node_t *);
86 extern void node_add(node_t *);
87 extern void node_del(node_t *);
88 extern node_t *lookup_node(char *);
89 extern node_t *lookup_node_udp(sockaddr_t *);
90 extern void dump_nodes(void);
91
92 #endif /* __TINC_NODE_H__ */