|
Packit |
c4476c |
/*
|
|
Packit |
c4476c |
* Copyright 2001-2018 The OpenSSL Project Authors. All Rights Reserved.
|
|
Packit |
c4476c |
*
|
|
Packit |
c4476c |
* Licensed under the OpenSSL license (the "License"). You may not use
|
|
Packit |
c4476c |
* this file except in compliance with the License. You can obtain a copy
|
|
Packit |
c4476c |
* in the file LICENSE in the source distribution or at
|
|
Packit |
c4476c |
* https://www.openssl.org/source/license.html
|
|
Packit |
c4476c |
*/
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
#include "eng_local.h"
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
static ENGINE_TABLE *dsa_table = NULL;
|
|
Packit |
c4476c |
static const int dummy_nid = 1;
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
void ENGINE_unregister_DSA(ENGINE *e)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
engine_table_unregister(&dsa_table, e);
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
static void engine_unregister_all_DSA(void)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
engine_table_cleanup(&dsa_table);
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
int ENGINE_register_DSA(ENGINE *e)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
if (e->dsa_meth)
|
|
Packit |
c4476c |
return engine_table_register(&dsa_table,
|
|
Packit |
c4476c |
engine_unregister_all_DSA, e, &dummy_nid,
|
|
Packit |
c4476c |
1, 0);
|
|
Packit |
c4476c |
return 1;
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
void ENGINE_register_all_DSA(void)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
ENGINE *e;
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
for (e = ENGINE_get_first(); e; e = ENGINE_get_next(e))
|
|
Packit |
c4476c |
ENGINE_register_DSA(e);
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
int ENGINE_set_default_DSA(ENGINE *e)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
if (e->dsa_meth)
|
|
Packit |
c4476c |
return engine_table_register(&dsa_table,
|
|
Packit |
c4476c |
engine_unregister_all_DSA, e, &dummy_nid,
|
|
Packit |
c4476c |
1, 1);
|
|
Packit |
c4476c |
return 1;
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
/*
|
|
Packit |
c4476c |
* Exposed API function to get a functional reference from the implementation
|
|
Packit |
c4476c |
* table (ie. try to get a functional reference from the tabled structural
|
|
Packit |
c4476c |
* references).
|
|
Packit |
c4476c |
*/
|
|
Packit |
c4476c |
ENGINE *ENGINE_get_default_DSA(void)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
return engine_table_select(&dsa_table, dummy_nid);
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
/* Obtains an DSA implementation from an ENGINE functional reference */
|
|
Packit |
c4476c |
const DSA_METHOD *ENGINE_get_DSA(const ENGINE *e)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
return e->dsa_meth;
|
|
Packit |
c4476c |
}
|
|
Packit |
c4476c |
|
|
Packit |
c4476c |
/* Sets an DSA implementation in an ENGINE structure */
|
|
Packit |
c4476c |
int ENGINE_set_DSA(ENGINE *e, const DSA_METHOD *dsa_meth)
|
|
Packit |
c4476c |
{
|
|
Packit |
c4476c |
e->dsa_meth = dsa_meth;
|
|
Packit |
c4476c |
return 1;
|
|
Packit |
c4476c |
}
|