Another file moved; random interface stuff.
[tinc] / lib / 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.1 2002/04/28 12:46:25 zarq Exp $
21 */
22
23 #include "config.h"
24
25 #include <stdio.h>
26 #include <stdlib.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 #include "logging.h"
40
41 #include "xalloc.h"
42 #include "system.h"
43
44 avl_tree_t *connection_tree;    /* Meta connections */
45
46 int connection_compare(connection_t *a, connection_t *b)
47 {
48   return a - b;
49 }
50
51 void init_connections(void)
52 {
53 cp
54   connection_tree = avl_alloc_tree((avl_compare_t)connection_compare, NULL);
55 cp
56 }
57
58 void exit_connections(void)
59 {
60 cp
61   avl_delete_tree(connection_tree);
62 cp
63 }
64
65 connection_t *new_connection(void)
66 {
67   connection_t *c;
68 cp
69   c = (connection_t *)xmalloc_and_zero(sizeof(connection_t));
70
71   if(!c)
72     return NULL;
73
74   gettimeofday(&c->start, NULL);
75 cp
76   return c;
77 }
78
79 void free_connection(connection_t *c)
80 {
81 cp
82   if(c->hostname)
83     free(c->hostname);
84   if(c->inkey)
85     free(c->inkey);
86   if(c->outkey)
87     free(c->outkey);
88   if(c->mychallenge)
89     free(c->mychallenge);
90   if(c->hischallenge)
91     free(c->hischallenge);
92   free(c);
93 cp
94 }
95
96 void connection_add(connection_t *c)
97 {
98 cp
99   avl_insert(connection_tree, c);
100 cp
101 }
102
103 void connection_del(connection_t *c)
104 {
105 cp
106   avl_delete(connection_tree, c);
107 cp
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 options %lx socket %d status %04x"),
121              c->name, c->hostname, c->options, c->socket, c->status);
122     }
123     
124   syslog(LOG_DEBUG, _("End of connections."));
125 cp
126 }