VirtualBox

source: vbox/trunk/src/libs/openssl-3.0.3/test/fake_rsaprov.c@ 95218

最後變更 在這個檔案從95218是 94320,由 vboxsync 提交於 3 年 前

libs/openssl-3.0.1: Export to OSE and fix copyright headers in Makefiles, bugref:10128

檔案大小: 6.6 KB
 
1/*
2 * Copyright 2021 The OpenSSL Project Authors. All Rights Reserved.
3 *
4 * Licensed under the Apache License 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 * https://www.openssl.org/source/license.html
8 * or in the file LICENSE in the source distribution.
9 */
10
11#include <string.h>
12#include <openssl/core_names.h>
13#include <openssl/rand.h>
14#include <openssl/provider.h>
15#include "testutil.h"
16#include "fake_rsaprov.h"
17
18static OSSL_FUNC_keymgmt_new_fn fake_rsa_keymgmt_new;
19static OSSL_FUNC_keymgmt_free_fn fake_rsa_keymgmt_free;
20static OSSL_FUNC_keymgmt_has_fn fake_rsa_keymgmt_has;
21static OSSL_FUNC_keymgmt_query_operation_name_fn fake_rsa_keymgmt_query;
22static OSSL_FUNC_keymgmt_import_fn fake_rsa_keymgmt_import;
23static OSSL_FUNC_keymgmt_import_types_fn fake_rsa_keymgmt_imptypes;
24
25static int has_selection;
26static int imptypes_selection;
27static int query_id;
28
29static void *fake_rsa_keymgmt_new(void *provctx)
30{
31 unsigned char *keydata = OPENSSL_zalloc(1);
32
33 TEST_ptr(keydata);
34
35 /* clear test globals */
36 has_selection = 0;
37 imptypes_selection = 0;
38 query_id = 0;
39
40 return keydata;
41}
42
43static void fake_rsa_keymgmt_free(void *keydata)
44{
45 OPENSSL_free(keydata);
46}
47
48static int fake_rsa_keymgmt_has(const void *key, int selection)
49{
50 /* record global for checking */
51 has_selection = selection;
52
53 return 1;
54}
55
56
57static const char *fake_rsa_keymgmt_query(int id)
58{
59 /* record global for checking */
60 query_id = id;
61
62 return "RSA";
63}
64
65static int fake_rsa_keymgmt_import(void *keydata, int selection,
66 const OSSL_PARAM *p)
67{
68 unsigned char *fake_rsa_key = keydata;
69
70 /* key was imported */
71 *fake_rsa_key = 1;
72
73 return 1;
74}
75
76static const OSSL_PARAM fake_rsa_import_key_types[] = {
77 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_N, NULL, 0),
78 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_E, NULL, 0),
79 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_D, NULL, 0),
80 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_FACTOR1, NULL, 0),
81 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_FACTOR2, NULL, 0),
82 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_EXPONENT1, NULL, 0),
83 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_EXPONENT2, NULL, 0),
84 OSSL_PARAM_BN(OSSL_PKEY_PARAM_RSA_COEFFICIENT1, NULL, 0),
85 OSSL_PARAM_END
86};
87
88static const OSSL_PARAM *fake_rsa_keymgmt_imptypes(int selection)
89{
90 /* record global for checking */
91 imptypes_selection = selection;
92
93 return fake_rsa_import_key_types;
94}
95
96static const OSSL_DISPATCH fake_rsa_keymgmt_funcs[] = {
97 { OSSL_FUNC_KEYMGMT_NEW, (void (*)(void))fake_rsa_keymgmt_new },
98 { OSSL_FUNC_KEYMGMT_FREE, (void (*)(void))fake_rsa_keymgmt_free} ,
99 { OSSL_FUNC_KEYMGMT_HAS, (void (*)(void))fake_rsa_keymgmt_has },
100 { OSSL_FUNC_KEYMGMT_QUERY_OPERATION_NAME,
101 (void (*)(void))fake_rsa_keymgmt_query },
102 { OSSL_FUNC_KEYMGMT_IMPORT, (void (*)(void))fake_rsa_keymgmt_import },
103 { OSSL_FUNC_KEYMGMT_IMPORT_TYPES,
104 (void (*)(void))fake_rsa_keymgmt_imptypes },
105 { 0, NULL }
106};
107
108static const OSSL_ALGORITHM fake_rsa_keymgmt_algs[] = {
109 { "RSA:rsaEncryption", "provider=fake-rsa", fake_rsa_keymgmt_funcs, "Fake RSA Key Management" },
110 { NULL, NULL, NULL, NULL }
111};
112
113static OSSL_FUNC_signature_newctx_fn fake_rsa_sig_newctx;
114static OSSL_FUNC_signature_freectx_fn fake_rsa_sig_freectx;
115static OSSL_FUNC_signature_sign_init_fn fake_rsa_sig_sign_init;
116static OSSL_FUNC_signature_sign_fn fake_rsa_sig_sign;
117
118static void *fake_rsa_sig_newctx(void *provctx, const char *propq)
119{
120 unsigned char *sigctx = OPENSSL_zalloc(1);
121
122 TEST_ptr(sigctx);
123
124 return sigctx;
125}
126
127static void fake_rsa_sig_freectx(void *sigctx)
128{
129 OPENSSL_free(sigctx);
130}
131
132static int fake_rsa_sig_sign_init(void *ctx, void *provkey,
133 const OSSL_PARAM params[])
134{
135 unsigned char *sigctx = ctx;
136 unsigned char *keydata = provkey;
137
138 /* we must have a ctx */
139 if (!TEST_ptr(sigctx))
140 return 0;
141
142 /* we must have some initialized key */
143 if (!TEST_ptr(keydata) || !TEST_int_gt(keydata[0], 0))
144 return 0;
145
146 /* record that sign init was called */
147 *sigctx = 1;
148 return 1;
149}
150
151static int fake_rsa_sig_sign(void *ctx, unsigned char *sig,
152 size_t *siglen, size_t sigsize,
153 const unsigned char *tbs, size_t tbslen)
154{
155 unsigned char *sigctx = ctx;
156
157 /* we must have a ctx and init was called upon it */
158 if (!TEST_ptr(sigctx) || !TEST_int_eq(*sigctx, 1))
159 return 0;
160
161 *siglen = 256;
162 /* record that the real sign operation was called */
163 if (sig != NULL) {
164 if (!TEST_int_ge(sigsize, *siglen))
165 return 0;
166 *sigctx = 2;
167 /* produce a fake signature */
168 memset(sig, 'a', *siglen);
169 }
170
171 return 1;
172}
173
174static const OSSL_DISPATCH fake_rsa_sig_funcs[] = {
175 { OSSL_FUNC_SIGNATURE_NEWCTX, (void (*)(void))fake_rsa_sig_newctx },
176 { OSSL_FUNC_SIGNATURE_FREECTX, (void (*)(void))fake_rsa_sig_freectx },
177 { OSSL_FUNC_SIGNATURE_SIGN_INIT, (void (*)(void))fake_rsa_sig_sign_init },
178 { OSSL_FUNC_SIGNATURE_SIGN, (void (*)(void))fake_rsa_sig_sign },
179 { 0, NULL }
180};
181
182static const OSSL_ALGORITHM fake_rsa_sig_algs[] = {
183 { "RSA:rsaEncryption", "provider=fake-rsa", fake_rsa_sig_funcs, "Fake RSA Signature" },
184 { NULL, NULL, NULL, NULL }
185};
186
187static const OSSL_ALGORITHM *fake_rsa_query(void *provctx,
188 int operation_id,
189 int *no_cache)
190{
191 *no_cache = 0;
192 switch (operation_id) {
193 case OSSL_OP_SIGNATURE:
194 return fake_rsa_sig_algs;
195
196 case OSSL_OP_KEYMGMT:
197 return fake_rsa_keymgmt_algs;
198 }
199 return NULL;
200}
201
202/* Functions we provide to the core */
203static const OSSL_DISPATCH fake_rsa_method[] = {
204 { OSSL_FUNC_PROVIDER_TEARDOWN, (void (*)(void))OSSL_LIB_CTX_free },
205 { OSSL_FUNC_PROVIDER_QUERY_OPERATION, (void (*)(void))fake_rsa_query },
206 { 0, NULL }
207};
208
209static int fake_rsa_provider_init(const OSSL_CORE_HANDLE *handle,
210 const OSSL_DISPATCH *in,
211 const OSSL_DISPATCH **out, void **provctx)
212{
213 if (!TEST_ptr(*provctx = OSSL_LIB_CTX_new()))
214 return 0;
215 *out = fake_rsa_method;
216 return 1;
217}
218
219OSSL_PROVIDER *fake_rsa_start(OSSL_LIB_CTX *libctx)
220{
221 OSSL_PROVIDER *p;
222
223 if (!TEST_true(OSSL_PROVIDER_add_builtin(libctx, "fake-rsa",
224 fake_rsa_provider_init))
225 || !TEST_ptr(p = OSSL_PROVIDER_try_load(libctx, "fake-rsa", 1)))
226 return NULL;
227
228 return p;
229}
230
231void fake_rsa_finish(OSSL_PROVIDER *p)
232{
233 OSSL_PROVIDER_unload(p);
234}
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette