tinc/src/connection.c

130 lines
2.8 KiB
C
Raw Normal View History

/*
2000-11-20 19:12:17 +00:00
connection.c -- connection list management
Copyright (C) 2000,2001 Guus Sliepen <guus@sliepen.warande.net>,
2000,2001 Ivo Timmermans <itimmermans@bigfoot.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: connection.c,v 1.1.2.18 2001/10/10 09:42:29 guus Exp $
*/
#include "config.h"
#include <stdio.h>
#include <syslog.h>
2001-06-29 13:09:55 +00:00
#include <string.h>
#include <avl_tree.h>
#include <list.h>
2000-11-20 19:12:17 +00:00
#include "net.h" /* Don't ask. */
2000-11-04 11:49:58 +00:00
#include "netutl.h"
#include "config.h"
#include "conf.h"
#include <utils.h>
#include "subnet.h"
2000-10-29 00:02:20 +00:00
#include "xalloc.h"
#include "system.h"
avl_tree_t *connection_tree; /* Meta connections */
2000-11-20 19:12:17 +00:00
int connection_compare(connection_t *a, connection_t *b)
{
return a->socket - b->socket;
}
2000-11-20 19:12:17 +00:00
void init_connections(void)
{
cp
connection_tree = avl_alloc_tree((avl_compare_t)connection_compare, NULL);
cp
}
void exit_connection(void)
{
cp
avl_delete_tree(connection_tree);
cp
}
connection_t *new_connection(void)
{
cp
return (connection_t *)xmalloc_and_zero(sizeof(*c));
}
void free_connection(connection_t *c)
{
cp
if(c->hostname)
free(c->hostname);
if(c->rsa_key)
RSA_free(c->rsa_key);
if(c->inpktkey)
free(c->inpktkey);
if(c->outpktkey)
free(c->outpktkey);
if(c->mychallenge)
free(c->mychallenge);
if(c->hischallenge)
free(c->hischallenge);
free(c);
cp
}
void connection_add(connection_t *c)
{
cp
avl_insert(connection_tree, c);
cp
}
void connection_del(connection_t *c)
{
cp
avl_delete(connection_tree, c);
cp
}
connection_t *lookup_connection(ipv4_t address, short unsigned int port)
{
connection_t c;
cp
c.address = address;
c.port = port;
return avl_search(connection_tree, &c);
}
void dump_connections(void)
{
avl_node_t *node;
connection_t *c;
cp
syslog(LOG_DEBUG, _("Connections:"));
for(node = connection_tree->head; node; node = node->next)
{
c = (connection_t *)node->data;
syslog(LOG_DEBUG, _(" %s at %s port %hd options %ld socket %d status %04x"),
c->node->name, c->hostname, c->port, c->options,
cl->socket, c->status);
}
syslog(LOG_DEBUG, _("End of connections."));
cp
}