client: use more GIO

Fixes https://bugzilla.gnome.org/show_bug.cgi?id=681593
This commit is contained in:
Wim Taymans 2012-09-07 17:14:30 +02:00
parent 87c73c06fb
commit 3e55e0e467

View file

@ -18,19 +18,7 @@
*/ */
#include <stdio.h> #include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <string.h> #include <string.h>
#include <sys/time.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netdb.h>
#include <sys/socket.h>
#include <sys/wait.h>
#include <fcntl.h>
#include <arpa/inet.h>
#include <sys/ioctl.h>
#include "rtsp-client.h" #include "rtsp-client.h"
#include "rtsp-sdp.h" #include "rtsp-sdp.h"
@ -2012,9 +2000,6 @@ attach_client (GstRTSPClient * client, GSocket * socket,
GSource *source; GSource *source;
GMainContext *context; GMainContext *context;
GstRTSPUrl *url; GstRTSPUrl *url;
struct sockaddr_storage addr;
socklen_t addrlen;
gchar ip[INET6_ADDRSTRLEN];
read_socket = gst_rtsp_connection_get_read_socket (conn); read_socket = gst_rtsp_connection_get_read_socket (conn);
client->is_ipv6 = g_socket_get_family (socket) == G_SOCKET_FAMILY_IPV6; client->is_ipv6 = g_socket_get_family (socket) == G_SOCKET_FAMILY_IPV6;
@ -2022,18 +2007,17 @@ attach_client (GstRTSPClient * client, GSocket * socket,
if (!(addres = g_socket_get_remote_address (read_socket, error))) if (!(addres = g_socket_get_remote_address (read_socket, error)))
goto no_address; goto no_address;
addrlen = sizeof (addr);
if (!g_socket_address_to_native (addres, &addr, addrlen, error))
goto native_failed;
g_object_unref (addres);
if (getnameinfo ((struct sockaddr *) &addr, addrlen, ip, sizeof (ip), NULL, 0,
NI_NUMERICHOST) != 0)
goto getnameinfo_failed;
/* keep the original ip that the client connected to */
g_free (client->server_ip); g_free (client->server_ip);
client->server_ip = g_strndup (ip, sizeof (ip)); /* keep the original ip that the client connected to */
if (G_IS_INET_SOCKET_ADDRESS (addres)) {
GInetAddress *iaddr;
iaddr = g_inet_socket_address_get_address (G_INET_SOCKET_ADDRESS (addres));
client->server_ip = g_inet_address_to_string (iaddr);
} else {
client->server_ip = g_strdup ("unknown");
}
GST_INFO ("client %p connected to server ip %s, ipv6 = %d", client, GST_INFO ("client %p connected to server ip %s, ipv6 = %d", client,
client->server_ip, client->is_ipv6); client->server_ip, client->is_ipv6);
@ -2066,17 +2050,6 @@ no_address:
GST_ERROR ("could not get remote address %s", (*error)->message); GST_ERROR ("could not get remote address %s", (*error)->message);
return FALSE; return FALSE;
} }
native_failed:
{
g_object_unref (addres);
GST_ERROR ("could not get native address %s", (*error)->message);
return FALSE;
}
getnameinfo_failed:
{
GST_ERROR ("getnameinfo failed: %s", g_strerror (errno));
return FALSE;
}
} }
/** /**