summaryrefslogtreecommitdiff
path: root/src/common/tortls.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-03-31 10:04:10 -0400
committerNick Mathewson <nickm@torproject.org>2017-03-31 10:04:45 -0400
commit28f9b68e8763b2e5c4e7b0ed9170f41ead15feb1 (patch)
tree45f7e0a5799cfaaeb84ebf7d5788d5d34edb0b4c /src/common/tortls.c
parent5ca0d6daf077a17d8b82f5749e12d624ceebe5cb (diff)
downloadtor-28f9b68e8763b2e5c4e7b0ed9170f41ead15feb1.tar.gz
tor-28f9b68e8763b2e5c4e7b0ed9170f41ead15feb1.zip
Move "change cert expiration and re-sign" fn into tortls.c
This lets test_link_handshake stop including openssl headers.
Diffstat (limited to 'src/common/tortls.c')
-rw-r--r--src/common/tortls.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/common/tortls.c b/src/common/tortls.c
index aa1914068a..fadf52fa0a 100644
--- a/src/common/tortls.c
+++ b/src/common/tortls.c
@@ -2264,6 +2264,24 @@ check_cert_lifetime_internal(int severity, const X509 *cert,
return 0;
}
+#ifdef TOR_UNIT_TESTS
+/* Testing only: return a new x509 cert with the same contents as <b>inp</b>,
+ but with the expiration time <b>new_expiration_time</b>, signed with
+ <b>signing_key</b>. */
+STATIC tor_x509_cert_t *
+tor_x509_cert_replace_expiration(const tor_x509_cert_t *inp,
+ time_t new_expiration_time,
+ crypto_pk_t *signing_key)
+{
+ X509 *newc = X509_dup(inp->cert);
+ X509_time_adj(X509_get_notAfter(newc), 0, &new_expiration_time);
+ EVP_PKEY *pk = crypto_pk_get_evp_pkey_(signing_key, 1);
+ tor_assert(X509_sign(newc, pk, EVP_sha256()));
+ EVP_PKEY_free(pk);
+ return tor_x509_cert_new(newc);
+}
+#endif
+
/** Return the number of bytes available for reading from <b>tls</b>.
*/
int