/********************************************************************** * gost_ctl.c * * Copyright (c) 2005-2006 Cryptocom LTD * * This file is distributed under the same license as OpenSSL * * * * Implementation of control commands for GOST engine * * OpenSSL 0.9.9 libraries required * **********************************************************************/ #include #include #include #include #include #include #include "gost_lcl.h" static char *gost_params[GOST_PARAM_MAX + 1] = { NULL }; static const char *gost_envnames[] = { "CRYPT_PARAMS", "GOST_PBE_HMAC", "GOST_PK_FORMAT" }; const ENGINE_CMD_DEFN gost_cmds[] = { {GOST_CTRL_CRYPT_PARAMS, "CRYPT_PARAMS", "OID of default GOST 28147-89 parameters", ENGINE_CMD_FLAG_STRING}, {GOST_CTRL_PBE_PARAMS, "PBE_PARAMS", "Shortname of default digest alg for PBE", ENGINE_CMD_FLAG_STRING}, {GOST_CTRL_PK_FORMAT, "GOST_PK_FORMAT", "Private key format params", ENGINE_CMD_FLAG_STRING}, {0, NULL, NULL, 0} }; void gost_param_free() { int i; for (i = 0; i <= GOST_PARAM_MAX; i++) { OPENSSL_free(gost_params[i]); gost_params[i] = NULL; } } int gost_control_func(ENGINE *e, int cmd, long i, void *p, void (*f) (void)) { int param = cmd - ENGINE_CMD_BASE; int ret = 0; if (param < 0 || param > GOST_PARAM_MAX) { return -1; } ret = gost_set_default_param(param, p); return ret; } const char *get_gost_engine_param(int param) { char *tmp; if (param < 0 || param > GOST_PARAM_MAX) return NULL; if (gost_params[param] != NULL) { return gost_params[param]; } tmp = getenv(gost_envnames[param]); if (tmp) { OPENSSL_free(gost_params[param]); gost_params[param] = BUF_strdup(tmp); return gost_params[param]; } return NULL; } int gost_set_default_param(int param, const char *value) { const char *tmp; if (param < 0 || param > GOST_PARAM_MAX) return 0; tmp = getenv(gost_envnames[param]); /* * if there is value in the environment, use it, else -passed string * */ if (!tmp) { tmp = value; } OPENSSL_free(gost_params[param]); gost_params[param] = BUF_strdup(tmp); return 1; }