[svn-commits] jrose: branch certified-13.1 r434418 - in	/certified/branches/13.1: ./ main/
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Wed Apr  8 12:24:24 CDT 2015
    
    
  
Author: jrose
Date: Wed Apr  8 12:24:23 2015
New Revision: 434418
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=434418
Log:
Security/tcptls: MitM Attack potential from certificate with NULL byte in CN.
When registering to a SIP server with TLS, Asterisk will accept CA signed
certificates with a common name that was signed for a domain other than the
one requested if it contains a null character in the common name portion of
the cert. This patch fixes that by checking that the common name length
matches the the length of the content we actually read from the common name
segment. Some certificate authorities automatically sign CA requests when
the requesting CN isn't already taken, so an attacker could potentially
register a CN with something like www.google.com\x00www.secretlyevil.net
and have their certificate signed and Asterisk would accept that certificate
as though it had been for www.google.com - this is a security fix and is
noted in AST-2015-003.
ASTERISK-24847 #close
Reported by: Maciej Szmigiero
Patches:
 asterisk-null-in-cn.patch submitted by mhej (license 6085)
........
Merged revisions 434337 from http://svn.asterisk.org/svn/asterisk/branches/1.8
........
Merged revisions 434338 from http://svn.asterisk.org/svn/asterisk/branches/11
........
Merged revisions 434384 from http://svn.asterisk.org/svn/asterisk/branches/13
Modified:
    certified/branches/13.1/   (props changed)
    certified/branches/13.1/main/tcptls.c
Propchange: certified/branches/13.1/
------------------------------------------------------------------------------
Binary property 'branch-13-merged' - no diff available.
Modified: certified/branches/13.1/main/tcptls.c
URL: http://svnview.digium.com/svn/asterisk/certified/branches/13.1/main/tcptls.c?view=diff&rev=434418&r1=434417&r2=434418
==============================================================================
--- certified/branches/13.1/main/tcptls.c (original)
+++ certified/branches/13.1/main/tcptls.c Wed Apr  8 12:24:23 2015
@@ -640,9 +640,15 @@
 							break;
 						}
 						str = X509_NAME_ENTRY_get_data(X509_NAME_get_entry(name, pos));
-						ASN1_STRING_to_UTF8(&str2, str);
+						ret = ASN1_STRING_to_UTF8(&str2, str);
+						if (ret < 0) {
+							continue;
+						}
+
 						if (str2) {
-							if (!strcasecmp(tcptls_session->parent->hostname, (char *) str2)) {
+							if (strlen((char *) str2) != ret) {
+								ast_log(LOG_WARNING, "Invalid certificate common name length (contains NULL bytes?)\n");
+							} else if (!strcasecmp(tcptls_session->parent->hostname, (char *) str2)) {
 								found = 1;
 							}
 							ast_debug(3, "SSL Common Name compare s1='%s' s2='%s'\n", tcptls_session->parent->hostname, str2);
    
    
More information about the svn-commits
mailing list