mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-08-30 22:15:20 +00:00
3786. [func] Provide more detailed error codes when using native PKCS#11. "pkcs11-tokens" now fails robustly rather than asserting when run against an HSM with an incomplete PCKS#11 API implementation. [RT #35479]
86 lines
2.2 KiB
C
86 lines
2.2 KiB
C
/*
|
|
* Copyright (C) 2014 Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
* AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
|
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
* PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <stddef.h>
|
|
|
|
#include <isc/once.h>
|
|
#include <isc/msgcat.h>
|
|
#include <isc/util.h>
|
|
|
|
#include <pk11/result.h>
|
|
|
|
LIBISC_EXTERNAL_DATA isc_msgcat_t * pk11_msgcat = NULL;
|
|
|
|
static isc_once_t msgcat_once = ISC_ONCE_INIT;
|
|
|
|
static const char *text[PK11_R_NRESULTS] = {
|
|
"PKCS#11 initialization failed", /*%< 0 */
|
|
"no PKCS#11 provider", /*%< 1 */
|
|
"PKCS#11 provider has no random service", /*%< 2 */
|
|
"PKCS#11 provider has no digest service", /*%< 3 */
|
|
"PKCS#11 provider has no AES service", /*%< 4 */
|
|
};
|
|
|
|
#define PK11_RESULT_RESULTSET 2
|
|
|
|
static isc_once_t once = ISC_ONCE_INIT;
|
|
|
|
static void
|
|
open_msgcat(void) {
|
|
isc_msgcat_open("libpk11.cat", &pk11_msgcat);
|
|
}
|
|
|
|
void
|
|
pk11_initmsgcat(void) {
|
|
|
|
/*
|
|
* Initialize the PKCS#11 support's message catalog,
|
|
* pk11_msgcat, if it has not already been initialized.
|
|
*/
|
|
|
|
RUNTIME_CHECK(isc_once_do(&msgcat_once, open_msgcat) == ISC_R_SUCCESS);
|
|
}
|
|
|
|
static void
|
|
initialize_action(void) {
|
|
isc_result_t result;
|
|
|
|
result = isc_result_register(ISC_RESULTCLASS_PK11, PK11_R_NRESULTS,
|
|
text, pk11_msgcat, PK11_RESULT_RESULTSET);
|
|
if (result != ISC_R_SUCCESS)
|
|
UNEXPECTED_ERROR(__FILE__, __LINE__,
|
|
"isc_result_register() failed: %u", result);
|
|
}
|
|
|
|
static void
|
|
initialize(void) {
|
|
pk11_initmsgcat();
|
|
RUNTIME_CHECK(isc_once_do(&once, initialize_action) == ISC_R_SUCCESS);
|
|
}
|
|
|
|
const char *
|
|
pk11_result_totext(isc_result_t result) {
|
|
initialize();
|
|
|
|
return (isc_result_totext(result));
|
|
}
|
|
|
|
void
|
|
pk11_result_register(void) {
|
|
initialize();
|
|
}
|