mirror of
https://github.com/osmarks/ngircd.git
synced 2025-10-24 02:27:38 +00:00
Only close "unrelated" sockets in forked child processes
This fixes the problem that ngIRCd can't do any IDENT lookups because
of the socket has already been closed in the child process.
The bug has been introduced starting with ngIRCd 17 ... :-(
(commit ID 6ebb31ab35
)
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* ngIRCd -- The Next Generation IRC Daemon
|
* ngIRCd -- The Next Generation IRC Daemon
|
||||||
* Copyright (c)2001-2010 Alexander Barton <alex@barton.de>
|
* Copyright (c)2001-2011 Alexander Barton (alex@barton.de) and Contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -435,12 +435,13 @@ Conn_Exit( void )
|
|||||||
* they don't hold connections open that the main process wants to close.
|
* they don't hold connections open that the main process wants to close.
|
||||||
*/
|
*/
|
||||||
GLOBAL void
|
GLOBAL void
|
||||||
Conn_CloseAllSockets(void)
|
Conn_CloseAllSockets(int ExceptOf)
|
||||||
{
|
{
|
||||||
CONN_ID idx;
|
CONN_ID idx;
|
||||||
|
|
||||||
for(idx = 0; idx < Pool_Size; idx++) {
|
for(idx = 0; idx < Pool_Size; idx++) {
|
||||||
if(My_Connections[idx].sock > NONE)
|
if(My_Connections[idx].sock > NONE &&
|
||||||
|
My_Connections[idx].sock != ExceptOf)
|
||||||
close(My_Connections[idx].sock);
|
close(My_Connections[idx].sock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* ngIRCd -- The Next Generation IRC Daemon
|
* ngIRCd -- The Next Generation IRC Daemon
|
||||||
* Copyright (c)2001-2010 Alexander Barton <alex@barton.de>
|
* Copyright (c)2001-2011 Alexander Barton (alex@barton.de) and Contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -106,7 +106,7 @@ GLOBAL long WCounter;
|
|||||||
GLOBAL void Conn_Init PARAMS((void ));
|
GLOBAL void Conn_Init PARAMS((void ));
|
||||||
GLOBAL void Conn_Exit PARAMS(( void ));
|
GLOBAL void Conn_Exit PARAMS(( void ));
|
||||||
|
|
||||||
GLOBAL void Conn_CloseAllSockets PARAMS((void));
|
GLOBAL void Conn_CloseAllSockets PARAMS((int ExceptOf));
|
||||||
|
|
||||||
GLOBAL unsigned int Conn_InitListeners PARAMS(( void ));
|
GLOBAL unsigned int Conn_InitListeners PARAMS(( void ));
|
||||||
GLOBAL void Conn_ExitListeners PARAMS(( void ));
|
GLOBAL void Conn_ExitListeners PARAMS(( void ));
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* ngIRCd -- The Next Generation IRC Daemon
|
* ngIRCd -- The Next Generation IRC Daemon
|
||||||
* Copyright (c)2001-2010 Alexander Barton (alex@barton.de)
|
* Copyright (c)2001-2011 Alexander Barton (alex@barton.de) and Contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -959,6 +959,7 @@ Hello_User(CLIENT * Client)
|
|||||||
} else {
|
} else {
|
||||||
/* Sub process */
|
/* Sub process */
|
||||||
Log_Init_Subprocess("Auth");
|
Log_Init_Subprocess("Auth");
|
||||||
|
Conn_CloseAllSockets(NONE);
|
||||||
result = PAM_Authenticate(Client);
|
result = PAM_Authenticate(Client);
|
||||||
if (write(pipefd[1], &result, sizeof(result)) != sizeof(result))
|
if (write(pipefd[1], &result, sizeof(result)) != sizeof(result))
|
||||||
Log_Subprocess(LOG_ERR,
|
Log_Subprocess(LOG_ERR,
|
||||||
|
@@ -79,7 +79,6 @@ Proc_Fork(PROC_STAT *proc, int *pipefds, void (*cbfunc)(int, short), int timeout
|
|||||||
signal(SIGALRM, Proc_GenericSignalHandler);
|
signal(SIGALRM, Proc_GenericSignalHandler);
|
||||||
close(pipefds[0]);
|
close(pipefds[0]);
|
||||||
alarm(timeout);
|
alarm(timeout);
|
||||||
Conn_CloseAllSockets();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* ngIRCd -- The Next Generation IRC Daemon
|
* ngIRCd -- The Next Generation IRC Daemon
|
||||||
* Copyright (c)2001-2009 by Alexander Barton (alex@barton.de)
|
* Copyright (c)2001-2011 Alexander Barton (alex@barton.de) and Contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -75,7 +75,8 @@ Resolve_Addr(PROC_STAT * s, const ng_ipaddr_t *Addr, int identsock,
|
|||||||
} else if( pid == 0 ) {
|
} else if( pid == 0 ) {
|
||||||
/* Sub process */
|
/* Sub process */
|
||||||
Log_Init_Subprocess("Resolver");
|
Log_Init_Subprocess("Resolver");
|
||||||
Do_ResolveAddr( Addr, identsock, pipefd[1]);
|
Conn_CloseAllSockets(identsock);
|
||||||
|
Do_ResolveAddr(Addr, identsock, pipefd[1]);
|
||||||
Log_Exit_Subprocess("Resolver");
|
Log_Exit_Subprocess("Resolver");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
@@ -104,6 +105,7 @@ Resolve_Name( PROC_STAT *s, const char *Host, void (*cbfunc)(int, short))
|
|||||||
} else if( pid == 0 ) {
|
} else if( pid == 0 ) {
|
||||||
/* Sub process */
|
/* Sub process */
|
||||||
Log_Init_Subprocess("Resolver");
|
Log_Init_Subprocess("Resolver");
|
||||||
|
Conn_CloseAllSockets(NONE);
|
||||||
Do_ResolveName(Host, pipefd[1]);
|
Do_ResolveName(Host, pipefd[1]);
|
||||||
Log_Exit_Subprocess("Resolver");
|
Log_Exit_Subprocess("Resolver");
|
||||||
exit(0);
|
exit(0);
|
||||||
|
Reference in New Issue
Block a user