/src/openssl35/crypto/x509/x509_d2.c
Line | Count | Source |
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) |
59 | 0 | <= 0) |
60 | 0 | return 0; |
61 | | |
62 | 0 | return 1; |
63 | 0 | } |
64 | | |
65 | | int X509_STORE_load_file(X509_STORE *ctx, const char *file) |
66 | 0 | { |
67 | 0 | return X509_STORE_load_file_ex(ctx, file, NULL, NULL); |
68 | 0 | } |
69 | | |
70 | | int X509_STORE_load_path(X509_STORE *ctx, const char *path) |
71 | 0 | { |
72 | 0 | X509_LOOKUP *lookup; |
73 | |
|
74 | 0 | if (path == NULL |
75 | 0 | || (lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_hash_dir())) == NULL |
76 | 0 | || X509_LOOKUP_add_dir(lookup, path, X509_FILETYPE_PEM) <= 0) |
77 | 0 | return 0; |
78 | | |
79 | 0 | return 1; |
80 | 0 | } |
81 | | |
82 | | int X509_STORE_load_store_ex(X509_STORE *ctx, const char *uri, |
83 | | OSSL_LIB_CTX *libctx, const char *propq) |
84 | 0 | { |
85 | 0 | X509_LOOKUP *lookup; |
86 | |
|
87 | 0 | if (uri == NULL |
88 | 0 | || (lookup = X509_STORE_add_lookup(ctx, X509_LOOKUP_store())) == NULL |
89 | 0 | || X509_LOOKUP_add_store_ex(lookup, uri, libctx, propq) == 0) |
90 | 0 | return 0; |
91 | | |
92 | 0 | return 1; |
93 | 0 | } |
94 | | |
95 | | int X509_STORE_load_store(X509_STORE *ctx, const char *uri) |
96 | 0 | { |
97 | 0 | return X509_STORE_load_store_ex(ctx, uri, NULL, NULL); |
98 | 0 | } |
99 | | |
100 | | int X509_STORE_load_locations_ex(X509_STORE *ctx, const char *file, |
101 | | const char *path, OSSL_LIB_CTX *libctx, |
102 | | const char *propq) |
103 | 0 | { |
104 | 0 | if (file == NULL && path == NULL) |
105 | 0 | return 0; |
106 | 0 | if (file != NULL && !X509_STORE_load_file_ex(ctx, file, libctx, propq)) |
107 | 0 | return 0; |
108 | 0 | if (path != NULL && !X509_STORE_load_path(ctx, path)) |
109 | 0 | return 0; |
110 | 0 | return 1; |
111 | 0 | } |
112 | | |
113 | | int X509_STORE_load_locations(X509_STORE *ctx, const char *file, |
114 | | const char *path) |
115 | 0 | { |
116 | 0 | return X509_STORE_load_locations_ex(ctx, file, path, NULL, NULL); |
117 | 0 | } |