What was I thinking? s/vertex/edge/g.
[tinc] / src / connection.c
1 /*
2     connection.c -- connection list management
3     Copyright (C) 2000,2001 Guus Sliepen <guus@sliepen.warande.net>,
4                   2000,2001 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: connection.c,v 1.1.2.22 2001/10/28 08:41:19 guus Exp $
21 */
22
23 #include "config.h"
24
25 #include <stdio.h>
26 #include <syslog.h>
27 #include <string.h>
28
29 #include <avl_tree.h>
30 #include <list.h>
31
32 #include "net.h"        /* Don't ask. */
33 #include "netutl.h"
34 #include "config.h"
35 #include "conf.h"
36 #include <utils.h>
37 #include "subnet.h"
38
39 #include "xalloc.h"
40 #include "system.h"
41
42 avl_tree_t *connection_tree;    /* Meta connections */
43
44 int connection_compare(connection_t *a, connection_t *b)
45 {
46   return a->socket - b->socket;
47 }
48
49 void init_connections(void)
50 {
51 cp
52   connection_tree = avl_alloc_tree((avl_compare_t)connection_compare, NULL);
53 cp
54 }
55
56 void exit_connection(void)
57 {
58 cp
59   avl_delete_tree(connection_tree);
60 cp
61 }
62
63 connection_t *new_connection(void)
64 {
65   connection_t *c;
66 cp
67   c = (connection_t *)xmalloc_and_zero(sizeof(connection_t));
68 cp
69   return c;
70 }
71
72 void free_connection(connection_t *c)
73 {
74 cp
75   if(c->hostname)
76     free(c->hostname);
77   if(c->inkey)
78     free(c->inkey);
79   if(c->outkey)
80     free(c->outkey);
81   if(c->mychallenge)
82     free(c->mychallenge);
83   if(c->hischallenge)
84     free(c->hischallenge);
85   free(c);
86 cp
87 }
88
89 void connection_add(connection_t *c)
90 {
91 cp
92   avl_insert(connection_tree, c);
93 cp
94 }
95
96 void connection_del(connection_t *c)
97 {
98 cp
99   avl_delete(connection_tree, c);
100 cp
101 }
102
103 connection_t *lookup_connection(ipv4_t address, short unsigned int port)
104 {
105   connection_t c;
106 cp
107   c.address = address;
108   c.port = port;
109
110   return avl_search(connection_tree, &c);
111 }
112
113 void dump_connections(void)
114 {
115   avl_node_t *node;
116   connection_t *c;
117 cp
118   syslog(LOG_DEBUG, _("Connections:"));
119
120   for(node = connection_tree->head; node; node = node->next)
121     {
122       c = (connection_t *)node->data;
123       syslog(LOG_DEBUG, _(" %s at %s port %hd options %ld socket %d status %04x"),
124              c->name, c->hostname, c->port, c->options,
125              c->socket, c->status);
126     }
127     
128   syslog(LOG_DEBUG, _("End of connections."));
129 cp
130 }
131
132 int read_connection_config(connection_t *c)
133 {
134   char *fname;
135   int x;
136 cp
137   asprintf(&fname, "%s/hosts/%s", confbase, c->name);
138   x = read_config_file(c->config_tree, fname);
139   free(fname);
140 cp
141   return x;
142 }