# HG changeset patch # User William Ehlhardt # Date 1180455639 0 # Node ID 8b322c8afeb68ec9c662c82d85c9510c3a90806d # Parent b31f53796f3bda506e160d73323ee130deed6f85# Parent 5ba545dfe2d660276996b5c14ce45548d276a944 propagate from branch 'im.pidgin.pidgin' (head 5c2d6effc264261827fe521b1ae841611b61dde6) to branch 'im.pidgin.soc.2007.certmgr' (head 6a6fa8ac35fd753ae9141f59e9e6dbcf811162fe) diff -r b31f53796f3b -r 8b322c8afeb6 libpurple/plugins/ssl/ssl-gnutls.c --- a/libpurple/plugins/ssl/ssl-gnutls.c Tue May 29 05:40:45 2007 +0000 +++ b/libpurple/plugins/ssl/ssl-gnutls.c Tue May 29 16:20:39 2007 +0000 @@ -24,12 +24,14 @@ #include "plugin.h" #include "sslconn.h" #include "version.h" +#include "util.h" #define SSL_GNUTLS_PLUGIN_ID "ssl-gnutls" #ifdef HAVE_GNUTLS #include +#include typedef struct { @@ -94,6 +96,67 @@ } else { purple_debug_info("gnutls", "Handshake complete\n"); + { + const gnutls_datum_t *cert_list; + unsigned int cert_list_size = 0; + gnutls_session_t session=gnutls_data->session; + + cert_list = + gnutls_certificate_get_peers(session, &cert_list_size); + + purple_debug_info("gnutls", + "Peer provided %d certs\n", + cert_list_size); + int i; + for (i=0; iconnect_cb(gsc->connect_cb_data, gsc, cond); } diff -r b31f53796f3b -r 8b322c8afeb6 libpurple/util.c --- a/libpurple/util.c Tue May 29 05:40:45 2007 +0000 +++ b/libpurple/util.c Tue May 29 16:20:39 2007 +0000 @@ -155,6 +155,31 @@ return data; } +gchar * +purple_base16_encode_chunked(const guchar *data, gsize len) +{ + int i; + gchar *ascii = NULL; + + g_return_val_if_fail(data != NULL, NULL); + g_return_val_if_fail(len > 0, NULL); + + /* For each byte of input, we need 2 bytes for the hex representation + * and 1 for the colon. + * The final colon will be replaced by a terminating NULL + */ + ascii = g_malloc(len * 3 + 1); + + for (i = 0; i < len; i++) + g_snprintf(&ascii[i * 3], 4, "%02hhx:", data[i]); + + /* Replace the final colon with NULL */ + ascii[len * 3 - 1] = 0; + + return ascii; +} + + /************************************************************************** * Base64 Functions **************************************************************************/ diff -r b31f53796f3b -r 8b322c8afeb6 libpurple/util.h --- a/libpurple/util.h Tue May 29 05:40:45 2007 +0000 +++ b/libpurple/util.h Tue May 29 16:20:39 2007 +0000 @@ -118,6 +118,21 @@ */ guchar *purple_base16_decode(const char *str, gsize *ret_len); +/** + * Converts a chunk of binary data to a chunked base-16 representation + * (handy for key fingerprints) + * + * Example output: 01:23:45:67:89:AB:CD:EF + * + * @param data The data to convert. + * @param len The length of the data. + * + * @return The base-16 string in the ASCII chunked encoding. Must be + * g_free'd when no longer needed. + */ +gchar *purple_base16_encode_chunked(const guchar *data, gsize len); + + /*@}*/ /**************************************************************************/