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