break;
case X509_OUTPUT_PEM:
- if (fprintf(ofstream,pem_prolog)<0) {
+ if (fprintf(ofstream, "%s", pem_prolog)<0) {
is_err = -1;
break;
}
fprintf(ofstream,"%.64s\n",&base_buf[i]);
}
- if (fprintf(ofstream, pem_epilog)<0) {
+ if (fprintf(ofstream, "%s", pem_epilog)<0) {
is_err = -1;
break;
}
(unsigned char*)"", 0);
}
+/*
+ * Create a random serial
+ */
+static int get_random_serial(void)
+{
+ int random = 0;
+ FILE *fd;
+
+ fd = fopen("/dev/urandom", "r");
+
+ if (fd) {
+ if (fread(&random, 1, sizeof(random), fd) != sizeof(random))
+ random = 0;
+
+ fclose(fd);
+ }
+
+ return random;
+}
+
/*
* Create a self signed certificate
*/
/*
* CertificateSerialNumber ::= INTEGER
*/
- srand((unsigned int) time(NULL));
- serial = rand();
+ serial = get_random_serial();
+
+ if (serial == 0)
+ return 1;
+
if ((ret = asn1_add_int(serial, &chain->serial)) != 0)
return ret;