mirror of
https://github.com/osmarks/ngircd.git
synced 2025-01-19 03:52:52 +00:00
New function Conn_GetFromProc() to get CONN_ID of a subprocess
Get CONN_ID from file descriptor associated to a subprocess structure.
This commit is contained in:
parent
2d4ea28835
commit
3d49fa5bff
@ -1986,7 +1986,7 @@ cb_Read_Resolver_Result( int r_fd, UNUSED short events )
|
|||||||
* IDENT user name.*/
|
* IDENT user name.*/
|
||||||
|
|
||||||
CLIENT *c;
|
CLIENT *c;
|
||||||
int i;
|
CONN_ID i;
|
||||||
size_t len;
|
size_t len;
|
||||||
char *identptr;
|
char *identptr;
|
||||||
#ifdef IDENTAUTH
|
#ifdef IDENTAUTH
|
||||||
@ -1996,14 +1996,8 @@ cb_Read_Resolver_Result( int r_fd, UNUSED short events )
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
LogDebug("Resolver: Got callback on fd %d, events %d", r_fd, events );
|
LogDebug("Resolver: Got callback on fd %d, events %d", r_fd, events );
|
||||||
|
i = Conn_GetFromProc(r_fd);
|
||||||
/* Search associated connection ... */
|
if (i == NONE) {
|
||||||
for( i = 0; i < Pool_Size; i++ ) {
|
|
||||||
if(( My_Connections[i].sock != NONE )
|
|
||||||
&& (Proc_GetPipeFd(&My_Connections[i].proc_stat) == r_fd))
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if( i >= Pool_Size ) {
|
|
||||||
/* Ops, none found? Probably the connection has already
|
/* Ops, none found? Probably the connection has already
|
||||||
* been closed!? We'll ignore that ... */
|
* been closed!? We'll ignore that ... */
|
||||||
io_close( r_fd );
|
io_close( r_fd );
|
||||||
@ -2108,6 +2102,26 @@ Conn_GetClient( CONN_ID Idx )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get CONN_ID from file descriptor associated to a subprocess structure.
|
||||||
|
* @param fd File descriptor
|
||||||
|
* @return CONN_ID or NONE (-1)
|
||||||
|
*/
|
||||||
|
GLOBAL CONN_ID
|
||||||
|
Conn_GetFromProc(int fd)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
assert(fd > 0);
|
||||||
|
for (i = 0; i < Pool_Size; i++) {
|
||||||
|
if ((My_Connections[i].sock != NONE)
|
||||||
|
&& (Proc_GetPipeFd(&My_Connections[i].proc_stat) == fd))
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
return NONE;
|
||||||
|
} /* Conn_GetFromProc */
|
||||||
|
|
||||||
|
|
||||||
#ifdef SSL_SUPPORT
|
#ifdef SSL_SUPPORT
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -113,6 +113,7 @@ GLOBAL void Conn_Close PARAMS(( CONN_ID Idx, const char *LogMsg, const char *Fwd
|
|||||||
|
|
||||||
GLOBAL void Conn_SyncServerStruct PARAMS(( void ));
|
GLOBAL void Conn_SyncServerStruct PARAMS(( void ));
|
||||||
|
|
||||||
|
GLOBAL CONN_ID Conn_GetFromProc PARAMS((int fd));
|
||||||
GLOBAL CLIENT* Conn_GetClient PARAMS((CONN_ID i));
|
GLOBAL CLIENT* Conn_GetClient PARAMS((CONN_ID i));
|
||||||
#ifdef SSL_SUPPORT
|
#ifdef SSL_SUPPORT
|
||||||
GLOBAL bool Conn_GetCipherInfo PARAMS((CONN_ID Idx, char *buf, size_t len));
|
GLOBAL bool Conn_GetCipherInfo PARAMS((CONN_ID Idx, char *buf, size_t len));
|
||||||
|
Loading…
Reference in New Issue
Block a user