From e526fb6a523fedc203084eaf45f4f983662cfffd Mon Sep 17 00:00:00 2001 From: Ben Toews Date: Fri, 9 Jun 2017 08:52:56 -0600 Subject: [PATCH] use copies of pointers for d2i functions, since they update the ptr argument --- SelfSignedCertificate/SelfSignedCertificate.m | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/SelfSignedCertificate/SelfSignedCertificate.m b/SelfSignedCertificate/SelfSignedCertificate.m index 5108770..275f45d 100644 --- a/SelfSignedCertificate/SelfSignedCertificate.m +++ b/SelfSignedCertificate/SelfSignedCertificate.m @@ -9,6 +9,10 @@ #import "private.h" #import "public.h" +// Yes, this is the private key from our cert. Yes, this sucks. +// But, U2F requires that the cert/key be shared between "devices" +// to prevent user-tracking. Fortunately, "theft" of this key doesn't +// get you anything... const unsigned char *priv = (unsigned char*) "\x30\x77\x02\x01\x01\x04\x20\x03\x84\x2a\xc7\xf4\xcd\xe3\x67\xde" "\xa0\x56\xc6\x4f\x7f\x3b\x15\xea\x7d\x4b\xc4\x83\xca\xc6\x97\x9f" @@ -48,8 +52,9 @@ + (NSData *)toDer { int len; unsigned char *buf; X509 *x509; + const unsigned char *crt_cpy = cert; - x509 = d2i_X509(NULL, &cert, cert_len); + x509 = d2i_X509(NULL, &crt_cpy, cert_len); if (x509 == NULL) { printf("failed to parse cert\n"); return nil; @@ -75,8 +80,9 @@ + (NSData *)signData:(NSData *)msg { unsigned int len; EC_KEY *ec; EVP_PKEY *pkey; + const unsigned char *priv_cpy = priv; - ec = d2i_ECPrivateKey(NULL, &priv, priv_len); + ec = d2i_ECPrivateKey(NULL, &priv_cpy, priv_len); if (ec == NULL) { printf("error importing private key\n"); return nil; @@ -135,11 +141,11 @@ + (NSData *)signData:(NSData *)msg { + (bool)parseX509:(NSData *)data consumed:(NSInteger *)consumed; { - X509 *crt = NULL; + X509 *crt; const unsigned char *crtStart, *crtEnd; crtStart = crtEnd = [data bytes]; - d2i_X509(&crt, &crtEnd, [data length]); + crt = d2i_X509(NULL, &crtEnd, [data length]); if (crt == NULL) { return false;