return xmalloc_and_zero(sizeof(connection_t));
}
-void free_connection_partially(connection_t *c) {
+void free_connection(connection_t *c) {
+ if(!c)
+ return;
+
cipher_close(&c->incipher);
digest_close(&c->indigest);
cipher_close(&c->outcipher);
ecdsa_free(&c->ecdsa);
rsa_free(&c->rsa);
- if(c->hischallenge)
- free(c->hischallenge);
+ free(c->hischallenge);
buffer_clear(&c->inbuf);
buffer_clear(&c->outbuf);
if(c->socket > 0)
closesocket(c->socket);
- c->socket = -1;
-}
-
-void free_connection(connection_t *c) {
- if(!c)
- return;
-
- free_connection_partially(c);
-
free(c->name);
free(c->hostname);
for(node = connection_tree->head; node; node = node->next) {
c = node->data;
- send_request(cdump, "%d %d %s at %s options %x socket %d status %04x",
+ send_request(cdump, "%d %d %s %s %x %d %x",
CONTROL, REQ_DUMP_CONNECTIONS,
c->name, c->hostname, c->options, c->socket,
bitfield_to_int(&c->status, sizeof c->status));