Rewind the file before trying to use PEM_read_RSA_PUBKEY().
authorGuus Sliepen <guus@tinc-vpn.org>
Wed, 26 Feb 2014 16:27:57 +0000 (17:27 +0100)
committerGuus Sliepen <guus@tinc-vpn.org>
Wed, 26 Feb 2014 16:27:57 +0000 (17:27 +0100)
src/openssl/rsa.c

index 20bfb65a072b2926e26a1e21191c32dcd3c0aa2b..9c1f4984ba1f4fbbddf0715643ea37a4a10fa7f4 100644 (file)
@@ -61,8 +61,10 @@ rsa_t *rsa_set_hex_private_key(char *n, char *e, char *d) {
 rsa_t *rsa_read_pem_public_key(FILE *fp) {
        rsa_t *rsa = PEM_read_RSAPublicKey(fp, NULL, NULL, NULL);
 
-       if(!rsa)
+       if(!rsa) {
+               rewind(fp);
                rsa = PEM_read_RSA_PUBKEY(fp, NULL, NULL, NULL);
+       }
 
        if(!rsa)
                logger(DEBUG_ALWAYS, LOG_ERR, "Unable to read RSA public key: %s", ERR_error_string(ERR_get_error(), NULL));