summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Aurich <darkrain42@pidgin.im>2009-04-03 17:15:40 +0000
committerPaul Aurich <darkrain42@pidgin.im>2009-04-03 17:15:40 +0000
commit84cb80bb70849514078a5e97eba789e15e4e2f50 (patch)
tree363d0663a121bd76378577c3113a55c38b6e3115
parent35800d2eeafac0f92bc963089aa4ad62103fbb4a (diff)
downloadpidgin-84cb80bb70849514078a5e97eba789e15e4e2f50.tar.gz
Migrate googleinfo:jabber handlers and add some safety checks.
Do not parse STUN servers from anyone, enforce that they must come from our bare JID (i.e. our server on behalf of us).
-rw-r--r--libpurple/protocols/jabber/google.c99
-rw-r--r--libpurple/protocols/jabber/google.h4
2 files changed, 67 insertions, 36 deletions
diff --git a/libpurple/protocols/jabber/google.c b/libpurple/protocols/jabber/google.c
index 06157c4438..6337564b9c 100644
--- a/libpurple/protocols/jabber/google.c
+++ b/libpurple/protocols/jabber/google.c
@@ -1160,48 +1160,77 @@ jabber_google_stun_lookup_cb(GSList *hosts, gpointer data,
}
static void
-jabber_google_jingle_info_cb(JabberStream *js, xmlnode *result,
- gpointer nullus)
-{
- if (result) {
- const xmlnode *query =
- xmlnode_get_child_with_namespace(result, "query",
- GOOGLE_JINGLE_INFO_NAMESPACE);
-
- if (query) {
- const xmlnode *stun = xmlnode_get_child(query, "stun");
-
- purple_debug_info("jabber", "got google:jingleinfo\n");
-
- if (stun) {
- xmlnode *server = xmlnode_get_child(stun, "server");
-
- if (server) {
- const gchar *host = xmlnode_get_attrib(server, "host");
- const gchar *udp = xmlnode_get_attrib(server, "udp");
-
- if (host && udp) {
- int port = atoi(udp);
- /* if there, would already be an ongoing query,
- cancel it */
- if (js->stun_query)
- purple_dnsquery_destroy(js->stun_query);
-
- js->stun_query = purple_dnsquery_a(host, port,
- jabber_google_stun_lookup_cb, js);
- }
- }
+jabber_google_jingle_info_common(JabberStream *js, const char *from,
+ JabberIqType type, xmlnode *query)
+{
+ const xmlnode *stun = xmlnode_get_child(query, "stun");
+ gchar *my_bare_jid;
+
+ /*
+ * Make sure that random people aren't sending us STUN servers. Per
+ * http://code.google.com/apis/talk/jep_extensions/jingleinfo.html, these
+ * stanzas are stamped from our bare JID.
+ */
+ if (from) {
+ my_bare_jid = g_strdup_printf("%s@%s", js->user->node, js->user->domain);
+ if (!purple_strequal(from, my_bare_jid)) {
+ purple_debug_warning("jabber", "got google:jingleinfo with invalid from (%s)\n",
+ from);
+ g_free(my_bare_jid);
+ return;
+ }
+
+ g_free(my_bare_jid);
+ }
+
+ if (type == JABBER_IQ_ERROR || type == JABBER_IQ_GET)
+ return;
+
+ purple_debug_info("jabber", "got google:jingleinfo\n");
+
+ if (stun) {
+ xmlnode *server = xmlnode_get_child(stun, "server");
+
+ if (server) {
+ const gchar *host = xmlnode_get_attrib(server, "host");
+ const gchar *udp = xmlnode_get_attrib(server, "udp");
+
+ if (host && udp) {
+ int port = atoi(udp);
+ /* if there, would already be an ongoing query,
+ cancel it */
+ if (js->stun_query)
+ purple_dnsquery_destroy(js->stun_query);
+
+ js->stun_query = purple_dnsquery_a(host, port,
+ jabber_google_stun_lookup_cb, js);
}
- /* should perhaps handle relays later on, or maybe wait until
- Google supports a common standard... */
}
}
+ /* should perhaps handle relays later on, or maybe wait until
+ Google supports a common standard... */
+}
+
+static void
+jabber_google_jingle_info_cb(JabberStream *js, const char *from,
+ JabberIqType type, const char *id,
+ xmlnode *packet, gpointer data)
+{
+ xmlnode *query = xmlnode_get_child_with_namespace(packet, "query",
+ GOOGLE_JINGLE_INFO_NAMESPACE);
+
+ if (query)
+ jabber_google_jingle_info_common(js, from, type, query);
+ else
+ purple_debug_warning("jabber", "Got invalid google:jingleinfo\n");
}
void
-jabber_google_handle_jingle_info(JabberStream *js, xmlnode *packet)
+jabber_google_handle_jingle_info(JabberStream *js, const char *from,
+ JabberIqType type, const char *id,
+ xmlnode *child)
{
- jabber_google_jingle_info_cb(js, packet, NULL);
+ jabber_google_jingle_info_common(js, from, type, child);
}
void
diff --git a/libpurple/protocols/jabber/google.h b/libpurple/protocols/jabber/google.h
index 8cb67ec1dc..1131a558f3 100644
--- a/libpurple/protocols/jabber/google.h
+++ b/libpurple/protocols/jabber/google.h
@@ -53,7 +53,9 @@ char *jabber_google_format_to_html(const char *text);
gboolean jabber_google_session_initiate(JabberStream *js, const gchar *who, PurpleMediaSessionType type);
void jabber_google_session_parse(JabberStream *js, xmlnode *node);
-void jabber_google_handle_jingle_info(JabberStream *js, xmlnode *packet);
+void jabber_google_handle_jingle_info(JabberStream *js, const char *from,
+ JabberIqType type, const char *id,
+ xmlnode *child);
void jabber_google_send_jingle_info(JabberStream *js);
#endif /* _PURPLE_GOOGLE_H_ */