--- a/libpurple/stun.c Tue Dec 15 23:59:40 2015 -0600
+++ b/libpurple/stun.c Wed Dec 16 01:09:22 2015 -0600
@@ -29,6 +29,8 @@
#if defined (__SVR4) && defined (__sun)
@@ -36,8 +38,6 @@
@@ -283,10 +283,15 @@
-static void hbn_listen_cb(int fd, gpointer data) {
+hbn_listen_cb(int fd, gpointer data) { + GList *addresses = data; + GInetAddress *address = NULL; + GSocketAddress *socket_address = NULL; static struct stun_header hdr_data;
nattype.status = PURPLE_STUN_STATUS_UNKNOWN;
@@ -304,15 +309,13 @@
sc->incb = purple_input_add(fd, PURPLE_INPUT_READ, reply_cb, sc);
- hosts = g_slist_delete_link(hosts, hosts);
- memcpy(&(sc->addr), hosts->data, sizeof(struct sockaddr_in));
- hosts = g_slist_delete_link(hosts, hosts);
- hosts = g_slist_delete_link(hosts, hosts);
- hosts = g_slist_delete_link(hosts, hosts);
+ address = G_INET_ADDRESS(addresses->data); + socket_address = g_inet_socket_address_new(address, port); + g_socket_address_to_native(socket_address, &(sc->addr), g_socket_address_get_native_size(socket_address), NULL); + g_object_unref(G_OBJECT(address)); + g_object_unref(G_OBJECT(socket_address)); + g_resolver_free_addresses(addresses); hdr_data.type = htons(MSGTYPE_BINDINGREQUEST);
@@ -336,44 +339,57 @@
sc->timeout = purple_timeout_add(500, (GSourceFunc) timeoutfunc, sc);
-static void hbn_cb(GSList *hosts, gpointer data, const char *error_message) {
+hbn_cb(GObject *sender, GAsyncResult *res, gpointer data) { + GList *addresses = NULL; - if(!hosts || !hosts->data) {
+ addresses = g_resolver_lookup_by_name_finish(g_resolver_get_default(), res, &error); nattype.status = PURPLE_STUN_STATUS_UNDISCOVERED;
nattype.lookup_time = time(NULL);
- if (!purple_network_listen_range(12108, 12208, AF_UNSPEC, SOCK_DGRAM, TRUE, hbn_listen_cb, hosts)) {
- hosts = g_slist_delete_link(hosts, hosts);
- hosts = g_slist_delete_link(hosts, hosts);
+ if (!purple_network_listen_range(12108, 12208, AF_UNSPEC, SOCK_DGRAM, TRUE, hbn_listen_cb, addresses)) { nattype.status = PURPLE_STUN_STATUS_UNKNOWN;
nattype.lookup_time = time(NULL);
+do_test1(GObject *sender, GAsyncResult *res, gpointer data) { + GList *services = NULL; + const char *servername = data; + services = g_resolver_lookup_service_finish(g_resolver_get_default(), res, &error); + purple_debug_info("stun", "Failed to look up srv record : %s\n", error->message); + servername = g_srv_target_get_hostname((GSrvTarget *)services->data); + port = g_srv_target_get_port((GSrvTarget *)services->data);
-static void do_test1(PurpleSrvResponse *resp, int results, gpointer sdata) {
- const char *servername = sdata;
+ purple_debug_info("stun", "connecting to %s:%d\n", servername, port);
- servername = resp[0].hostname;
- purple_debug_info("stun", "got %d SRV responses, server: %s, port: %d\n",
- results, servername, port);
+ g_resolver_lookup_by_name_async(g_resolver_get_default(), + GINT_TO_POINTER(port)); - purple_dnsquery_a(NULL, servername, port, hbn_cb, NULL);
+ g_resolver_free_targets(services); static gboolean call_callback(gpointer data) {
@@ -431,8 +447,14 @@
nattype.servername = g_strdup(servername);
callbacks = g_slist_append(callbacks, cb);
- purple_srv_resolve(NULL, "stun", "udp", servername, do_test1,
- (gpointer) servername);
+ g_resolver_lookup_service_async(g_resolver_get_default(),