f7f650050467709e772b1e0879a7f2717d015d65
[oweals/tinc.git] / 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.26 2001/11/16 12:20:44 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 "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_connections(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
69   if(!c)
70     return NULL;
71
72   gettimeofday(&c->start, NULL);
73 cp
74   return c;
75 }
76
77 void free_connection(connection_t *c)
78 {
79 cp
80   if(c->hostname)
81     free(c->hostname);
82   if(c->inkey)
83     free(c->inkey);
84   if(c->outkey)
85     free(c->outkey);
86   if(c->mychallenge)
87     free(c->mychallenge);
88   if(c->hischallenge)
89     free(c->hischallenge);
90   free(c);
91 cp
92 }
93
94 void connection_add(connection_t *c)
95 {
96 cp
97   avl_insert(connection_tree, c);
98 cp
99 }
100
101 void connection_del(connection_t *c)
102 {
103 cp
104   avl_delete(connection_tree, c);
105 cp
106 }
107
108 connection_t *lookup_connection(struct addrinfo *address)
109 {
110   connection_t c;
111 cp
112   c.address = address;
113
114   return avl_search(connection_tree, &c);
115 }
116
117 void dump_connections(void)
118 {
119   avl_node_t *node;
120   connection_t *c;
121 cp
122   syslog(LOG_DEBUG, _("Connections:"));
123
124   for(node = connection_tree->head; node; node = node->next)
125     {
126       c = (connection_t *)node->data;
127       syslog(LOG_DEBUG, _(" %s at %s port %hd options %ld socket %d status %04x"),
128              c->name, c->hostname, c->port, c->options,
129              c->socket, c->status);
130     }
131     
132   syslog(LOG_DEBUG, _("End of connections."));
133 cp
134 }
135
136 int read_connection_config(connection_t *c)
137 {
138   char *fname;
139   int x;
140 cp
141   asprintf(&fname, "%s/hosts/%s", confbase, c->name);
142   x = read_config_file(c->config_tree, fname);
143   free(fname);
144 cp
145   return x;
146 }