Commit ec492c8a authored by Dr. Stephen Henson's avatar Dr. Stephen Henson
Browse files

Compare encodings in X509_cmp as well as hash.

parent 3323314f
Loading
Loading
Loading
Loading
+14 −1
Original line number Diff line number Diff line
@@ -178,11 +178,24 @@ unsigned long X509_subject_name_hash_old(X509 *x)
 */
int X509_cmp(const X509 *a, const X509 *b)
{
	int rv;
	/* ensure hash is valid */
	X509_check_purpose((X509 *)a, -1, 0);
	X509_check_purpose((X509 *)b, -1, 0);

	return memcmp(a->sha1_hash, b->sha1_hash, SHA_DIGEST_LENGTH);
	rv = memcmp(a->sha1_hash, b->sha1_hash, SHA_DIGEST_LENGTH);
	if (rv)
		return rv;
	/* Check for match against stored encoding too */
	if (!a->cert_info->enc.modified && !b->cert_info->enc.modified)
		{
		rv = (int)(a->cert_info->enc.len - b->cert_info->enc.len);
		if (rv)
			return rv;
		return memcmp(a->cert_info->enc.enc, b->cert_info->enc.enc,
				a->cert_info->enc.len);
		}
	return rv;
}
#endif