parent
5d0599976e
commit
08cd36bef0
|
@ -36,6 +36,7 @@ identd (char *username)
|
||||||
char *p;
|
char *p;
|
||||||
char buf[256];
|
char buf[256];
|
||||||
char outbuf[256];
|
char outbuf[256];
|
||||||
|
char ipbuf[INET_ADDRSTRLEN];
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
|
|
||||||
sok = socket (AF_INET, SOCK_STREAM, 0);
|
sok = socket (AF_INET, SOCK_STREAM, 0);
|
||||||
|
@ -80,7 +81,8 @@ identd (char *username)
|
||||||
#if 0 /* causes random crashes, probably due to CreateThread */
|
#if 0 /* causes random crashes, probably due to CreateThread */
|
||||||
EMIT_SIGNAL (XP_TE_IDENTD, current_sess, inet_ntoa (addr.sin_addr), username, NULL, NULL, 0);
|
EMIT_SIGNAL (XP_TE_IDENTD, current_sess, inet_ntoa (addr.sin_addr), username, NULL, NULL, 0);
|
||||||
#endif
|
#endif
|
||||||
snprintf (outbuf, sizeof (outbuf), "*\tServicing ident request from %s as %s\n", inet_ntoa (addr.sin_addr), username);
|
inet_ntop (AF_INET, &addr.sin_addr, ipbuf, sizeof (ipbuf));
|
||||||
|
snprintf (outbuf, sizeof (outbuf), "*\tServicing ident request from %s as %s\n", ipbuf, username);
|
||||||
PrintText (current_sess, outbuf);
|
PrintText (current_sess, outbuf);
|
||||||
|
|
||||||
recv (read_sok, buf, sizeof (buf) - 1, 0);
|
recv (read_sok, buf, sizeof (buf) - 1, 0);
|
||||||
|
@ -103,23 +105,20 @@ identd (char *username)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_IPV6
|
#ifdef USE_IPV6
|
||||||
#define IPV6BUFLEN 60
|
|
||||||
static int
|
static int
|
||||||
identd_ipv6 (char *username)
|
identd_ipv6 (char *username)
|
||||||
{
|
{
|
||||||
int sok, read_sok, len;
|
int sok, read_sok, len;
|
||||||
char *p;
|
char *p;
|
||||||
char buf[256];
|
char buf[256];
|
||||||
char outbuf[256];
|
char outbuf[256];
|
||||||
LPSTR ipv6buf = (LPSTR) malloc (IPV6BUFLEN);
|
char ipbuf[INET6_ADDRSTRLEN];
|
||||||
struct sockaddr_in6 addr;
|
struct sockaddr_in6 addr;
|
||||||
|
|
||||||
sok = socket (AF_INET6, SOCK_STREAM, 0);
|
sok = socket (AF_INET6, SOCK_STREAM, 0);
|
||||||
|
|
||||||
if (sok == INVALID_SOCKET)
|
if (sok == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
free (username);
|
free (username);
|
||||||
free (ipv6buf);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,7 +133,6 @@ identd_ipv6 (char *username)
|
||||||
{
|
{
|
||||||
closesocket (sok);
|
closesocket (sok);
|
||||||
free (username);
|
free (username);
|
||||||
free (ipv6buf);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,39 +140,28 @@ identd_ipv6 (char *username)
|
||||||
{
|
{
|
||||||
closesocket (sok);
|
closesocket (sok);
|
||||||
free (username);
|
free (username);
|
||||||
free (ipv6buf);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
len = sizeof (addr);
|
len = sizeof (addr);
|
||||||
read_sok = accept (sok, (struct sockaddr *) &addr, &len);
|
read_sok = accept (sok, (struct sockaddr *) &addr, &len);
|
||||||
closesocket (sok);
|
closesocket (sok);
|
||||||
|
|
||||||
if (read_sok == INVALID_SOCKET)
|
if (read_sok == INVALID_SOCKET)
|
||||||
{
|
{
|
||||||
free (username);
|
free (username);
|
||||||
free (ipv6buf);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
identd_ipv6_is_running = FALSE;
|
identd_ipv6_is_running = FALSE;
|
||||||
|
|
||||||
if (WSAAddressToString ((struct sockaddr *) &addr, sizeof (addr), NULL, ipv6buf, (LPDWORD) IPV6BUFLEN) == SOCKET_ERROR)
|
inet_ntop (AF_INET6, &addr.sin6_addr, ipbuf, sizeof (ipbuf));
|
||||||
{
|
snprintf (outbuf, sizeof (outbuf), "*\tServicing ident request from %s as %s\n", ipbuf, username);
|
||||||
snprintf (ipv6buf, sizeof (ipv6buf) - 1, "[SOCKET ERROR: 0x%X]", WSAGetLastError ());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0 /* causes random crashes, probably due to CreateThread */
|
|
||||||
EMIT_SIGNAL (XP_TE_IDENTD, current_sess, ipv6buf, username, NULL, NULL, 0);
|
|
||||||
#endif
|
|
||||||
snprintf (outbuf, sizeof (outbuf), "*\tServicing ident request from %s as %s\n", ipv6buf, username);
|
|
||||||
PrintText (current_sess, outbuf);
|
PrintText (current_sess, outbuf);
|
||||||
|
|
||||||
recv (read_sok, buf, sizeof (buf) - 1, 0);
|
recv (read_sok, buf, sizeof (buf) - 1, 0);
|
||||||
buf[sizeof (buf) - 1] = 0; /* ensure null termination */
|
buf[sizeof (buf) - 1] = 0; /* ensure null termination */
|
||||||
|
|
||||||
p = strchr (buf, ',');
|
p = strchr (buf, ',');
|
||||||
|
|
||||||
if (p)
|
if (p)
|
||||||
{
|
{
|
||||||
snprintf (outbuf, sizeof (outbuf) - 1, "%d, %d : USERID : UNIX : %s\r\n", atoi (buf), atoi (p + 1), username);
|
snprintf (outbuf, sizeof (outbuf) - 1, "%d, %d : USERID : UNIX : %s\r\n", atoi (buf), atoi (p + 1), username);
|
||||||
|
@ -185,7 +172,6 @@ identd_ipv6 (char *username)
|
||||||
sleep (1);
|
sleep (1);
|
||||||
closesocket (read_sok);
|
closesocket (read_sok);
|
||||||
free (username);
|
free (username);
|
||||||
free (ipv6buf);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue