The X509_NAME object needs to be free'd even if printing it fails.
Introduced in
be5adfd6e3 ("Support subjectDirectoryAttributes and
associatedInformation exts", 2024-06-18), but subsequently moved in
7bcfb41489 ("ossl_print_attribute_value(): use a sequence value only if
type is a sequence", 2024-08-05).
Signed-off-by: Beat Bolli <dev@drbeat.li>
Reviewed-by: Tom Cosgrove <tom.cosgrove@arm.com>
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/25207)
unsigned char *value;
X509_NAME *xn = NULL;
int64_t int_val;
+ int ret = 1;
switch (av->type) {
case V_ASN1_BOOLEAN:
return 0;
}
if (X509_NAME_print_ex(out, xn, indent, XN_FLAG_SEP_CPLUS_SPC) <= 0)
- return 0;
+ ret = 0;
X509_NAME_free(xn);
- return 1;
+ return ret;
default:
break;