Make sure everything links.
[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.20 2001/10/27 12:13:17 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 cp
66   return (connection_t *)xmalloc_and_zero(sizeof(connection_t));
67 }
68
69 void free_connection(connection_t *c)
70 {
71 cp
72   if(c->hostname)
73     free(c->hostname);
74   if(c->inkey)
75     free(c->inkey);
76   if(c->outkey)
77     free(c->outkey);
78   if(c->mychallenge)
79     free(c->mychallenge);
80   if(c->hischallenge)
81     free(c->hischallenge);
82   free(c);
83 cp
84 }
85
86 void connection_add(connection_t *c)
87 {
88 cp
89   avl_insert(connection_tree, c);
90 cp
91 }
92
93 void connection_del(connection_t *c)
94 {
95 cp
96   avl_delete(connection_tree, c);
97 cp
98 }
99
100 connection_t *lookup_connection(ipv4_t address, short unsigned int port)
101 {
102   connection_t c;
103 cp
104   c.address = address;
105   c.port = port;
106
107   return avl_search(connection_tree, &c);
108 }
109
110 void dump_connections(void)
111 {
112   avl_node_t *node;
113   connection_t *c;
114 cp
115   syslog(LOG_DEBUG, _("Connections:"));
116
117   for(node = connection_tree->head; node; node = node->next)
118     {
119       c = (connection_t *)node->data;
120       syslog(LOG_DEBUG, _(" %s at %s port %hd options %ld socket %d status %04x"),
121              c->name, c->hostname, c->port, c->options,
122              c->socket, c->status);
123     }
124     
125   syslog(LOG_DEBUG, _("End of connections."));
126 cp
127 }
128
129 int read_connection_config(connection_t *c)
130 {
131   char *fname;
132   int x;
133 cp
134   asprintf(&fname, "%s/hosts/%s", confbase, c->name);
135   x = read_config_file(c->config_tree, fname);
136   free(fname);
137 cp
138   return x;
139 }