projects
/
tinc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add cleanup hook for integration tests
[tinc]
/
src
/
openssl
/
rsagen.c
diff --git
a/src/openssl/rsagen.c
b/src/openssl/rsagen.c
index
4a47619
..
79127f6
100644
(file)
--- a/
src/openssl/rsagen.c
+++ b/
src/openssl/rsagen.c
@@
-22,45
+22,49
@@
#include <openssl/pem.h>
#include <openssl/err.h>
#include <openssl/pem.h>
#include <openssl/err.h>
-#define
__TINC_RSA_INTERNAL__
+#define
TINC_RSA_INTERNAL
typedef RSA rsa_t;
#include "../logger.h"
#include "../rsagen.h"
typedef RSA rsa_t;
#include "../logger.h"
#include "../rsagen.h"
+#include "../xalloc.h"
/* This function prettyprints the key generation process */
static int indicator(int a, int b, BN_GENCB *cb) {
/* This function prettyprints the key generation process */
static int indicator(int a, int b, BN_GENCB *cb) {
- switch (a) {
- case 0:
- fprintf(stderr, ".");
- break;
+ (void)cb;
- case 1:
- fprintf(stderr, "+");
- break;
+ switch(a) {
+ case 0:
+ fprintf(stderr, ".");
+ break;
-
case 2
:
-
fprintf(stderr, "-
");
-
break;
+
case 1
:
+
fprintf(stderr, "+
");
+ break;
- case 3:
- switch (b) {
- case 0:
- fprintf(stderr, " p\n");
- break;
+ case 2:
+ fprintf(stderr, "-");
+ break;
- case 1:
- fprintf(stderr, " q\n");
- break;
+ case 3:
+ switch(b) {
+ case 0:
+ fprintf(stderr, " p\n");
+ break;
- default:
- fprintf(stderr, "?");
- }
+ case 1:
+ fprintf(stderr, " q\n");
break;
default:
fprintf(stderr, "?");
break;
default:
fprintf(stderr, "?");
+ }
+
+ break;
+
+ default:
+ fprintf(stderr, "?");
}
return 1;
}
return 1;
@@
-83,17
+87,24
@@
rsa_t *rsa_generate(size_t bits, unsigned long exponent) {
rsa_t *rsa = RSA_new();
BN_GENCB *cb = BN_GENCB_new();
rsa_t *rsa = RSA_new();
BN_GENCB *cb = BN_GENCB_new();
- if(!bn_e || !rsa || !cb)
+ if(!bn_e || !rsa || !cb)
{
abort();
abort();
+ }
BN_set_word(bn_e, exponent);
BN_GENCB_set(cb, indicator, NULL);
BN_set_word(bn_e, exponent);
BN_GENCB_set(cb, indicator, NULL);
- RSA_generate_key_ex(rsa, bits, bn_e, cb);
+
int result =
RSA_generate_key_ex(rsa, bits, bn_e, cb);
BN_GENCB_free(cb);
BN_free(bn_e);
BN_GENCB_free(cb);
BN_free(bn_e);
+ if(!result) {
+ fprintf(stderr, "Error during key generation!\n");
+ RSA_free(rsa);
+ return NULL;
+ }
+
return rsa;
}
return rsa;
}