d606e9c3a1c0c3cc2591bc01a7e624f0cb7f3ee4
[tinc] / 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.19 2001/10/10 20:35:10 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->rsa_key)
75     RSA_free(c->rsa_key);
76   if(c->inkey)
77     free(c->inkey);
78   if(c->outkey)
79     free(c->outkey);
80   if(c->mychallenge)
81     free(c->mychallenge);
82   if(c->hischallenge)
83     free(c->hischallenge);
84   free(c);
85 cp
86 }
87
88 void connection_add(connection_t *c)
89 {
90 cp
91   avl_insert(connection_tree, c);
92 cp
93 }
94
95 void connection_del(connection_t *c)
96 {
97 cp
98   avl_delete(connection_tree, c);
99 cp
100 }
101
102 connection_t *lookup_connection(ipv4_t address, short unsigned int port)
103 {
104   connection_t c;
105 cp
106   c.address = address;
107   c.port = port;
108
109   return avl_search(connection_tree, &c);
110 }
111
112 void dump_connections(void)
113 {
114   avl_node_t *node;
115   connection_t *c;
116 cp
117   syslog(LOG_DEBUG, _("Connections:"));
118
119   for(node = connection_tree->head; node; node = node->next)
120     {
121       c = (connection_t *)node->data;
122       syslog(LOG_DEBUG, _(" %s at %s port %hd options %ld socket %d status %04x"),
123              c->node->name, c->hostname, c->port, c->options,
124              c->socket, c->status);
125     }
126     
127   syslog(LOG_DEBUG, _("End of connections."));
128 cp
129 }