b1e3146bc6732a35dcbde34929368a49aa89ed5b
[tinc] / src / connlist.c
1 /*
2     connlist.c -- connection list management
3     Copyright (C) 2000 Guus Sliepen <guus@sliepen.warande.net>,
4                   2000 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: connlist.c,v 1.1.2.4 2000/10/15 00:59:34 guus Exp $
21 */
22
23 #include <syslog.h>
24
25 #include "net.h"        /* Don't ask. */
26 #include "config.h"
27 #include "conf.h"
28 #include <utils.h>
29
30 #include "system.h"
31
32 /* Root of the connection list */
33
34 conn_list_t *conn_list = NULL;
35 conn_list_t *myself = NULL;
36
37 /* Creation and deletion of conn_list elements */
38
39 conn_list_t *new_conn_list(void)
40 {
41   conn_list_t *p = (conn_list_t *)xmalloc(sizeof(*p));
42 cp
43   /* initialise all those stupid pointers at once */
44   memset(p, '\0', sizeof(*p));
45 cp
46   return p;
47 }
48
49 void free_conn_list(conn_list_t *p)
50 {
51 cp
52   if(p->sq)
53     destroy_queue(p->sq);
54   if(p->rq)
55     destroy_queue(p->rq);
56   if(p->name && p->name!=unknown)
57     free(p->name);
58   if(p->hostname)
59     free(p->hostname);
60   if(p->public_key)
61     RSA_free(p->public_key);
62   if(p->cipher_pktkey)
63     free(p->cipher_pktkey);
64   if(p->buffer)
65     free(p->buffer);
66   free(p);
67 cp
68 }
69
70 /*
71   remove all marked connections
72 */
73 void prune_conn_list(void)
74 {
75   conn_list_t *p, *prev = NULL, *next = NULL;
76 cp
77   for(p = conn_list; p != NULL; )
78     {
79       next = p->next;
80
81       if(p->status.remove)
82         {
83           if(prev)
84             prev->next = next;
85           else
86             conn_list = next;
87
88           free_conn_list(p);
89         }
90       else
91         prev = p;
92
93       p = next;
94     }
95 cp
96 }
97
98 /*
99   free all elements of conn_list
100 */
101 void destroy_conn_list(void)
102 {
103   conn_list_t *p, *next;
104 cp
105   for(p = conn_list; p != NULL; )
106     {
107       next = p->next;
108       free_conn_list(p);
109       p = next;
110     }
111
112   conn_list = NULL;
113 cp
114 }
115
116 /* Linked list management */
117
118 void conn_list_add(conn_list_t *cl)
119 {
120 cp
121   cl->next = conn_list;
122   cl->prev = NULL;
123   cl->next->prev = cl;
124   conn_list = cl;
125 cp
126 }
127
128 void conn_list_del(conn_list_t *cl)
129 {
130 cp
131   if(cl->prev)
132     cl->prev->next = cl->next;
133   else
134     conn_list = cl->next;
135   
136   cl->next->prev = cl->prev;
137   free_conn_list(cl);
138 cp
139 }
140
141 /* Lookup functions */
142
143 conn_list_t *lookup_id(char *name)
144 {
145   conn_list_t *p;
146 cp
147   for(p = conn_list; p != NULL; p = p->next)
148     if(strcmp(name, p->name) == 0)
149       break;
150 cp
151   return p;
152 }
153
154 conn_list_t *lookup_conn_list_mac(mac_t address)
155 {
156   conn_list_t *p;
157 cp
158   for(p = conn_list; p != NULL; p = p->next)
159     if(lookup_subnet_mac(p->subnets, address))
160       break;
161 cp
162   return p;
163 }
164
165 conn_list_t *lookup_conn_list_ipv4(ipv4_t address)
166 {
167   conn_list_t *p;
168 cp
169   for(p = conn_list; p != NULL; p = p->next)
170     if(lookup_subnet_ipv4(p->subnets, address))
171       break;
172 cp
173   return p;
174 }
175
176 conn_list_t *lookup_conn_list_ipv6(ipv6_t address)
177 {
178   conn_list_t *p;
179 cp
180   for(p = conn_list; p != NULL; p = p->next)
181     if(lookup_subnet_ipv6(p->subnets, address))
182       break;
183 cp
184   return p;
185 }
186
187 /* Debugging */
188
189 void dump_conn_list(void)
190 {
191   conn_list_t *p;
192   subnet_t *s;
193   char *netstr;
194 cp
195   syslog(LOG_DEBUG, _("Connection list:"));
196
197   for(p = conn_list; p != NULL; p = p->next)
198     {
199       syslog(LOG_DEBUG, _("%s at %s port %hd flags %d sockets %d, %d status %04x"),
200              p->name, p->hostname, p->port, p->flags,
201              p->socket, p->meta_socket, p->status);
202       for(s = p->subnets; s != NULL; s = s->next)
203         {
204           netstr = net2str(s);
205           syslog(LOG_DEBUG, ": %s", netstr);
206           free(netstr);
207         }
208     }
209
210   syslog(LOG_DEBUG, _("End of connection list."));
211 cp
212 }
213
214 int read_host_config(conn_list_t *cl)
215 {
216   char *fname;
217   int x;
218 cp
219   asprintf(&fname, "%s/hosts/%s", confbase, cl->name);
220   x = read_config_file(&cl->config, fname);
221   free(fname);
222 cp
223   return x;
224 }