[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[or-cvs] Changed crypto calls to go through common/crypto.[hc] inste...
Update of /home/or/cvsroot/src/or
In directory moria.seul.org:/tmp/cvs-serv19250/src/or
Modified Files:
cell.c circuit.c connection.c connection_ap.c connection_op.c
connection_or.c main.c onion.c or.h routers.c test_onion.c
Log Message:
Changed crypto calls to go through common/crypto.[hc] instead of calling OpenSSL directly.
Index: cell.c
===================================================================
RCS file: /home/or/cvsroot/src/or/cell.c,v
retrieving revision 1.4
retrieving revision 1.5
diff -u -d -r1.4 -r1.5
--- cell.c 19 Jul 2002 18:48:28 -0000 1.4
+++ cell.c 22 Aug 2002 07:30:03 -0000 1.5
@@ -21,8 +21,8 @@
c->seq = 0;
memcpy((void *)c->payload, (void *)buf, length);
- retval = RAND_pseudo_bytes((unsigned char *)(c->payload+length),CELL_PAYLOAD_SIZE-length);
- if (retval == -1) /* RAND_pseudo_bytes() error */
+ retval = crypto_pseudo_rand(CELL_PAYLOAD_SIZE-length, (unsigned char *)(c->payload+length));
+ if (retval) /* RAND_pseudo_bytes() error */
{
free((void *)c);
return NULL;
Index: circuit.c
===================================================================
RCS file: /home/or/cvsroot/src/or/circuit.c,v
retrieving revision 1.9
retrieving revision 1.10
diff -u -d -r1.9 -r1.10
--- circuit.c 22 Jul 2002 04:08:37 -0000 1.9
+++ circuit.c 22 Aug 2002 07:30:03 -0000 1.10
@@ -66,9 +66,11 @@
}
void circuit_free(circuit_t *circ) {
-
- EVP_CIPHER_CTX_cleanup(&circ->n_ctx);
- EVP_CIPHER_CTX_cleanup(&circ->p_ctx);
+
+ if (circ->n_crypto)
+ crypto_free_cipher_env(circ->n_crypto);
+ if (circ->p_crypto)
+ crypto_free_cipher_env(circ->p_crypto);
if(circ->onion)
free(circ->onion);
@@ -93,7 +95,7 @@
log(LOG_DEBUG,"get_unique_aci_by_addr_port() trying to get a unique aci");
- RAND_pseudo_bytes((unsigned char *)&test_aci, 2);
+ crypto_pseudo_rand(2, (unsigned char *)&test_aci);
if(aci_type == ACI_TYPE_LOWER)
test_aci &= htons(0x00FF);
@@ -117,7 +119,7 @@
int circuit_init(circuit_t *circ, int aci_type) {
onion_layer_t *ol;
- int retval = 0;
+ unsigned char iv[16];
unsigned char digest1[20];
unsigned char digest2[20];
@@ -143,32 +145,23 @@
log(LOG_DEBUG,"circuit_init(): Chosen ACI %u.",circ->n_aci);
/* keys */
- SHA1(ol->keyseed,16,digest1);
- SHA1(digest1,20,digest2);
- SHA1(digest2,20,digest1);
- memcpy(circ->p_key,digest2,16);
- memcpy(circ->n_key,digest1,16);
+ memset((void *)iv, 0, 16);
+ crypto_SHA_digest(ol->keyseed,16,digest1);
+ crypto_SHA_digest(digest1,20,digest2);
+ crypto_SHA_digest(digest2,20,digest1);
log(LOG_DEBUG,"circuit_init(): Computed keys.");
- /* set IVs to zero */
- memset(circ->n_iv,0,16);
- memset(circ->p_iv,0,16);
-
- /* initialize cipher context */
- EVP_CIPHER_CTX_init(&circ->n_ctx);
- EVP_CIPHER_CTX_init(&circ->p_ctx);
-
/* initialize crypto engines */
switch(circ->p_f)
{
case ONION_CIPHER_DES :
- retval = EVP_EncryptInit(&circ->p_ctx, EVP_des_ofb(), circ->p_key, circ->p_iv);
+ circ->p_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
break;
case ONION_CIPHER_RC4 :
- retval = EVP_EncryptInit(&circ->p_ctx, EVP_rc4(), circ->p_key,circ->p_iv);
+ circ->p_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_RC4);
break;
case ONION_CIPHER_IDENTITY :
- retval = EVP_EncryptInit(&circ->p_ctx, EVP_enc_null(), circ->p_key, circ->p_iv);
+ circ->p_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_IDENTITY);
break;
default :
log(LOG_ERR,"Onion contains unrecognized cipher(%u) for ACI : %u.",circ->p_f,circ->n_aci);
@@ -176,36 +169,65 @@
break;
}
- if (!retval) /* EVP_EncryptInit() error */
+ if (!circ->p_crypto) {
+ log(LOG_ERR,"Could not create a cryptographic environment.");
+ return -1;
+ }
+ if (crypto_cipher_set_iv(circ->p_crypto, iv) == -1) {
+ log(LOG_ERR,"Could not set the IV.");
+ crypto_free_cipher_env(circ->p_crypto);
+ return -1;
+ }
+ if (crypto_cipher_set_key(circ->p_crypto, digest2) == -1) {
+ log(LOG_ERR,"Could not set encryption key.");
+ crypto_free_cipher_env(circ->p_crypto);
+ return -1;
+ }
+ if (crypto_cipher_encrypt_init_cipher(circ->p_crypto)) /* crypto_cipher_init_cipher error */
{
log(LOG_ERR,"Cipher initialization failed (ACI %u).",circ->n_aci);
- EVP_CIPHER_CTX_cleanup(&circ->n_ctx);
- EVP_CIPHER_CTX_cleanup(&circ->p_ctx);
+ crypto_free_cipher_env(circ->p_crypto);
return -1;
}
+
switch(circ->n_f)
{
case ONION_CIPHER_DES :
- retval = EVP_DecryptInit(&circ->n_ctx, EVP_des_ofb(), circ->n_key, circ->n_iv);
+ circ->n_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
break;
case ONION_CIPHER_RC4 :
- retval = EVP_DecryptInit(&circ->n_ctx, EVP_rc4(), circ->n_key,circ->n_iv);
+ circ->n_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_RC4);
break;
case ONION_CIPHER_IDENTITY :
- retval = EVP_DecryptInit(&circ->n_ctx, EVP_enc_null(), circ->n_key, circ->n_iv);
+ circ->n_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_IDENTITY);
break;
default :
- log(LOG_ERR,"Onion contains unrecognized cipher for ACI : %u.",circ->n_aci);
+ log(LOG_ERR,"Onion contains unrecognized cipher(%u) for ACI : %u.",circ->n_f,circ->n_aci);
return -1;
break;
}
- if (!retval) /* EVP_EncryptInit() error */
+
+ if (!circ->n_crypto) {
+ log(LOG_ERR,"Could not create a cryptographic environment.");
+ return -1;
+ }
+ if (crypto_cipher_set_iv(circ->n_crypto, iv) == -1) {
+ log(LOG_ERR,"Could not set the IV.");
+ crypto_free_cipher_env(circ->n_crypto);
+ return -1;
+ }
+ if (crypto_cipher_set_key(circ->n_crypto, digest1) == -1) {
+ log(LOG_ERR,"Could not set encryption key.");
+ crypto_free_cipher_env(circ->n_crypto);
+ return -1;
+ }
+ if (crypto_cipher_decrypt_init_cipher(circ->n_crypto)) /* crypto_cipher_init_cipher error */
{
log(LOG_ERR,"Cipher initialization failed (ACI %u).",circ->n_aci);
- EVP_CIPHER_CTX_cleanup(&circ->n_ctx);
- EVP_CIPHER_CTX_cleanup(&circ->p_ctx);
+ crypto_free_cipher_env(circ->n_crypto);
return -1;
}
+
log(LOG_DEBUG,"circuit_init(): Cipher initialization complete.");
circ->expire = ol->expire;
@@ -276,13 +298,12 @@
int circuit_crypt(circuit_t *circ, char *in, size_t inlen, char crypt_type) {
char *out;
- int outlen;
int i;
crypt_path_t *thishop;
assert(circ && in);
- out = malloc(inlen);
+ out = (char *)malloc(inlen);
if(!out)
return -1;
@@ -298,8 +319,8 @@
thishop = circ->cpath[i];
/* encrypt */
- if(!EVP_EncryptUpdate(&thishop->f_ctx,out,&outlen,in,inlen)) {
- log(LOG_ERR,"Error performing encryption:%s",ERR_reason_error_string(ERR_get_error()));
+ if(crypto_cipher_encrypt(thishop->f_crypto, in, inlen, (unsigned char *)out)) {
+ log(LOG_ERR,"Error performing encryption:%s",crypto_perror());
free(out);
return -1;
}
@@ -308,9 +329,9 @@
memcpy(in,out,inlen);
}
} else { /* we're in the middle. Just one crypt. */
- if(!EVP_EncryptUpdate(&circ->p_ctx,out,&outlen,in,inlen)) {
+ if(crypto_cipher_encrypt(circ->p_crypto,in, inlen, out)) {
log(LOG_ERR,"circuit_encrypt(): Encryption failed for ACI : %u (%s).",
- circ->p_aci, ERR_reason_error_string(ERR_get_error()));
+ circ->p_aci, crypto_perror());
free(out);
return -1;
}
@@ -327,8 +348,8 @@
thishop = circ->cpath[i];
/* encrypt */
- if(!EVP_DecryptUpdate(&thishop->b_ctx,out,&outlen,in,inlen)) {
- log(LOG_ERR,"Error performing decryption:%s",ERR_reason_error_string(ERR_get_error()));
+ if(crypto_cipher_decrypt(thishop->b_crypto, in, inlen, out)) {
+ log(LOG_ERR,"Error performing decryption:%s",crypto_perror());
free(out);
return -1;
}
@@ -337,9 +358,9 @@
memcpy(in,out,inlen);
}
} else { /* we're in the middle. Just one crypt. */
- if(!EVP_DecryptUpdate(&circ->n_ctx,out,&outlen,in,inlen)) {
+ if(crypto_cipher_decrypt(circ->n_crypto,in, inlen, out)) {
log(LOG_ERR,"circuit_crypt(): Decryption failed for ACI : %u (%s).",
- circ->n_aci, ERR_reason_error_string(ERR_get_error()));
+ circ->n_aci, crypto_perror());
free(out);
return -1;
}
Index: connection.c
===================================================================
RCS file: /home/or/cvsroot/src/or/connection.c,v
retrieving revision 1.11
retrieving revision 1.12
diff -u -d -r1.11 -r1.12
--- connection.c 22 Jul 2002 04:08:37 -0000 1.11
+++ connection.c 22 Aug 2002 07:30:03 -0000 1.12
@@ -86,6 +86,20 @@
conn->receiver_bucket = 10240; /* should be enough to do the handshake */
conn->bandwidth = conn->receiver_bucket / 10; /* give it a default */
+
+ if (connection_speaks_cells(conn)) {
+ conn->f_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
+ if (!conn->f_crypto) {
+ free((void *)conn);
+ return NULL;
+ }
+ conn->b_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
+ if (!conn->b_crypto) {
+ crypto_free_cipher_env(conn->f_crypto);
+ free((void *)conn);
+ return NULL;
+ }
+ }
return conn;
}
@@ -102,8 +116,10 @@
free(conn->dest_port);
if(connection_speaks_cells(conn)) {
- EVP_CIPHER_CTX_cleanup(&conn->f_ctx);
- EVP_CIPHER_CTX_cleanup(&conn->b_ctx);
+ if (conn->f_crypto)
+ crypto_free_cipher_env(conn->f_crypto);
+ if (conn->b_crypto)
+ crypto_free_cipher_env(conn->b_crypto);
}
if(conn->s > 0)
@@ -111,7 +127,7 @@
free(conn);
}
-int connection_create_listener(RSA *prkey, struct sockaddr_in *local, int type) {
+int connection_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local, int type) {
connection_t *conn;
int s;
int one=1;
@@ -230,7 +246,7 @@
}
int retry_all_connections(int role, routerinfo_t **router_array, int rarray_len,
- RSA *prkey, uint16_t or_listenport, uint16_t op_listenport, uint16_t ap_listenport) {
+ crypto_pk_env_t *prkey, uint16_t or_listenport, uint16_t op_listenport, uint16_t ap_listenport) {
/* start all connections that should be up but aren't */
@@ -275,7 +291,7 @@
return 0;
}
-connection_t *connection_connect_to_router_as_op(routerinfo_t *router, RSA *prkey, uint16_t local_or_port) {
+connection_t *connection_connect_to_router_as_op(routerinfo_t *router, crypto_pk_env_t *prkey, uint16_t local_or_port) {
struct sockaddr_in local; /* local address */
if(learn_local(&local) < 0)
@@ -488,7 +504,6 @@
int connection_encrypt_cell_header(cell_t *cellp, connection_t *conn) {
char newheader[8];
- int newsize;
#if 0
int x;
char *px;
@@ -501,7 +516,7 @@
printf("\n");
#endif
- if(!EVP_EncryptUpdate(&conn->f_ctx, newheader, &newsize, (char *)cellp, 8)) {
+ if(crypto_cipher_encrypt(conn->f_crypto, (char *)cellp, 8, newheader)) {
log(LOG_ERR,"Could not encrypt data for connection %s:%u.",conn->address,ntohs(conn->port));
return -1;
}
@@ -664,7 +679,6 @@
*/
char crypted[128];
char outbuf[1024];
- int outlen;
// int x;
cell_t *cellp;
@@ -683,7 +697,7 @@
printf("\n");
#endif
/* decrypt */
- if(!EVP_DecryptUpdate(&conn->b_ctx,(unsigned char *)outbuf,&outlen,crypted,8)) {
+ if(crypto_cipher_decrypt(conn->b_crypto,crypted,8,(unsigned char *)outbuf)) {
log(LOG_ERR,"connection_process_cell_from_inbuf(): Decryption failed, dropping.");
return connection_process_inbuf(conn); /* process the remainder of the buffer */
}
Index: connection_ap.c
===================================================================
RCS file: /home/or/cvsroot/src/or/connection_ap.c,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -d -r1.7 -r1.8
--- connection_ap.c 22 Jul 2002 04:08:37 -0000 1.7
+++ connection_ap.c 22 Aug 2002 07:30:03 -0000 1.8
@@ -378,7 +378,7 @@
}
-int connection_ap_create_listener(RSA *prkey, struct sockaddr_in *local) {
+int connection_ap_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local) {
log(LOG_DEBUG,"connection_create_ap_listener starting");
return connection_create_listener(prkey, local, CONN_TYPE_AP_LISTENER);
}
Index: connection_op.c
===================================================================
RCS file: /home/or/cvsroot/src/or/connection_op.c,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- connection_op.c 18 Jul 2002 06:37:58 -0000 1.5
+++ connection_op.c 22 Aug 2002 07:30:03 -0000 1.6
@@ -33,6 +33,7 @@
int op_handshake_process_keys(connection_t *conn) {
int retval;
int x;
+ unsigned char iv[16];
/* key exchange message */
unsigned char auth_cipher[128];
@@ -51,12 +52,12 @@
log(LOG_DEBUG,"op_handshake_process_keys() : Received auth.");
/* decrypt response */
- retval = RSA_private_decrypt(128,auth_cipher,auth_plain,conn->prkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_private_decrypt(conn->prkey, auth_cipher, 128, auth_plain,RSA_PKCS1_PADDING);
if (retval == -1)
{
log(LOG_ERR,"Decrypting keys from new OP failed.");
log(LOG_DEBUG,"op_handshake_process_keys() : Reason : %s.",
- ERR_reason_error_string(ERR_get_error()));
+ crypto_perror());
return -1;
}
@@ -64,25 +65,24 @@
conn->bandwidth = ntohl(*((uint32_t *)auth_plain));
- memcpy(conn->b_session_key, auth_plain+4, 8);
- memcpy(conn->f_session_key, auth_plain+12, 8);
+ crypto_cipher_set_key(conn->b_crypto, auth_plain+4);
+ crypto_cipher_set_key(conn->f_crypto, auth_plain+12);
printf("f_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->f_session_key[x]);
+ printf("%d ",conn->f_crypto->key[x]);
}
printf("\nb_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->b_session_key[x]);
+ printf("%d ",conn->b_crypto->key[x]);
}
printf("\n");
+
+ memset((void *)iv, 0, 16);
+ crypto_cipher_set_key(conn->b_crypto, iv);
+ crypto_cipher_set_key(conn->f_crypto, iv);
- memset((void *)conn->f_session_iv, 0, 8);
- memset((void *)conn->b_session_iv, 0, 8);
-
- EVP_CIPHER_CTX_init(&conn->f_ctx);
- EVP_CIPHER_CTX_init(&conn->b_ctx);
- EVP_EncryptInit(&conn->b_ctx, EVP_des_ofb(), conn->b_session_key, conn->b_session_iv);
- EVP_DecryptInit(&conn->f_ctx, EVP_des_ofb(), conn->f_session_key, conn->f_session_iv);
+ crypto_cipher_encrypt_init_cipher(conn->b_crypto);
+ crypto_cipher_decrypt_init_cipher(conn->f_crypto);
conn->state = OP_CONN_STATE_OPEN;
connection_init_timeval(conn);
@@ -109,7 +109,7 @@
}
-int connection_op_create_listener(RSA *prkey, struct sockaddr_in *local) {
+int connection_op_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local) {
log(LOG_DEBUG,"connection_create_op_listener starting");
return connection_create_listener(prkey, local, CONN_TYPE_OP_LISTENER);
}
Index: connection_or.c
===================================================================
RCS file: /home/or/cvsroot/src/or/connection_or.c,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -d -r1.7 -r1.8
--- connection_or.c 18 Jul 2002 06:37:58 -0000 1.7
+++ connection_or.c 22 Aug 2002 07:30:03 -0000 1.8
@@ -112,24 +112,25 @@
void conn_or_init_crypto(connection_t *conn) {
int x;
+ unsigned char iv[16];
assert(conn);
printf("f_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->f_session_key[x]);
+ printf("%d ",conn->f_crypto->key[x]);
}
printf("\nb_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->b_session_key[x]);
+ printf("%d ",conn->b_crypto->key[x]);
}
printf("\n");
- memset(conn->f_session_iv,0,8);
- memset(conn->b_session_iv,0,8);
- EVP_CIPHER_CTX_init(&conn->f_ctx);
- EVP_CIPHER_CTX_init(&conn->b_ctx);
- EVP_EncryptInit(&conn->f_ctx, EVP_des_ofb(), conn->f_session_key, conn->f_session_iv);
- EVP_DecryptInit(&conn->b_ctx, EVP_des_ofb(), conn->b_session_key, conn->b_session_iv);
+ memset((void *)iv, 0, 16);
+ crypto_cipher_set_iv(conn->f_crypto, iv);
+ crypto_cipher_set_iv(conn->b_crypto, iv);
+
+ crypto_cipher_encrypt_init_cipher(conn->f_crypto);
+ crypto_cipher_decrypt_init_cipher(conn->b_crypto);
/* always encrypt with f, always decrypt with b */
}
@@ -139,7 +140,7 @@
* *result to 1 if connect() returned before completing, or to 2
* if it completed, and returns the new conn.
*/
-connection_t *connection_or_connect(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local,
+connection_t *connection_or_connect(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local,
uint16_t port, int *result) {
connection_t *conn;
struct sockaddr_in router_addr;
@@ -215,7 +216,7 @@
*
*/
-connection_t *connection_or_connect_as_op(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local) {
+connection_t *connection_or_connect_as_op(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local) {
connection_t *conn;
int result=0; /* so connection_or_connect() can tell us what happened */
@@ -263,28 +264,28 @@
assert(conn && conn->type == CONN_TYPE_OR);
/* generate random keys */
- if(!RAND_bytes(conn->f_session_key,8) ||
- !RAND_bytes(conn->b_session_key,8)) {
+ if(crypto_cipher_generate_key(conn->f_crypto) ||
+ crypto_cipher_generate_key(conn->b_crypto)) {
log(LOG_ERR,"Cannot generate a secure DES key.");
return -1;
}
log(LOG_DEBUG,"or_handshake_op_send_keys() : Generated DES keys.");
/* compose the message */
memcpy((void *)message, (void *)&bandwidth, 4);
- memcpy((void *)(message + 4), (void *)conn->f_session_key, 8);
- memcpy((void *)(message + 12), (void *)conn->b_session_key, 8);
+ memcpy((void *)(message + 4), (void *)conn->f_crypto->key, 8);
+ memcpy((void *)(message + 12), (void *)conn->b_crypto->key, 8);
printf("f_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->f_session_key[x]);
+ printf("%d ",conn->f_crypto->key[x]);
}
printf("\nb_session_key: ");
for(x=0;x<8;x++) {
- printf("%d ",conn->b_session_key[x]);
+ printf("%d ",conn->b_crypto->key[x]);
}
printf("\n");
/* encrypt with RSA */
- if(RSA_public_encrypt(20, message, cipher, conn->pkey, RSA_PKCS1_PADDING) < 0) {
+ if(crypto_pk_public_encrypt(conn->pkey, message, 20, cipher, RSA_PKCS1_PADDING) < 0) {
log(LOG_ERR,"or_handshake_op_send_keys(): Public key encryption failed.");
return -1;
}
@@ -332,7 +333,7 @@
*
*/
-connection_t *connection_or_connect_as_or(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local) {
+connection_t *connection_or_connect_as_or(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local) {
connection_t *conn;
int result=0; /* so connection_or_connect() can tell us what happened */
@@ -374,8 +375,8 @@
assert(conn);
/* generate random keys */
- if(!RAND_bytes(conn->f_session_key,8) ||
- !RAND_bytes(conn->b_session_key,8)) {
+ if(crypto_cipher_generate_key(conn->f_crypto) ||
+ crypto_cipher_generate_key(conn->b_crypto)) {
log(LOG_ERR,"Cannot generate a secure DES key.");
return -1;
}
@@ -386,17 +387,17 @@
memcpy(buf+4,(void *)&conn->local.sin_port,2); /* local port */
memcpy(buf+6, (void *)&conn->addr, 4); /* remote address */
memcpy(buf+10, (void *)&conn->port, 2); /* remote port */
- memcpy(buf+12,conn->f_session_key,8); /* keys */
- memcpy(buf+20,conn->b_session_key,8);
+ memcpy(buf+12,conn->f_crypto->key,8); /* keys */
+ memcpy(buf+20,conn->b_crypto->key,8);
*((uint32_t *)(buf+28)) = htonl(conn->bandwidth); /* max link utilisation */
log(LOG_DEBUG,"or_handshake_client_send_auth() : Generated first authentication message.");
/* encrypt message */
- retval = RSA_public_encrypt(36,buf,cipher,conn->pkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_public_encrypt(conn->pkey, buf, 36, cipher,RSA_PKCS1_PADDING);
if (retval == -1) /* error */
{
log(LOG_ERR,"Public-key encryption failed during authentication to %s:%u.",conn->address,ntohs(conn->port));
- log(LOG_DEBUG,"or_handshake_client_send_auth() : Reason : %s.",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_DEBUG,"or_handshake_client_send_auth() : Reason : %s.",crypto_perror());
return -1;
}
log(LOG_DEBUG,"or_handshake_client_send_auth() : Encrypted authentication message.");
@@ -444,13 +445,13 @@
log(LOG_DEBUG,"or_handshake_client_process_auth() : Received auth.");
/* decrypt response */
- retval = RSA_private_decrypt(128,cipher,buf,conn->prkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_private_decrypt(conn->prkey, cipher, 128, buf, RSA_PKCS1_PADDING);
if (retval == -1)
{
log(LOG_ERR,"Public-key decryption failed during authentication to %s:%u.",
conn->address,ntohs(conn->port));
log(LOG_DEBUG,"or_handshake_client_process_auth() : Reason : %s.",
- ERR_reason_error_string(ERR_get_error()));
+ crypto_perror());
return -1;
}
else if (retval != 44)
@@ -465,8 +466,8 @@
(memcmp(&conn->local.sin_port, buf+4, 2)) || /* local port */
(memcmp(&conn->addr, buf+6, 4)) || /* remote address */
(memcmp(&conn->port, buf+10, 2)) || /* remote port */
- (memcmp(&conn->f_session_key, buf+12, 8)) || /* keys */
- (memcmp(&conn->b_session_key, buf+20, 8)))
+ (memcmp(conn->f_crypto->key, buf+12, 8)) || /* keys */
+ (memcmp(conn->b_crypto->key, buf+20, 8)))
{ /* incorrect response */
log(LOG_ERR,"Router %s:%u failed to authenticate. Either the key I have is obsolete or they're doing something they're not supposed to.",conn->address,ntohs(conn->port));
return -1;
@@ -484,11 +485,11 @@
memcpy(buf+12, buf+36, 8);
/* encrypt reply */
- retval = RSA_public_encrypt(20,buf,cipher,conn->pkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_public_encrypt(conn->pkey, buf, 20, cipher,RSA_PKCS1_PADDING);
if (retval == -1) /* error */
{
log(LOG_ERR,"Public-key encryption failed during authentication to %s:%u.",conn->address,ntohs(conn->port));
- log(LOG_DEBUG,"or_handshake_client_process_auth() : Reason : %s.",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_DEBUG,"or_handshake_client_process_auth() : Reason : %s.",crypto_perror());
return -1;
}
@@ -552,12 +553,12 @@
log(LOG_DEBUG,"or_handshake_server_process_auth() : Received auth.");
/* decrypt response */
- retval = RSA_private_decrypt(128,cipher,buf,conn->prkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_private_decrypt(conn->prkey, cipher, 128, buf,RSA_PKCS1_PADDING);
if (retval == -1)
{
log(LOG_ERR,"Public-key decryption failed processing auth message from new client.");
log(LOG_DEBUG,"or_handshake_server_process_auth() : Reason : %s.",
- ERR_reason_error_string(ERR_get_error()));
+ crypto_perror());
return -1;
}
else if (retval != 36)
@@ -586,8 +587,8 @@
}
/* save keys */
- memcpy(conn->b_session_key,buf+12,8);
- memcpy(conn->f_session_key,buf+20,8);
+ crypto_cipher_set_key(conn->b_crypto,buf+12);
+ crypto_cipher_set_key(conn->f_crypto,buf+20);
/* update link info */
bandwidth = ntohl(*(uint32_t *)(buf+28));
@@ -603,8 +604,8 @@
conn->address = strdup(router->address);
/* generate a nonce */
- retval = RAND_pseudo_bytes(conn->nonce,8);
- if (retval == -1) /* error */
+ retval = crypto_pseudo_rand(8, conn->nonce);
+ if (retval) /* error */
{
log(LOG_ERR,"Cannot generate a nonce.");
return -1;
@@ -616,11 +617,11 @@
*(uint32_t *)(buf+28) = htonl(conn->bandwidth); /* send max link utilisation */
/* encrypt message */
- retval = RSA_public_encrypt(44,buf,cipher,conn->pkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_public_encrypt(conn->pkey, buf, 44, cipher,RSA_PKCS1_PADDING);
if (retval == -1) /* error */
{
log(LOG_ERR,"Public-key encryption failed during authentication to %s:%u.",conn->address,ntohs(conn->port));
- log(LOG_DEBUG,"or_handshake_server_process_auth() : Reason : %s.",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_DEBUG,"or_handshake_server_process_auth() : Reason : %s.",crypto_perror());
return -1;
}
log(LOG_DEBUG,"or_handshake_server_process_auth() : Reply encrypted.");
@@ -668,13 +669,13 @@
log(LOG_DEBUG,"or_handshake_server_process_nonce() : Received auth.");
/* decrypt response */
- retval = RSA_private_decrypt(128,cipher,buf,conn->prkey,RSA_PKCS1_PADDING);
+ retval = crypto_pk_private_decrypt(conn->prkey, cipher, 128, buf,RSA_PKCS1_PADDING);
if (retval == -1)
{
log(LOG_ERR,"Public-key decryption failed during authentication to %s:%u.",
conn->address,ntohs(conn->port));
log(LOG_DEBUG,"or_handshake_server_process_nonce() : Reason : %s.",
- ERR_reason_error_string(ERR_get_error()));
+ crypto_perror());
return -1;
}
else if (retval != 20)
@@ -709,7 +710,7 @@
/* ********************************** */
-int connection_or_create_listener(RSA *prkey, struct sockaddr_in *local) {
+int connection_or_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local) {
log(LOG_DEBUG,"connection_create_or_listener starting");
return connection_create_listener(prkey, local, CONN_TYPE_OR_LISTENER);
}
Index: main.c
===================================================================
RCS file: /home/or/cvsroot/src/or/main.c,v
retrieving revision 1.15
retrieving revision 1.16
diff -u -d -r1.15 -r1.16
--- main.c 22 Jul 2002 04:08:37 -0000 1.15
+++ main.c 22 Aug 2002 07:30:03 -0000 1.16
@@ -18,7 +18,7 @@
static int nfds=0; /* number of connections currently active */
/* private key */
-static RSA *prkey = NULL;
+static crypto_pk_env_t *prkey;
/* router array */
static routerinfo_t **router_array = NULL;
@@ -89,20 +89,10 @@
return 0;
}
-int pkey_cmp(RSA *a, RSA *b) {
+int pkey_cmp(crypto_pk_env_t *a, crypto_pk_env_t *b) {
/* return 0 if a and b are "the same key". Return non-0 otherwise. */
- int result;
-
- if(!a || !b)
- return -1;
-
- assert(a->n && a->e && b->n && b->e);
-
- result = BN_cmp(a->n, b->n);
- if(result)
- return result;
- return BN_cmp(a->e, b->e);
+ return crypto_pk_cmp_keys(a, b);
}
connection_t *connection_twin_get_by_addr_port(uint32_t addr, uint16_t port) {
@@ -431,13 +421,16 @@
}
/* load the private key */
- prkey = load_prkey(options.PrivateKeyFile);
- if (!prkey)
+ prkey = crypto_new_pk_env(CRYPTO_PK_RSA);
+ if (!prkey) {
+ log(LOG_ERR,"Error creating a crypto environment.");
+ return -1;
+ }
+ if (crypto_pk_read_private_key_filename(prkey, options.PrivateKeyFile))
{
log(LOG_ERR,"Error loading private key.");
return -1;
}
- log(LOG_DEBUG,"core : Loaded private key of size %u bytes.",RSA_size(prkey));
/* start-up the necessary connections based on global_role. This is where we
* try to connect to all the other ORs, and start the listeners */
@@ -506,9 +499,9 @@
log(options.loglevel,NULL); /* assign logging severity level from options */
global_role = options.Role; /* assign global_role from options. FIX: remove from global namespace later. */
- ERR_load_crypto_strings();
+ crypto_global_init();
retval = do_main_loop();
- ERR_free_strings();
+ crypto_global_cleanup();
return retval;
}
Index: onion.c
===================================================================
RCS file: /home/or/cvsroot/src/or/onion.c,v
retrieving revision 1.6
retrieving revision 1.7
diff -u -d -r1.6 -r1.7
--- onion.c 22 Jul 2002 04:38:36 -0000 1.6
+++ onion.c 22 Aug 2002 07:30:03 -0000 1.7
@@ -75,8 +75,8 @@
while(1)
{
- retval = RAND_pseudo_bytes(&coin,1);
- if (retval == -1)
+ retval = crypto_pseudo_rand(1, &coin);
+ if (retval)
return -1;
if (coin > cw*255) /* don't extend */
@@ -125,8 +125,8 @@
for(i=0;i<routelen;i++)
{
log(LOG_DEBUG,"new_route() : Choosing hop %u.",i);
- retval = RAND_pseudo_bytes((unsigned char *)&choice,sizeof(unsigned int));
- if (retval == -1)
+ retval = crypto_pseudo_rand(sizeof(unsigned int),(unsigned char *)&choice);
+ if (retval)
{
free((void *)route);
return NULL;
@@ -161,6 +161,7 @@
unsigned char *retbuf = NULL;
unsigned char *bufp;
routerinfo_t *router;
+ unsigned char iv[16];
assert(rarray && route && lenp && routelen);
@@ -179,7 +180,7 @@
for (retval=0; retval<routelen;retval++)
{
- log(LOG_DEBUG,"create_onion() : %u : %s:%u, %u/%u",routelen-retval,inet_ntoa(*((struct in_addr *)&((rarray[route[retval]])->addr))),ntohs((rarray[route[retval]])->or_port),(rarray[route[retval]])->pkey,RSA_size((rarray[route[retval]])->pkey));
+ log(LOG_DEBUG,"create_onion() : %u : %s:%u, %u/%u",routelen-retval,inet_ntoa(*((struct in_addr *)&((rarray[route[retval]])->addr))),ntohs((rarray[route[retval]])->or_port),(rarray[route[retval]])->pkey,crypto_pk_keysize((rarray[route[retval]])->pkey));
}
layer = (onion_layer_t *)(bufp + *lenp - 128); /* pointer to innermost layer */
@@ -191,7 +192,7 @@
log(LOG_DEBUG,"create_onion() : %u",router);
log(LOG_DEBUG,"create_onion() : This router is %s:%u",inet_ntoa(*((struct in_addr *)&router->addr)),ntohs(router->or_port));
log(LOG_DEBUG,"create_onion() : Key pointer = %u.",router->pkey);
- log(LOG_DEBUG,"create_onion() : Key size = %u.",RSA_size(router->pkey));
+ log(LOG_DEBUG,"create_onion() : Key size = %u.",crypto_pk_keysize(router->pkey));
/* 0 bit */
layer->zero = 0;
@@ -213,15 +214,21 @@
/* Expiration Time */
layer->expire = time(NULL) + 3600; /* NOW + 1 hour */
/* Key Seed Material */
- retval = RAND_bytes(layer->keyseed,16);
- if (retval < 1) /* error */
+ retval = crypto_rand(16, layer->keyseed);
+ if (retval) /* error */
{
log(LOG_ERR,"Error generating random data.");
free((void *)bufp);
if (cpathp)
{
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
+
free((void *)cpathp[i]);
+ }
}
return NULL;
}
@@ -235,8 +242,14 @@
{
log(LOG_ERR,"Error allocating memory.");
free((void *)bufp);
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
+
free((void *)cpathp[i]);
+ }
}
log(LOG_DEBUG,"create_onion() : Building hop %u of crypt path.",i+1);
@@ -246,78 +259,131 @@
hop->forwf = layer->forwf;
/* calculate keys */
- SHA1(layer->keyseed,16,hop->digest3);
+ crypto_SHA_digest(layer->keyseed,16,hop->digest3);
log(LOG_DEBUG,"create_onion() : First SHA pass performed.");
- SHA1(hop->digest3,20,hop->digest2);
+ crypto_SHA_digest(hop->digest3,20,hop->digest2);
log(LOG_DEBUG,"create_onion() : Second SHA pass performed.");
- SHA1(hop->digest2,20,hop->digest3);
+ crypto_SHA_digest(hop->digest2,20,hop->digest3);
log(LOG_DEBUG,"create_onion() : Third SHA pass performed.");
log(LOG_DEBUG,"create_onion() : Keys generated.");
- /* set IVs */
- memset((void *)hop->f_iv,0,16);
- memset((void *)hop->b_iv,0,16);
-
- /* initialize cipher contexts */
- EVP_CIPHER_CTX_init(&hop->f_ctx);
- EVP_CIPHER_CTX_init(&hop->b_ctx);
+ /* set IV to zero */
+ memset((void *)iv,0,16);
/* initialize cipher engines */
switch(layer->forwf)
{
case ONION_CIPHER_DES :
- retval = EVP_EncryptInit(&hop->f_ctx, EVP_des_ofb(), hop->digest3, hop->f_iv);
+ hop->f_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
break;
case ONION_CIPHER_RC4 :
- retval = EVP_EncryptInit(&hop->f_ctx, EVP_rc4(), hop->digest3, hop->f_iv);
+ hop->f_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_RC4);
break;
case ONION_CIPHER_IDENTITY :
- retval = EVP_EncryptInit(&hop->f_ctx, EVP_enc_null(), hop->digest3, hop->f_iv);
+ hop->f_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_IDENTITY);
break;
}
- if (!retval) /* cipher initialization failed */
+ if (!hop->f_crypto) /* cipher initialization failed */
{
- log(LOG_ERR,"Could not initialize crypto engines.");
+ log(LOG_ERR,"Could not create a crypto environment.");
free((void *)bufp);
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
free((void *)cpathp[i]);
+ }
return NULL;
}
+ /* set the key and IV */
+ if (crypto_cipher_set_key(hop->f_crypto, hop->digest3) ||
+ crypto_cipher_set_iv(hop->f_crypto, iv)) {
+ log(LOG_ERR,"Could not initialize the crypto engine.");
+ free((void *)bufp);
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
+ free((void *)cpathp[i]);
+ }
+ return NULL;
+ }
+
switch(layer->backf)
{
case ONION_CIPHER_DES :
- retval = EVP_DecryptInit(&hop->b_ctx, EVP_des_ofb(), hop->digest2, hop->b_iv);
+ hop->b_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
break;
case ONION_CIPHER_RC4 :
- retval = EVP_DecryptInit(&hop->b_ctx, EVP_rc4(), hop->digest2, hop->b_iv);
+ hop->b_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_RC4);
break;
case ONION_CIPHER_IDENTITY :
- retval = EVP_DecryptInit(&hop->b_ctx, EVP_enc_null(), hop->digest2, hop->b_iv);
+ hop->b_crypto = crypto_new_cipher_env(CRYPTO_CIPHER_IDENTITY);
break;
}
- if (!retval) /* cipher initialization failed */
+ if (!hop->b_crypto) /* cipher initialization failed */
{
- log(LOG_ERR,"Could not initialize crypto engines.");
+ log(LOG_ERR,"Could not create a crypto environment.");
free((void *)bufp);
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
free((void *)cpathp[i]);
+ }
return NULL;
}
-
+ /* set the key and IV */
+ if (crypto_cipher_set_key(hop->b_crypto, hop->digest2) ||
+ crypto_cipher_set_iv(hop->b_crypto, iv)) {
+ log(LOG_ERR,"Could not initialize the crypto engine.");
+ free((void *)bufp);
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
+ free((void *)cpathp[i]);
+ }
+ return NULL;
+ }
+
+ /* initialize */
+ if (crypto_cipher_encrypt_init_cipher(hop->f_crypto) || crypto_cipher_decrypt_init_cipher(hop->b_crypto)) {
+ log(LOG_ERR,"Could not initialize the crypto engine.");
+ free((void *)bufp);
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
+ free((void *)cpathp[i]);
+ }
+ return NULL;
+ }
+
log(LOG_DEBUG,"create_onion() : Built corresponding crypt path hop.");
}
/* padding if this is the innermost layer */
if (!i)
{
- retval=RAND_pseudo_bytes((unsigned char *)layer + 28,100);
- if (retval == -1) /* error */
+ retval=crypto_pseudo_rand(100, (unsigned char *)layer + 28);
+ if (retval) /* error */
{
log(LOG_ERR,"Error generating pseudo-random data.");
free((void *)bufp);
if (cpathp)
{
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
free((void *)cpathp[i]);
+ }
}
return NULL;
}
@@ -332,8 +398,13 @@
free((void *)bufp);
if (cpathp)
{
- for (j=0;j<i;j++)
+ for (j=0;j<i;j++) {
+ if (cpathp[i]->f_crypto)
+ crypto_free_cipher_env(cpathp[i]->f_crypto);
+ if (cpathp[i]->b_crypto)
+ crypto_free_cipher_env(cpathp[i]->b_crypto);
free((void *)cpathp[i]);
+ }
}
return NULL;
}
@@ -348,16 +419,14 @@
/* encrypts 128 bytes of the onion with the specified public key, the rest with
* DES OFB with the key as defined in the outter layer */
-unsigned char *encrypt_onion(onion_layer_t *onion, uint32_t onionlen, RSA *pkey)
+unsigned char *encrypt_onion(onion_layer_t *onion, uint32_t onionlen, crypto_pk_env_t *pkey)
{
unsigned char *tmpbuf = NULL; /* temporary buffer for crypto operations */
unsigned char digest[20]; /* stores SHA1 output - 160 bits */
- unsigned char *retbuf = NULL;
unsigned char iv[8];
int retval = 0;
- int outlen = 0;
- EVP_CIPHER_CTX ctx; /* cipher context */
+ crypto_cipher_env_t *crypt_env; /* crypto environment */
if ( (onion) && (pkey) ) /* valid parameters */
{
@@ -374,8 +443,7 @@
log(LOG_DEBUG,"encrypt_onion() : allocated %u bytes of memory for the encrypted onion (at %u).",onionlen,tmpbuf);
/* get key1 = SHA1(KeySeed) */
- retbuf = SHA1(((onion_layer_t *)onion)->keyseed,16,digest);
- if (!retbuf)
+ if (crypto_SHA_digest(((onion_layer_t *)onion)->keyseed,16,digest))
{
log(LOG_ERR,"Error computing SHA1 digest.");
free((void *)tmpbuf);
@@ -385,10 +453,10 @@
log(LOG_DEBUG,"encrypt_onion() : Trying to RSA encrypt.");
/* encrypt 128 bytes with RSA *pkey */
- retval = RSA_public_encrypt(128, (unsigned char *)onion, tmpbuf, pkey, RSA_NO_PADDING);
+ retval = crypto_pk_public_encrypt(pkey, (unsigned char *)onion, 128, tmpbuf, RSA_NO_PADDING);
if (retval == -1)
{
- log(LOG_ERR,"Error RSA-encrypting data :%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error RSA-encrypting data :%s",crypto_perror());
free((void *)tmpbuf);
return NULL;
}
@@ -396,26 +464,41 @@
log(LOG_DEBUG,"encrypt_onion() : RSA encrypted first 128 bytes of the onion.");
/* now encrypt the rest with DES OFB */
-
- EVP_CIPHER_CTX_init(&ctx);
- retval = EVP_EncryptInit(&ctx,EVP_des_ofb(),digest,iv);
- if (!retval) /* error */
+ crypt_env = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
+ if (!crypt_env)
+ {
+ log(LOG_ERR,"Error creating the crypto environment.");
+ free((void *)tmpbuf);
+ return NULL;
+ }
+ if (crypto_cipher_set_key(crypt_env, digest)) /* error */
{
- log(LOG_ERR,"Error initializing DES engine:%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
free((void *)tmpbuf);
return NULL;
}
+ if (crypto_cipher_set_iv(crypt_env, iv))
+ {
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
+ free((void *)tmpbuf);
+ return NULL;
+ }
+ if (crypto_cipher_encrypt_init_cipher(crypt_env)) {
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
+ free((void *)tmpbuf);
+ return NULL;
+ }
- retval = EVP_EncryptUpdate(&ctx,(unsigned char *)tmpbuf+128,&outlen,(unsigned char *)onion+128,onionlen-128);
- if (!retval) /* error */
+ retval = crypto_cipher_encrypt(crypt_env,(unsigned char *)onion+128, onionlen-128, (unsigned char *)tmpbuf+128);
+ if (retval) /* error */
{
- log(LOG_ERR,"Error performing DES encryption:%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error performing DES encryption:%s",crypto_perror());
free((void *)tmpbuf);
return NULL;
}
log(LOG_DEBUG,"encrypt_onion() : DES OFB encrypted the rest of the onion.");
- EVP_CIPHER_CTX_cleanup(&ctx);
+ crypto_free_cipher_env(crypt_env);
/* now copy tmpbuf to onion */
memcpy((void *)onion,(void *)tmpbuf,onionlen);
@@ -428,16 +511,14 @@
}
/* decrypts the first 128 bytes using RSA and prkey, decrypts the rest with DES OFB with key1 */
-unsigned char *decrypt_onion(onion_layer_t *onion, uint32_t onionlen, RSA *prkey)
+unsigned char *decrypt_onion(onion_layer_t *onion, uint32_t onionlen, crypto_pk_env_t *prkey)
{
void *tmpbuf = NULL; /* temporary buffer for crypto operations */
unsigned char digest[20]; /* stores SHA1 output - 160 bits */
- unsigned char *retbuf = NULL;
unsigned char iv[8];
int retval = 0;
- int outlen = 0;
- EVP_CIPHER_CTX ctx; /* cipher context */
+ crypto_cipher_env_t *crypt_env; /* crypto environment */
if ( (onion) && (prkey) ) /* valid parameters */
{
@@ -453,18 +534,18 @@
log(LOG_DEBUG,"decrypt_onion() : Allocated memory for the temporary buffer.");
/* decrypt 128 bytes with RSA *prkey */
- retval = RSA_private_decrypt(128, (unsigned char*)onion, (unsigned char *)tmpbuf, prkey, RSA_NO_PADDING);
+ retval = crypto_pk_private_decrypt(prkey, (unsigned char*)onion, 128, (unsigned char *)tmpbuf, RSA_NO_PADDING);
if (retval == -1)
{
- log(LOG_ERR,"Error RSA-decrypting data :%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error RSA-decrypting data :%s",crypto_perror());
free((void *)tmpbuf);
return NULL;
}
log(LOG_DEBUG,"decrypt_onion() : RSA decryption complete.");
/* get key1 = SHA1(KeySeed) */
- retbuf = SHA1(((onion_layer_t *)tmpbuf)->keyseed,16,digest);
- if (!retbuf)
+ retval = crypto_SHA_digest(((onion_layer_t *)tmpbuf)->keyseed,16,digest);
+ if (retval)
{
log(LOG_ERR,"Error computing SHA1 digest.");
free((void *)tmpbuf);
@@ -473,23 +554,40 @@
log(LOG_DEBUG,"decrypt_onion() : Computed DES key.");
/* now decrypt the rest with DES OFB */
- EVP_CIPHER_CTX_init(&ctx);
- retval = EVP_DecryptInit(&ctx,EVP_des_ofb(),digest,iv);
- if (!retval) /* error */
+ crypt_env = crypto_new_cipher_env(CRYPTO_CIPHER_DES);
+ if (!crypt_env)
{
- log(LOG_ERR,"Error initializing DES engine:%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error creating the crypto environment.");
free((void *)tmpbuf);
return NULL;
}
- retval = EVP_DecryptUpdate(&ctx,(unsigned char *)tmpbuf+128,&outlen,(unsigned char *)onion+128,onionlen-128);
- if (!retval) /* error */
+ if (crypto_cipher_set_key(crypt_env, digest)) /* error */
{
- log(LOG_ERR,"Error performing DES decryption:%s",ERR_reason_error_string(ERR_get_error()));
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
+ free((void *)tmpbuf);
+ return NULL;
+ }
+ if (crypto_cipher_set_iv(crypt_env, iv))
+ {
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
+ free((void *)tmpbuf);
+ return NULL;
+ }
+ if (crypto_cipher_decrypt_init_cipher(crypt_env)) {
+ log(LOG_ERR,"Error initializing DES engine:%s",crypto_perror());
free((void *)tmpbuf);
return NULL;
}
- EVP_CIPHER_CTX_cleanup(&ctx);
+ retval = crypto_cipher_decrypt(crypt_env,(unsigned char *)onion+128, onionlen-128,(unsigned char *)tmpbuf+128);
+ if (retval) /* error */
+ {
+ log(LOG_ERR,"Error performing DES decryption:%s",crypto_perror());
+ free((void *)tmpbuf);
+ return NULL;
+ }
+
+ crypto_free_cipher_env(crypt_env);
log(LOG_DEBUG,"decrypt_onion() : DES decryption complete.");
/* now copy tmpbuf to onion */
@@ -507,7 +605,7 @@
if (onion) /* valid parameter */
{
memmove((void *)onion,(void *)(onion+n),onionlen-n);
- RAND_pseudo_bytes(onion+onionlen-n,n);
+ crypto_pseudo_rand(n, onion+onionlen-n);
}
}
@@ -525,8 +623,7 @@
to->expire = ((onion_layer_t *)onion)->expire; /* set the expiration date */
/* compute the SHA digest */
- SHA1(onion, onionlen, to->digest);
- if (!to->digest)
+ if (crypto_SHA_digest(onion, onionlen, to->digest))
{
log(LOG_DEBUG,"new_tracked_onion() : Failed to compute a SHA1 digest of the onion.");
free((void *)to);
@@ -579,7 +676,7 @@
unsigned char digest[20];
/* compute the SHA digest of the onion */
- SHA1(onion,onionlen, digest);
+ crypto_SHA_digest(onion,onionlen, digest);
while(to)
{
Index: or.h
===================================================================
RCS file: /home/or/cvsroot/src/or/or.h,v
retrieving revision 1.13
retrieving revision 1.14
diff -u -d -r1.13 -r1.14
--- or.h 19 Jul 2002 18:48:28 -0000 1.13
+++ or.h 22 Aug 2002 07:30:03 -0000 1.14
@@ -22,15 +22,10 @@
#include <arpa/inet.h>
#include <errno.h>
#include <assert.h>
-
-#include <openssl/err.h>
-#include <openssl/rsa.h>
-#include <openssl/pem.h>
-#include <openssl/evp.h>
-#include <openssl/rand.h>
+#include <time.h>
#include "../common/config.h"
-#include "../common/key.h"
+#include "../common/crypto.h"
#include "../common/log.h"
#include "../common/ss.h"
#include "../common/version.h"
@@ -169,12 +164,8 @@
struct timeval send_timeval; /* for determining when to send the next cell */
/* link encryption */
- unsigned char f_session_key[8];
- unsigned char b_session_key[8];
- unsigned char f_session_iv[8];
- unsigned char b_session_iv[8];
- EVP_CIPHER_CTX f_ctx;
- EVP_CIPHER_CTX b_ctx;
+ crypto_cipher_env_t *f_crypto;
+ crypto_cipher_env_t *b_crypto;
// struct timeval lastsend; /* time of last transmission to the client */
// struct timeval interval; /* transmission interval */
@@ -193,7 +184,7 @@
/* used by OR, to keep state while connect()ing: Kludge. */
- RSA *prkey;
+ crypto_pk_env_t *prkey;
struct sockaddr_in local;
#if 0 /* obsolete, we now use conn->bandwidth */
@@ -203,7 +194,7 @@
#endif
char *address; /* strdup into this, because free_connection frees it */
- RSA *pkey; /* public RSA key for the other side */
+ crypto_pk_env_t *pkey; /* public RSA key for the other side */
char nonce[8];
@@ -219,7 +210,7 @@
uint16_t op_port;
uint16_t ap_port;
- RSA *pkey; /* public RSA key */
+ crypto_pk_env_t *pkey; /* public RSA key */
/* link info */
uint32_t min;
@@ -242,13 +233,9 @@
char digest2[20]; /* second SHA output for onion_layer_t.keyseed */
char digest3[20]; /* third SHA output for onion_layer_t.keyseed */
- /* IVs */
- char f_iv[16];
- char b_iv[16];
-
- /* cipher contexts */
- EVP_CIPHER_CTX f_ctx;
- EVP_CIPHER_CTX b_ctx;
+ /* crypto environments */
+ crypto_cipher_env_t *f_crypto;
+ crypto_cipher_env_t *b_crypto;
} crypt_path_t;
@@ -272,14 +259,8 @@
unsigned char p_f; /* crypto functions */
unsigned char n_f;
- unsigned char p_key[16]; /* crypto keys */
- unsigned char n_key[16];
-
- unsigned char p_iv[16]; /* initialization vectors */
- unsigned char n_iv[16];
-
- EVP_CIPHER_CTX p_ctx; /* cipher context */
- EVP_CIPHER_CTX n_ctx;
+ crypto_cipher_env_t *p_crypto; /* crypto environments */
+ crypto_cipher_env_t *n_crypto;
crypt_path_t **cpath;
size_t cpathlen;
@@ -415,14 +396,14 @@
void connection_free(connection_t *conn);
-int connection_create_listener(RSA *prkey, struct sockaddr_in *local, int type);
+int connection_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local, int type);
int connection_handle_listener_read(connection_t *conn, int new_type, int new_state);
/* start all connections that should be up but aren't */
int retry_all_connections(int role, routerinfo_t **router_array, int rarray_len,
- RSA *prkey, uint16_t or_port, uint16_t op_port, uint16_t ap_port);
-connection_t *connection_connect_to_router_as_op(routerinfo_t *router, RSA *prkey, uint16_t local_or_port);
+ crypto_pk_env_t *prkey, uint16_t or_port, uint16_t op_port, uint16_t ap_port);
+connection_t *connection_connect_to_router_as_op(routerinfo_t *router, crypto_pk_env_t *prkey, uint16_t local_or_port);
int connection_read_to_buf(connection_t *conn);
@@ -475,7 +456,7 @@
int connection_ap_finished_flushing(connection_t *conn);
-int connection_ap_create_listener(RSA *prkey, struct sockaddr_in *local);
+int connection_ap_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local);
int connection_ap_handle_listener_read(connection_t *conn);
@@ -496,7 +477,7 @@
int connection_op_finished_flushing(connection_t *conn);
-int connection_op_create_listener(RSA *prkey, struct sockaddr_in *local);
+int connection_op_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local);
int connection_op_handle_listener_read(connection_t *conn);
@@ -516,11 +497,11 @@
int or_handshake_server_process_auth(connection_t *conn);
int or_handshake_server_process_nonce(connection_t *conn);
-connection_t *connect_to_router_as_or(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local);
-connection_t *connection_or_connect_as_or(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local);
-connection_t *connection_or_connect_as_op(routerinfo_t *router, RSA *prkey, struct sockaddr_in *local);
+connection_t *connect_to_router_as_or(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local);
+connection_t *connection_or_connect_as_or(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local);
+connection_t *connection_or_connect_as_op(routerinfo_t *router, crypto_pk_env_t *prkey, struct sockaddr_in *local);
-int connection_or_create_listener(RSA *prkey, struct sockaddr_in *local);
+int connection_or_create_listener(crypto_pk_env_t *prkey, struct sockaddr_in *local);
int connection_or_handle_listener_read(connection_t *conn);
/********************************* main.c ***************************/
@@ -529,7 +510,7 @@
int connection_remove(connection_t *conn);
void connection_set_poll_socket(connection_t *conn);
-int pkey_cmp(RSA *a, RSA *b);
+int pkey_cmp(crypto_pk_env_t *a, crypto_pk_env_t *b);
connection_t *connection_twin_get_by_addr_port(uint32_t addr, uint16_t port);
connection_t *connection_exact_get_by_addr_port(uint32_t addr, uint16_t port);
@@ -578,10 +559,10 @@
/* encrypts 128 bytes of the onion with the specified public key, the rest with
* DES OFB with the key as defined in the outter layer */
-unsigned char *encrypt_onion(onion_layer_t *onion, uint32_t onionlen, RSA *pkey);
+unsigned char *encrypt_onion(onion_layer_t *onion, uint32_t onionlen, crypto_pk_env_t *pkey);
/* decrypts the first 128 bytes using RSA and prkey, decrypts the rest with DES OFB with key1 */
-unsigned char *decrypt_onion(onion_layer_t *onion, uint32_t onionlen, RSA *prkey);
+unsigned char *decrypt_onion(onion_layer_t *onion, uint32_t onionlen, crypto_pk_env_t *prkey);
/* delete first n bytes of the onion and pads the end with n bytes of random data */
void pad_onion(unsigned char *onion, uint32_t onionlen, size_t n);
Index: routers.c
===================================================================
RCS file: /home/or/cvsroot/src/or/routers.c,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- routers.c 22 Jul 2002 04:08:37 -0000 1.5
+++ routers.c 22 Aug 2002 07:30:03 -0000 1.6
@@ -62,7 +62,7 @@
{
tmp=list->next;
free((void *)list->address);
- RSA_free(list->pkey);
+ crypto_free_pk_env(list->pkey);
free((void *)list);
list = tmp;
}
@@ -275,9 +275,8 @@
log(LOG_DEBUG,"getrouters():Reading the key ...");
/* read the public key into router->pkey */
- router->pkey=NULL;
- router->pkey = PEM_read_RSAPublicKey(rf,&router->pkey,NULL,NULL);
- if (!router->pkey) /* something went wrong */
+ router->pkey = crypto_new_pk_env(CRYPTO_PK_RSA);
+ if (crypto_pk_read_public_key(router->pkey, rf)) /* something went wrong */
{
log(LOG_ERR,"Could not read public key for router %s:%u.",
router->address,router->or_port);
@@ -289,12 +288,12 @@
}
else /* read the key */
{
- log(LOG_DEBUG,"getrouters():Public key size = %u.", RSA_size(router->pkey));
- if (RSA_size(router->pkey) != 128) /* keys MUST be 1024 bits in size */
+ log(LOG_DEBUG,"getrouters():Public key size = %u.", crypto_pk_keysize(router->pkey));
+ if (crypto_pk_keysize(router->pkey) != 128) /* keys MUST be 1024 bits in size */
{
log(LOG_ERR,"Key for router %s:%u is not 1024 bits. All keys must be exactly 1024 bits long.",router->address,router->or_port);
free((void *)router->address);
- RSA_free(router->pkey);
+ crypto_free_pk_env(router->pkey);
free((void *)router);
fclose(rf);
delete_routerlist(routerlist);
@@ -316,13 +315,13 @@
{
log(LOG_DEBUG,"getrouters(): This entry is actually me. Ignoring.");
free((void *)router->address);
- RSA_free(router->pkey);
+ crypto_free_pk_env(router->pkey);
free((void *)router);
}
else /* router_is_me() returned an error */
{
free((void *)router->address);
- RSA_free(router->pkey);
+ crypto_free_pk_env(router->pkey);
free((void *)router);
fclose(rf);
delete_routerlist(routerlist);
Index: test_onion.c
===================================================================
RCS file: /home/or/cvsroot/src/or/test_onion.c,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -d -r1.1 -r1.2
--- test_onion.c 19 Jul 2002 14:08:44 -0000 1.1
+++ test_onion.c 22 Aug 2002 07:30:03 -0000 1.2
@@ -13,30 +13,27 @@
unsigned char onion_pass6[268];
/* RSA keys for the six layers */
- RSA *key1 = NULL;
- RSA *key2 = NULL;
- RSA *key3 = NULL;
- RSA *key4 = NULL;
- RSA *key5 = NULL;
- RSA *key6 = NULL;
+ crypto_pk_env_t *key1 = crypto_new_pk_env(CRYPTO_PK_RSA);
+ crypto_pk_env_t *key2 = crypto_new_pk_env(CRYPTO_PK_RSA);
+ crypto_pk_env_t *key3 = crypto_new_pk_env(CRYPTO_PK_RSA);
+ crypto_pk_env_t *key4 = crypto_new_pk_env(CRYPTO_PK_RSA);
+ crypto_pk_env_t *key5 = crypto_new_pk_env(CRYPTO_PK_RSA);
+ crypto_pk_env_t *key6 = crypto_new_pk_env(CRYPTO_PK_RSA);
+
/* END VARIABLES */
- ERR_load_crypto_strings();
+ crypto_global_init();
printf("onion.c test suite ...\n");
printf("\nGenerating 6 RSA keys ...\n");
- key1 = RSA_generate_key(1024,65535, NULL, NULL);
- key2 = RSA_generate_key(1024,65535, NULL, NULL);
- key3 = RSA_generate_key(1024,65535, NULL, NULL);
- key4 = RSA_generate_key(1024,65535, NULL, NULL);
- key5 = RSA_generate_key(1024,65535, NULL, NULL);
- key6 = RSA_generate_key(1024,65535, NULL, NULL);
+ crypto_pk_generate_key(key1);
+ crypto_pk_generate_key(key2);
+ crypto_pk_generate_key(key3);
+ crypto_pk_generate_key(key4);
+ crypto_pk_generate_key(key5);
+ crypto_pk_generate_key(key6);
- if (!key1 || !key2 || !key3 || !key4 || !key5 || !key6) {
- printf("\nFailed!\n\n");
- exit(1);
- }
printf("\ndone.\n");
printf("\nGenerating onion ...\n");
@@ -175,6 +172,6 @@
exit(1);
}
printf("\nTEST PASSED.\n");
- ERR_free_strings();
+ crypto_global_cleanup();
return 0;
}