mirror of
https://github.com/openssl/openssl.git
synced 2025-03-31 20:10:45 +08:00
add_uris_recursive(): Avoid OSSL_STORE_INFO leak on error
Fixes #26480 Reviewed-by: Tim Hudson <tjh@openssl.org> Reviewed-by: Viktor Dukhovni <viktor@openssl.org> (Merged from https://github.com/openssl/openssl/pull/26511)
This commit is contained in:
parent
56160f173d
commit
be5965acad
@ -1002,16 +1002,17 @@ static int add_uris_recursive(STACK_OF(X509_NAME) *stack,
|
||||
OSSL_STORE_CTX *ctx = NULL;
|
||||
X509 *x = NULL;
|
||||
X509_NAME *xn = NULL;
|
||||
OSSL_STORE_INFO *info = NULL;
|
||||
|
||||
if ((ctx = OSSL_STORE_open(uri, NULL, NULL, NULL, NULL)) == NULL)
|
||||
goto err;
|
||||
|
||||
while (!OSSL_STORE_eof(ctx) && !OSSL_STORE_error(ctx)) {
|
||||
OSSL_STORE_INFO *info = OSSL_STORE_load(ctx);
|
||||
int infotype = info == 0 ? 0 : OSSL_STORE_INFO_get_type(info);
|
||||
int infotype;
|
||||
|
||||
if (info == NULL)
|
||||
if ((info = OSSL_STORE_load(ctx)) == NULL)
|
||||
continue;
|
||||
infotype = OSSL_STORE_INFO_get_type(info);
|
||||
|
||||
if (infotype == OSSL_STORE_INFO_NAME) {
|
||||
/*
|
||||
@ -1036,6 +1037,7 @@ static int add_uris_recursive(STACK_OF(X509_NAME) *stack,
|
||||
}
|
||||
|
||||
OSSL_STORE_INFO_free(info);
|
||||
info = NULL;
|
||||
}
|
||||
|
||||
ERR_clear_error();
|
||||
@ -1043,6 +1045,7 @@ static int add_uris_recursive(STACK_OF(X509_NAME) *stack,
|
||||
|
||||
err:
|
||||
ok = 0;
|
||||
OSSL_STORE_INFO_free(info);
|
||||
done:
|
||||
OSSL_STORE_close(ctx);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user