/src/openssl/crypto/x509/x509_d2.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* |
2 | | * Copyright 1995-2024 The OpenSSL Project Authors. All Rights Reserved. |
3 | | * |
4 | | * Licensed under the Apache License 2.0 (the "License"). You may not use |
5 | | * this file except in compliance with the License. You can obtain a copy |
6 | | * in the file LICENSE in the source distribution or at |
7 | | * https://www.openssl.org/source/license.html |
8 | | */ |
9 | | |
10 | | #include <stdio.h> |
11 | | #include "internal/cryptlib.h" |
12 | | #include <openssl/crypto.h> |
13 | | #include <openssl/x509.h> |
14 | | |
15 | | int X509_STORE_set_default_paths_ex(X509_STORE *ctx, OSSL_LIB_CTX *libctx, |
16 | | const char *propq) |
17 | 0 | { |
18 | 0 | X509_LOOKUP *lookup; |
19 | |
|
20 | 0 | lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_file()); |
21 | 0 | if (lookup == NULL) |
22 | 0 | return 0; |
23 | 0 | X509_LOOKUP_load_file_ex(lookup, NULL, X509_FILETYPE_DEFAULT, libctx, propq); |
24 | |
|
25 | 0 | lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_hash_dir()); |
26 | 0 | if (lookup == NULL) |
27 | 0 | return 0; |
28 | 0 | X509_LOOKUP_add_dir(lookup, NULL, X509_FILETYPE_DEFAULT); |
29 | |
|
30 | 0 | lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_store()); |
31 | 0 | if (lookup == NULL) |
32 | 0 | return 0; |
33 | | /* |
34 | | * The NULL URI argument will activate any default URIs (presently none), |
35 | | * DO NOT pass the default CApath or CAfile, they're already handled above, |
36 | | * likely much more efficiently. |
37 | | */ |
38 | 0 | X509_LOOKUP_add_store_ex(lookup, NULL, libctx, propq); |
39 | | |
40 | | /* clear any errors */ |
41 | 0 | ERR_clear_error(); |
42 | |
|
43 | 0 | return 1; |
44 | 0 | } |
45 | | int X509_STORE_set_default_paths(X509_STORE *ctx) |
46 | 0 | { |
47 | 0 | return X509_STORE_set_default_paths_ex(ctx, NULL, NULL); |
48 | 0 | } |
49 | | |
50 | | int X509_STORE_load_file_ex(X509_STORE *ctx, const char *file, |
51 | | OSSL_LIB_CTX *libctx, const char *propq) |
52 | 0 | { |
53 | 0 | X509_LOOKUP *lookup; |
54 | |
|
55 | 0 | if (file == NULL |
56 | 0 | || (lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_file())) == NULL |
57 | 0 | || X509_LOOKUP_load_file_ex(lookup, file, X509_FILETYPE_PEM, libctx, |
58 | 0 | propq) <= 0) |
59 | 0 | return 0; |
60 | | |
61 | 0 | return 1; |
62 | 0 | } |
63 | | |
64 | | int X509_STORE_load_file(X509_STORE *ctx, const char *file) |
65 | 0 | { |
66 | 0 | return X509_STORE_load_file_ex(ctx, file, NULL, NULL); |
67 | 0 | } |
68 | | |
69 | | int X509_STORE_load_path(X509_STORE *ctx, const char *path) |
70 | 0 | { |
71 | 0 | X509_LOOKUP *lookup; |
72 | |
|
73 | 0 | if (path == NULL |
74 | 0 | || (lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_hash_dir())) == NULL |
75 | 0 | || X509_LOOKUP_add_dir(lookup, path, X509_FILETYPE_PEM) <= 0) |
76 | 0 | return 0; |
77 | | |
78 | 0 | return 1; |
79 | 0 | } |
80 | | |
81 | | int X509_STORE_load_store_ex(X509_STORE *ctx, const char *uri, |
82 | | OSSL_LIB_CTX *libctx, const char *propq) |
83 | 0 | { |
84 | 0 | X509_LOOKUP *lookup; |
85 | |
|
86 | 0 | if (uri == NULL |
87 | 0 | || (lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_store())) == NULL |
88 | 0 | || X509_LOOKUP_add_store_ex(lookup, uri, libctx, propq) == 0) |
89 | 0 | return 0; |
90 | | |
91 | 0 | return 1; |
92 | 0 | } |
93 | | |
94 | | int X509_STORE_load_store(X509_STORE *ctx, const char *uri) |
95 | 0 | { |
96 | 0 | return X509_STORE_load_store_ex(ctx, uri, NULL, NULL); |
97 | 0 | } |
98 | | |
99 | | int X509_STORE_load_locations_ex(X509_STORE *ctx, const char *file, |
100 | | const char *path, OSSL_LIB_CTX *libctx, |
101 | | const char *propq) |
102 | 0 | { |
103 | 0 | if (file == NULL && path == NULL) |
104 | 0 | return 0; |
105 | 0 | if (file != NULL && !X509_STORE_load_file_ex(ctx, file, libctx, propq)) |
106 | 0 | return 0; |
107 | 0 | if (path != NULL && !X509_STORE_load_path(ctx, path)) |
108 | 0 | return 0; |
109 | 0 | return 1; |
110 | 0 | } |
111 | | |
112 | | int X509_STORE_load_locations(X509_STORE *ctx, const char *file, |
113 | | const char *path) |
114 | 0 | { |
115 | 0 | return X509_STORE_load_locations_ex(ctx, file, path, NULL, NULL); |
116 | 0 | } |