summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/rsa
diff options
context:
space:
mode:
authortb <>2018-03-17 15:12:56 +0000
committertb <>2018-03-17 15:12:56 +0000
commit47bd2696f108ed72a37c309a2c1d049aeee2c89d (patch)
tree693ceaf9bf1ee171f1dc646660b23e8e873a78ce /src/lib/libcrypto/rsa
parent65699f19109f051e620133371f72270f87b16337 (diff)
downloadopenbsd-47bd2696f108ed72a37c309a2c1d049aeee2c89d.tar.gz
openbsd-47bd2696f108ed72a37c309a2c1d049aeee2c89d.tar.bz2
openbsd-47bd2696f108ed72a37c309a2c1d049aeee2c89d.zip
Provide RSA_meth_{dup,free,new,set_{finish,priv_{dec,enc}}}()
Note that these functions return NULL in out-of-memory situations, but contrary to OpenSSL's versions they do not set an error. ok jsing
Diffstat (limited to 'src/lib/libcrypto/rsa')
-rw-r--r--src/lib/libcrypto/rsa/rsa.h11
-rw-r--r--src/lib/libcrypto/rsa/rsa_meth.c86
2 files changed, 96 insertions, 1 deletions
diff --git a/src/lib/libcrypto/rsa/rsa.h b/src/lib/libcrypto/rsa/rsa.h
index 65a643f4c6..23929aafb9 100644
--- a/src/lib/libcrypto/rsa/rsa.h
+++ b/src/lib/libcrypto/rsa/rsa.h
@@ -1,4 +1,4 @@
1/* $OpenBSD: rsa.h,v 1.37 2018/02/20 17:42:32 tb Exp $ */ 1/* $OpenBSD: rsa.h,v 1.38 2018/03/17 15:12:56 tb Exp $ */
2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) 2/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
@@ -430,6 +430,15 @@ RSA *RSAPrivateKey_dup(RSA *rsa);
430 */ 430 */
431#define RSA_FLAG_CHECKED 0x0800 431#define RSA_FLAG_CHECKED 0x0800
432 432
433RSA_METHOD *RSA_meth_new(const char *name, int flags);
434void RSA_meth_free(RSA_METHOD *meth);
435RSA_METHOD *RSA_meth_dup(const RSA_METHOD *meth);
436int RSA_meth_set_priv_enc(RSA_METHOD *meth, int (*priv_enc)(int flen,
437 const unsigned char *from, unsigned char *to, RSA *rsa, int padding));
438int RSA_meth_set_priv_dec(RSA_METHOD *meth, int (*priv_dec)(int flen,
439 const unsigned char *from, unsigned char *to, RSA *rsa, int padding));
440int RSA_meth_set_finish(RSA_METHOD *meth, int (*finish)(RSA *rsa));
441
433/* BEGIN ERROR CODES */ 442/* BEGIN ERROR CODES */
434/* The following lines are auto generated by the script mkerr.pl. Any changes 443/* The following lines are auto generated by the script mkerr.pl. Any changes
435 * made after this point may be overwritten when the script is next run. 444 * made after this point may be overwritten when the script is next run.
diff --git a/src/lib/libcrypto/rsa/rsa_meth.c b/src/lib/libcrypto/rsa/rsa_meth.c
new file mode 100644
index 0000000000..0e52799a38
--- /dev/null
+++ b/src/lib/libcrypto/rsa/rsa_meth.c
@@ -0,0 +1,86 @@
1/* $OpenBSD: rsa_meth.c,v 1.1 2018/03/17 15:12:56 tb Exp $ */
2/*
3 * Copyright (c) 2018 Theo Buehler <tb@openbsd.org>
4 *
5 * Permission to use, copy, modify, and distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18#include <stdlib.h>
19#include <string.h>
20
21#include <openssl/err.h>
22#include <openssl/rsa.h>
23
24RSA_METHOD *
25RSA_meth_new(const char *name, int flags)
26{
27 RSA_METHOD *meth;
28
29 if ((meth = calloc(1, sizeof(*meth))) == NULL)
30 return NULL;
31 if ((meth->name = strdup(name)) == NULL) {
32 free(meth);
33 return NULL;
34 }
35 meth->flags = flags;
36
37 return meth;
38}
39
40void
41RSA_meth_free(RSA_METHOD *meth)
42{
43 if (meth != NULL) {
44 free((char *)meth->name);
45 free(meth);
46 }
47}
48
49RSA_METHOD *
50RSA_meth_dup(const RSA_METHOD *meth)
51{
52 RSA_METHOD *copy;
53
54 if ((copy = calloc(1, sizeof(*copy))) == NULL)
55 return NULL;
56 memcpy(copy, meth, sizeof(*copy));
57 if ((copy->name = strdup(meth->name)) == NULL) {
58 free(copy);
59 return NULL;
60 }
61
62 return copy;
63}
64
65int
66RSA_meth_set_priv_enc(RSA_METHOD *meth, int (*priv_enc)(int flen,
67 const unsigned char *from, unsigned char *to, RSA *rsa, int padding))
68{
69 meth->rsa_priv_enc = priv_enc;
70 return 1;
71}
72
73int
74RSA_meth_set_priv_dec(RSA_METHOD *meth, int (*priv_dec)(int flen,
75 const unsigned char *from, unsigned char *to, RSA *rsa, int padding))
76{
77 meth->rsa_priv_dec = priv_dec;
78 return 1;
79}
80
81int
82RSA_meth_set_finish(RSA_METHOD *meth, int (*finish)(RSA *rsa))
83{
84 meth->finish = finish;
85 return 1;
86}