*/
void RemoveContext (CitContext *con)
{
+ const char *c;
if (con==NULL) {
- syslog(LOG_ERR,
- "WARNING: RemoveContext() called with NULL!\n");
+ syslog(LOG_ERR, "WARNING: RemoveContext() called with NULL!\n");
return;
}
- syslog(LOG_DEBUG, "RemoveContext() session %d\n", con->cs_pid);
+ c = con->ServiceName;
+ if (c == NULL)
+ c = "WTF?";
+ syslog(LOG_DEBUG, "RemoveContext(%s) session %d\n", c, con->cs_pid);
+ cit_backtrace ();
/* Run any cleanup routines registered by loadable modules.
* Note: We have to "become_session()" because the cleanup functions
syslog(LOG_NOTICE, "[%3d] Session ended.\n", con->cs_pid);
- /*
- * If the client is still connected, blow 'em away.
- * if the socket is 0, its already gone or was never there.
- */
- if (con->client_socket != 0)
- {
- syslog(LOG_DEBUG, "Closing socket %d\n", con->client_socket);
- close(con->client_socket);
- }
+ /* If the client is still connected, blow 'em away. */
+ client_close();
/* If using AUTHMODE_LDAP, free the DN */
if (con->ldap_dn) {