6c0504911cfbcd456add3da8af1bd1d05b156e79
[silc.git] / lib / silccrypt / silcpkcs1_i.h
1 /*
2
3   silcpkcs1_i.h
4
5   Author: Pekka Riikonen <priikone@silcnet.org>
6
7   Copyright (C); 2006 Pekka Riikonen
8
9   This program is free software; you can redistribute it and/or modify
10   it under the terms of the GNU General Public License as published by
11   the Free Software Foundation; version 2 of the License.
12
13   This program is distributed in the hope that it will be useful,
14   but WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16   GNU General Public License for more details.
17
18 */
19
20 #ifndef SILCPKCS1_I_H
21 #define SILCPKCS1_I_H
22
23 SilcBool silc_pkcs1_generate_key(SilcUInt32 keylen,
24                                  SilcRng rng,
25                                  void **ret_public_key,
26                                  void **ret_private_key);
27 SilcBool silc_pkcs1_import_public_key(unsigned char *key,
28                                       SilcUInt32 key_len,
29                                       void **ret_public_key);
30 unsigned char *silc_pkcs1_export_public_key(void *public_key,
31                                             SilcUInt32 *ret_len);
32 SilcUInt32 silc_pkcs1_public_key_bitlen(void *public_key);
33 void *silc_pkcs1_public_key_copy(void *public_key);
34 SilcBool silc_pkcs1_public_key_compare(void *key1, void *key2);
35 void silc_pkcs1_public_key_free(void *public_key);
36 SilcBool silc_pkcs1_import_private_key(unsigned char *key,
37                                        SilcUInt32 key_len,
38                                        void **ret_private_key);
39 unsigned char *silc_pkcs1_export_private_key(void *private_key,
40                                              SilcUInt32 *ret_len);
41 SilcUInt32 silc_pkcs1_private_key_bitlen(void *private_key);
42 void silc_pkcs1_private_key_free(void *private_key);
43 SilcBool silc_pkcs1_encrypt(void *public_key,
44                             unsigned char *src,
45                             SilcUInt32 src_len,
46                             unsigned char *dst,
47                             SilcUInt32 dst_size,
48                             SilcUInt32 *ret_dst_len);
49 SilcBool silc_pkcs1_decrypt(void *private_key,
50                             unsigned char *src,
51                             SilcUInt32 src_len,
52                             unsigned char *dst,
53                             SilcUInt32 dst_size,
54                             SilcUInt32 *ret_dst_len);
55 SilcBool silc_pkcs1_sign(void *private_key,
56                          unsigned char *src,
57                          SilcUInt32 src_len,
58                          unsigned char *signature,
59                          SilcUInt32 signature_size,
60                          SilcUInt32 *ret_signature_len,
61                          SilcHash hash);
62 SilcBool silc_pkcs1_verify(void *public_key,
63                            unsigned char *signature,
64                            SilcUInt32 signature_len,
65                            unsigned char *data,
66                            SilcUInt32 data_len,
67                            SilcHash hash);
68 SilcBool silc_pkcs1_sign_no_oid(void *private_key,
69                                 unsigned char *src,
70                                 SilcUInt32 src_len,
71                                 unsigned char *signature,
72                                 SilcUInt32 signature_size,
73                                 SilcUInt32 *ret_signature_len,
74                                 SilcHash hash);
75 SilcBool silc_pkcs1_verify_no_oid(void *public_key,
76                                   unsigned char *signature,
77                                   SilcUInt32 signature_len,
78                                   unsigned char *data,
79                                   SilcUInt32 data_len,
80                                   SilcHash hash);
81
82 #endif /* SILCPKCS1_I_H */