diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-09-21 04:55:43 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-09-21 04:55:43 +0000 |
commit | 93f085c4a25efcac35a3e874798c894cc2fd050e (patch) | |
tree | 0498a0e2ca4270b210bb2d02b5323b0d7883b1a5 /src/common/crypto.c | |
parent | 802b203ff167df4aaf5c26bda1cf6f407530e6d7 (diff) | |
download | tor-93f085c4a25efcac35a3e874798c894cc2fd050e.tar tor-93f085c4a25efcac35a3e874798c894cc2fd050e.tar.gz |
Stop using openssl functions that rely on stdio; they can apparently lead to linker grief on win32.
svn:r2354
Diffstat (limited to 'src/common/crypto.c')
-rw-r--r-- | src/common/crypto.c | 48 |
1 files changed, 28 insertions, 20 deletions
diff --git a/src/common/crypto.c b/src/common/crypto.c index 9977d94ed..16c4ecb95 100644 --- a/src/common/crypto.c +++ b/src/common/crypto.c @@ -317,21 +317,29 @@ int crypto_pk_generate_key(crypto_pk_env_t *env) return 0; } -/** Read a PEM-encoded private key from <b>src</b> into <b>env</b>. +/** Read a PEM-encoded private key from the string <b>s</b> into <b>env</b>. */ -static int crypto_pk_read_private_key_from_file(crypto_pk_env_t *env, - FILE *src) +static int crypto_pk_read_private_key_from_string(crypto_pk_env_t *env, + const char *s) { - tor_assert(env && src); + BIO *b; + + tor_assert(env && s); + + /* Create a read-only memory BIO, backed by the nul-terminated string 's' */ + b = BIO_new_mem_buf((char*)s, -1); if (env->key) RSA_free(env->key); - env->key = PEM_read_RSAPrivateKey(src, NULL, NULL, NULL); + + env->key = PEM_read_bio_RSAPrivateKey(b,NULL,NULL,NULL); + + BIO_free(b); + if (!env->key) { - crypto_log_errors(LOG_WARN, "reading private key from file"); + crypto_log_errors(LOG_WARN, "Error parsing private key"); return -1; } - return 0; } @@ -340,23 +348,23 @@ static int crypto_pk_read_private_key_from_file(crypto_pk_env_t *env, */ int crypto_pk_read_private_key_from_filename(crypto_pk_env_t *env, const char *keyfile) { - FILE *f_pr; - - tor_assert(env && keyfile); - - /* open the keyfile */ - f_pr=fopen(keyfile,"r"); - if (!f_pr) - return -1; + char *contents; + int r; - /* read the private key */ - if(crypto_pk_read_private_key_from_file(env, f_pr) < 0) { - fclose(f_pr); + /* Read the file into a string. */ + contents = read_file_to_str(keyfile, 0); + if (!contents) { + log_fn(LOG_WARN, "Error reading private key from %s", keyfile); return -1; } - fclose(f_pr); - /* check the private key */ + /* Try to parse it. */ + r = crypto_pk_read_private_key_from_string(env, contents); + tor_free(contents); + if (r) + return -1; /* read_private_key_from_string already warned, so we don't.*/ + + /* Make sure it's valid. */ if (crypto_pk_check_key(env) <= 0) return -1; |