mirror of
https://github.com/openssl/openssl.git
synced 2025-01-06 13:26:43 +08:00
8ae40cf57d
The encoder implementations were implemented by unnecessarily copying code into numerous topical source files, making them hard to maintain. This changes merges all those into two source files, one that encodes into DER and PEM, the other to text. Diverse small cleanups are included. Reviewed-by: Shane Lontis <shane.lontis@oracle.com> (Merged from https://github.com/openssl/openssl/pull/12803)
85 lines
2.4 KiB
C
85 lines
2.4 KiB
C
/*
|
|
* Copyright 2020 The OpenSSL Project Authors. All Rights Reserved.
|
|
*
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
* in the file LICENSE in the source distribution or at
|
|
* https://www.openssl.org/source/license.html
|
|
*/
|
|
|
|
#include <openssl/core.h>
|
|
|
|
#include "endecoder_local.h"
|
|
|
|
OSSL_FUNC_keymgmt_new_fn *
|
|
ossl_prov_get_keymgmt_new(const OSSL_DISPATCH *fns)
|
|
{
|
|
/* Pilfer the keymgmt dispatch table */
|
|
for (; fns->function_id != 0; fns++)
|
|
if (fns->function_id == OSSL_FUNC_KEYMGMT_NEW)
|
|
return OSSL_FUNC_keymgmt_new(fns);
|
|
|
|
return NULL;
|
|
}
|
|
|
|
OSSL_FUNC_keymgmt_free_fn *
|
|
ossl_prov_get_keymgmt_free(const OSSL_DISPATCH *fns)
|
|
{
|
|
/* Pilfer the keymgmt dispatch table */
|
|
for (; fns->function_id != 0; fns++)
|
|
if (fns->function_id == OSSL_FUNC_KEYMGMT_FREE)
|
|
return OSSL_FUNC_keymgmt_free(fns);
|
|
|
|
return NULL;
|
|
}
|
|
|
|
OSSL_FUNC_keymgmt_import_fn *
|
|
ossl_prov_get_keymgmt_import(const OSSL_DISPATCH *fns)
|
|
{
|
|
/* Pilfer the keymgmt dispatch table */
|
|
for (; fns->function_id != 0; fns++)
|
|
if (fns->function_id == OSSL_FUNC_KEYMGMT_IMPORT)
|
|
return OSSL_FUNC_keymgmt_import(fns);
|
|
|
|
return NULL;
|
|
}
|
|
|
|
OSSL_FUNC_keymgmt_export_fn *
|
|
ossl_prov_get_keymgmt_export(const OSSL_DISPATCH *fns)
|
|
{
|
|
/* Pilfer the keymgmt dispatch table */
|
|
for (; fns->function_id != 0; fns++)
|
|
if (fns->function_id == OSSL_FUNC_KEYMGMT_EXPORT)
|
|
return OSSL_FUNC_keymgmt_export(fns);
|
|
|
|
return NULL;
|
|
}
|
|
|
|
void *ossl_prov_import_key(const OSSL_DISPATCH *fns, void *provctx,
|
|
int selection, const OSSL_PARAM params[])
|
|
{
|
|
OSSL_FUNC_keymgmt_new_fn *kmgmt_new = ossl_prov_get_keymgmt_new(fns);
|
|
OSSL_FUNC_keymgmt_free_fn *kmgmt_free = ossl_prov_get_keymgmt_free(fns);
|
|
OSSL_FUNC_keymgmt_import_fn *kmgmt_import =
|
|
ossl_prov_get_keymgmt_import(fns);
|
|
void *key = NULL;
|
|
|
|
if (kmgmt_new != NULL && kmgmt_import != NULL && kmgmt_free != NULL) {
|
|
if ((key = kmgmt_new(provctx)) == NULL
|
|
|| !kmgmt_import(key, selection, params)) {
|
|
kmgmt_free(key);
|
|
key = NULL;
|
|
}
|
|
}
|
|
return key;
|
|
}
|
|
|
|
void ossl_prov_free_key(const OSSL_DISPATCH *fns, void *key)
|
|
{
|
|
OSSL_FUNC_keymgmt_free_fn *kmgmt_free = ossl_prov_get_keymgmt_free(fns);
|
|
|
|
if (kmgmt_free != NULL)
|
|
kmgmt_free(key);
|
|
}
|
|
|