summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2003-11-18 06:52:25 +0000
committerNick Mathewson <nickm@torproject.org>2003-11-18 06:52:25 +0000
commitdd16a9abcb6820c1a495d0efa2bc4e5a5264f8f2 (patch)
treec24cd05b79d17e52efe440797f1ffee684782e2b /src/common
parent366ba4a7c788c80e3a5ddc3df62066a61abffa82 (diff)
downloadtor-dd16a9abcb6820c1a495d0efa2bc4e5a5264f8f2.tar.gz
tor-dd16a9abcb6820c1a495d0efa2bc4e5a5264f8f2.zip
Stop leaking X509 certs; those things are _nasty_ on the carpet
svn:r833
Diffstat (limited to 'src/common')
-rw-r--r--src/common/tortls.c25
1 files changed, 15 insertions, 10 deletions
diff --git a/src/common/tortls.c b/src/common/tortls.c
index 883d99410c..aab22b88ec 100644
--- a/src/common/tortls.c
+++ b/src/common/tortls.c
@@ -140,7 +140,6 @@ tor_tls_create_certificate(crypto_pk_env_t *rsa,
X509 *x509 = NULL;
X509_NAME *name = NULL;
int nid;
- int err;
tor_tls_init();
@@ -179,13 +178,13 @@ tor_tls_create_certificate(crypto_pk_env_t *rsa,
if (!X509_sign(x509, pkey, EVP_sha1()))
goto error;
- err = 0;
goto done;
error:
- err = 1;
+ if (x509) {
+ X509_free(x509);
+ x509 = NULL;
+ }
done:
- if (x509 && err)
- X509_free(x509);
if (pkey)
EVP_PKEY_free(pkey);
if (name)
@@ -483,23 +482,29 @@ tor_tls_get_peer_cert_nickname(tor_tls *tls, char *buf, int buflen)
if (!(cert = SSL_get_peer_certificate(tls->ssl))) {
log_fn(LOG_WARN, "Peer has no certificate");
- return -1;
+ goto error;
}
if (!(name = X509_get_subject_name(cert))) {
log_fn(LOG_WARN, "Peer certificate has no subject name");
- return -1;
+ goto error;
}
if ((nid = OBJ_txt2nid("commonName")) == NID_undef)
- return -1;
+ goto error;
lenout = X509_NAME_get_text_by_NID(name, nid, buf, buflen);
if (lenout == -1)
- return -1;
+ goto error;
if (strspn(buf, LEGAL_NICKNAME_CHARACTERS) != lenout) {
log_fn(LOG_WARN, "Peer certificate nickname has illegal characters.");
- return -1;
+ goto error;
}
return 0;
+ error:
+ if (cert)
+ X509_free(cert);
+ if (name)
+ X509_NAME_free(name);
+ return -1;
}
/* If the provided tls connection is authenticated and has a