aboutsummaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2002-10-02 20:39:51 +0000
committerNick Mathewson <nickm@torproject.org>2002-10-02 20:39:51 +0000
commitbef3424bec7ddc67f9d561b1e7f5aa652fb4893f (patch)
treec16defaeeb93b2daf54bb45e80e5535aa1d85f8b /src/common
parent7032d16e78fab3b651ea538920c528e403267000 (diff)
downloadtor-bef3424bec7ddc67f9d561b1e7f5aa652fb4893f.tar
tor-bef3424bec7ddc67f9d561b1e7f5aa652fb4893f.tar.gz
Add convenience functions to wrap create and init for symmetric ciphers; clean up error handling in onion.c
svn:r131
Diffstat (limited to 'src/common')
-rw-r--r--src/common/crypto.c44
-rw-r--r--src/common/crypto.h3
2 files changed, 47 insertions, 0 deletions
diff --git a/src/common/crypto.c b/src/common/crypto.c
index bbf3657d0..fec0a78a6 100644
--- a/src/common/crypto.c
+++ b/src/common/crypto.c
@@ -98,6 +98,49 @@ void crypto_free_pk_env(crypto_pk_env_t *env)
return;
}
+
+/* Create a new crypto_cipher_env_t for a given onion cipher type, key,
+ * iv, and encryption flag (1=encrypt, 0=decrypt). Return the crypto object
+ * on success; NULL on failure.
+ */
+crypto_cipher_env_t *
+crypto_create_init_cipher(int cipher_type, char *key, char *iv, int encrypt_mode)
+{
+ int r;
+ crypto_cipher_env_t *crypto = NULL;
+
+ if (! (crypto = crypto_new_cipher_env(cipher_type))) {
+ log(LOG_ERR, "Unable to allocate crypto object");
+ return NULL;
+ }
+
+ if (crypto_cipher_set_key(crypto, key)) {
+ log(LOG_ERR, "Unable to set key: %s", crypto_perror());
+ goto error;
+ }
+
+ if (crypto_cipher_set_iv(crypto, iv)) {
+ log(LOG_ERR, "Unable to set iv: %s", crypto_perror());
+ goto error;
+ }
+
+ if (encrypt_mode)
+ r = crypto_cipher_encrypt_init_cipher(crypto);
+ else
+ r = crypto_cipher_decrypt_init_cipher(crypto);
+
+ if (r) {
+ log(LOG_ERR, "Unabble to initialize cipher: %s", crypto_perror());
+ goto error;
+ }
+ return crypto;
+
+ error:
+ if (crypto)
+ crypto_free_cipher_env(crypto);
+ return NULL;
+}
+
crypto_cipher_env_t *crypto_new_cipher_env(int type)
{
crypto_cipher_env_t *env;
@@ -650,3 +693,4 @@ char *crypto_perror()
{
return (char *)ERR_reason_error_string(ERR_get_error());
}
+
diff --git a/src/common/crypto.h b/src/common/crypto.h
index 71a7a3cf4..4912ff50e 100644
--- a/src/common/crypto.h
+++ b/src/common/crypto.h
@@ -74,6 +74,9 @@ int crypto_cipher_decrypt_init_cipher(crypto_cipher_env_t *env);
int crypto_cipher_encrypt(crypto_cipher_env_t *env, unsigned char *from, unsigned int fromlen, unsigned char *to);
int crypto_cipher_decrypt(crypto_cipher_env_t *env, unsigned char *from, unsigned int fromlen, unsigned char *to);
+/* convenience function: wraps crypto_create_crypto_env, set_key, set_iv, and init. */
+crypto_cipher_env_t *crypto_create_init_cipher(int cipher_type, char *key, char *iv, int encrypt_mode);
+
/* SHA-1 */
int crypto_SHA_digest(unsigned char *m, int len, unsigned char *digest);