X-Git-Url: http://git.silcnet.org/gitweb/?p=silc.git;a=blobdiff_plain;f=apps%2Fsilcd%2Fserver_util.c;h=74ce18ba2902866107148517f3f961fe645dd714;hp=274bd0f58b483bbefbbe4bd2baf06740056f30f3;hb=55401f49c984e35e652eb590bdcefa07387ddd44;hpb=a939f27e19b8084ef2acd25156b19d26d1440ace diff --git a/apps/silcd/server_util.c b/apps/silcd/server_util.c index 274bd0f5..74ce18ba 100644 --- a/apps/silcd/server_util.c +++ b/apps/silcd/server_util.c @@ -228,6 +228,7 @@ SilcBool silc_server_remove_clients_by_server(SilcServer server, client->mode = 0; client->router = NULL; client->connection = NULL; + client->data.created = silc_time(); silc_dlist_del(server->expired_clients, client); silc_dlist_add(server->expired_clients, client); } else { @@ -290,6 +291,7 @@ SilcBool silc_server_remove_clients_by_server(SilcServer server, client->mode = 0; client->router = NULL; client->connection = NULL; + client->data.created = silc_time(); silc_dlist_del(server->expired_clients, client); silc_dlist_add(server->expired_clients, client); } else { @@ -1545,8 +1547,17 @@ void silc_server_kill_client(SilcServer server, if (remote_client->connection) { /* Remove locally conneted client */ SilcPacketStream sock = remote_client->connection; + + if (sock) + silc_packet_stream_ref(sock); + silc_server_free_sock_user_data(server, sock, NULL); - silc_server_close_connection(server, sock); + + if (sock) { + silc_packet_set_context(sock, NULL); + silc_server_close_connection(server, sock); + silc_packet_stream_unref(sock); + } } else { /* Update statistics */ server->stat.clients--; @@ -1568,6 +1579,7 @@ void silc_server_kill_client(SilcServer server, } /* Remove remote client */ + silc_dlist_del(server->expired_clients, remote_client); silc_idlist_del_data(remote_client); if (!silc_idlist_del_client(server->global_list, remote_client)) { /* Remove this client from watcher list if it is */