aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/openssl/apps/app_rand.c
blob: 13925b2f23132ae226f24cf8b3d0271a2bb11954 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/* 
 * Copyright 1995-2018 The OpenSSL Project Authors. All Rights Reserved. 
 * 
 * Licensed under the OpenSSL license (the "License").  You may not use 
 * this file except in compliance with the License.  You can obtain a copy 
 * in the file LICENSE in the source distribution or at 
 * https://www.openssl.org/source/license.html 
 */ 
 
#include "apps.h" 
#include <openssl/bio.h> 
#include <openssl/err.h> 
#include <openssl/rand.h> 
#include <openssl/conf.h> 
 
static char *save_rand_file; 
 
void app_RAND_load_conf(CONF *c, const char *section) 
{ 
    const char *randfile = NCONF_get_string(c, section, "RANDFILE"); 
 
    if (randfile == NULL) { 
        ERR_clear_error(); 
        return; 
    } 
    if (RAND_load_file(randfile, -1) < 0) { 
        BIO_printf(bio_err, "Can't load %s into RNG\n", randfile); 
        ERR_print_errors(bio_err); 
    } 
    if (save_rand_file == NULL) 
        save_rand_file = OPENSSL_strdup(randfile); 
} 
 
static int loadfiles(char *name) 
{ 
    char *p; 
    int last, ret = 1; 
 
    for ( ; ; ) { 
        last = 0; 
        for (p = name; *p != '\0' && *p != LIST_SEPARATOR_CHAR; p++) 
            continue; 
        if (*p == '\0') 
            last = 1; 
        *p = '\0'; 
        if (RAND_load_file(name, -1) < 0) { 
            BIO_printf(bio_err, "Can't load %s into RNG\n", name); 
            ERR_print_errors(bio_err); 
            ret = 0; 
        } 
        if (last) 
            break; 
        name = p + 1; 
        if (*name == '\0') 
            break; 
    } 
    return ret; 
} 
 
void app_RAND_write(void) 
{ 
    if (save_rand_file == NULL) 
        return; 
    if (RAND_write_file(save_rand_file) == -1) { 
        BIO_printf(bio_err, "Cannot write random bytes:\n"); 
        ERR_print_errors(bio_err); 
    } 
    OPENSSL_free(save_rand_file); 
    save_rand_file =  NULL; 
} 
 
 
/* 
 * See comments in opt_verify for explanation of this. 
 */ 
enum r_range { OPT_R_ENUM }; 
 
int opt_rand(int opt) 
{ 
    switch ((enum r_range)opt) { 
    case OPT_R__FIRST: 
    case OPT_R__LAST: 
        break; 
    case OPT_R_RAND: 
        return loadfiles(opt_arg()); 
        break; 
    case OPT_R_WRITERAND: 
        OPENSSL_free(save_rand_file); 
        save_rand_file = OPENSSL_strdup(opt_arg()); 
        break; 
    } 
    return 1; 
}