File: OpenSSLCryptoKeyRSA_8hpp-source.html

package info (click to toggle)
xml-security-c 1.2.1-3
  • links: PTS
  • area: main
  • in suites: etch-m68k
  • size: 24,464 kB
  • ctags: 6,673
  • sloc: cpp: 36,830; xml: 23,415; sh: 2,365; makefile: 340; perl: 221
file content (121 lines) | stat: -rw-r--r-- 10,821 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>XML-Security-C: OpenSSLCryptoKeyRSA.hpp Source File</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.4.2 -->
<div class="qindex"><a class="qindex" href="index.html">Main&nbsp;Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="hierarchy.html">Class&nbsp;Hierarchy</a> | <a class="qindex" href="annotated.html">Class&nbsp;List</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="functions.html">Class&nbsp;Members</a> | <a class="qindex" href="globals.html">File&nbsp;Members</a> | <a class="qindex" href="pages.html">Related&nbsp;Pages</a></div>
<div class="nav">
<a class="el" href="dir_000000.html">src</a>&nbsp;/&nbsp;<a class="el" href="dir_000002.html">enc</a>&nbsp;/&nbsp;<a class="el" href="dir_000003.html">OpenSSL</a></div>
<h1>OpenSSLCryptoKeyRSA.hpp</h1><a href="OpenSSLCryptoKeyRSA_8hpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment">00001 <span class="comment">/*</span>
00002 <span class="comment"> * Copyright 2002-2005 The Apache Software Foundation.</span>
00003 <span class="comment"> *</span>
00004 <span class="comment"> * Licensed under the Apache License, Version 2.0 (the "License");</span>
00005 <span class="comment"> * you may not use this file except in compliance with the License.</span>
00006 <span class="comment"> * You may obtain a copy of the License at</span>
00007 <span class="comment"> *</span>
00008 <span class="comment"> *     http://www.apache.org/licenses/LICENSE-2.0</span>
00009 <span class="comment"> *</span>
00010 <span class="comment"> * Unless required by applicable law or agreed to in writing, software</span>
00011 <span class="comment"> * distributed under the License is distributed on an "AS IS" BASIS,</span>
00012 <span class="comment"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span>
00013 <span class="comment"> * See the License for the specific language governing permissions and</span>
00014 <span class="comment"> * limitations under the License.</span>
00015 <span class="comment"> */</span>
00016 
00017 <span class="comment">/*</span>
00018 <span class="comment"> * XSEC</span>
00019 <span class="comment"> *</span>
00020 <span class="comment"> * XSECCryptoKeyRSA := RSA Keys</span>
00021 <span class="comment"> *</span>
00022 <span class="comment"> * Author(s): Berin Lautenbach</span>
00023 <span class="comment"> *</span>
00024 <span class="comment"> * $Id: OpenSSLCryptoKeyRSA.hpp,v 1.12 2005/06/04 11:30:26 blautenb Exp $</span>
00025 <span class="comment"> *</span>
00026 <span class="comment"> */</span>
00027 
00028 <span class="preprocessor">#ifndef OPENSSLCRYPTOKEYRSA_INCLUDE</span>
00029 <span class="preprocessor"></span><span class="preprocessor">#define OPENSSLCRYPTOKEYRSA_INCLUDE</span>
00030 <span class="preprocessor"></span>
00031 <span class="preprocessor">#include &lt;xsec/enc/XSECCryptoKeyRSA.hpp&gt;</span>
00032 
00033 <span class="preprocessor">#if defined (HAVE_OPENSSL)</span>
00034 <span class="preprocessor"></span><span class="preprocessor">#include &lt;openssl/evp.h&gt;</span>
00035 
<a name="l00046"></a><a class="code" href="classOpenSSLCryptoKeyRSA.html">00046</a> <span class="keyword">class </span><a class="code" href="XSECDefs_8hpp.html#a9">DSIG_EXPORT</a> <a class="code" href="classOpenSSLCryptoKeyRSA.html">OpenSSLCryptoKeyRSA</a> : <span class="keyword">public</span> <a class="code" href="classXSECCryptoKeyRSA.html">XSECCryptoKeyRSA</a> {
00047 
00048 <span class="keyword">public</span> :
00049 
00052     
00053     <a class="code" href="classOpenSSLCryptoKeyRSA.html">OpenSSLCryptoKeyRSA</a>();
00054     <span class="keyword">virtual</span> ~<a class="code" href="classOpenSSLCryptoKeyRSA.html">OpenSSLCryptoKeyRSA</a>();
00055 
00057 
00060 
00068     <span class="keyword">virtual</span> <a class="code" href="classXSECCryptoKey.html#w9">XSECCryptoKey::KeyType</a> <a class="code" href="classXSECCryptoKeyRSA.html#z167_0">getKeyType</a>();
00069 
<a name="l00074"></a><a class="code" href="classOpenSSLCryptoKeyRSA.html#z96_1">00074</a>     <span class="keyword">virtual</span> <span class="keyword">const</span> XMLCh * <a class="code" href="classXSECCryptoKey.html#z158_1">getProviderName</a>() {<span class="keywordflow">return</span> <a class="code" href="classDSIGConstants.html#s41">DSIGConstants::s_unicodeStrPROVOpenSSL</a>;}
00075 
00080     <span class="keyword">virtual</span> <a class="code" href="classXSECCryptoKey.html">XSECCryptoKey</a> * <a class="code" href="classXSECCryptoKeyRSA.html#z167_1">clone</a>();
00081 
00083 
00089 
00103     <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_0">setOAEPparams</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * params, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> paramsLen);
00104 
00111     <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_1">getOAEPparamsLen</a>(<span class="keywordtype">void</span>);
00112 
00120     <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * <a class="code" href="classXSECCryptoKeyRSA.html#z168_2">getOAEPparams</a>(<span class="keywordtype">void</span>);
00121 
00135     <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_3">verifySHA1PKCS1Base64Signature</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * hashBuf, 
00136                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> hashLen,
00137                                  <span class="keyword">const</span> <span class="keywordtype">char</span> * base64Signature,
00138                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> sigLen);
00139 
00156     <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_4">signSHA1PKCS1Base64Signature</a>(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * hashBuf,
00157         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> hashLen,
00158         <span class="keywordtype">char</span> * base64SignatureBuf,
00159         <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> base64SignatureBufLen);
00160 
00176     <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_5">privateDecrypt</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * inBuf,
00177                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * plainBuf, 
00178                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> inLength,
00179                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxOutLength,
00180                                  PaddingType padding,
00181                                  <a class="code" href="DSIGConstants_8hpp.html#a104">hashMethod</a> hm);
00182 
00183 
00199     <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_6">publicEncrypt</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * inBuf,
00200                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * cipherBuf, 
00201                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> inLength,
00202                                  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxOutLength,
00203                                  PaddingType padding,
00204                                  <a class="code" href="DSIGConstants_8hpp.html#a104">hashMethod</a> hm);
00205 
00212     <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classXSECCryptoKeyRSA.html#z168_7">getLength</a>(<span class="keywordtype">void</span>);
00213 
00215 
00222 
00232     <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classXSECCryptoKeyRSA.html#z169_0">loadPublicModulusBase64BigNums</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> * b64, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> len);
00233 
00243     <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classXSECCryptoKeyRSA.html#z169_1">loadPublicExponentBase64BigNums</a>(<span class="keyword">const</span> <span class="keywordtype">char</span> * b64, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> len);
00244 
00246 
00249 
00259     <a class="code" href="classOpenSSLCryptoKeyRSA.html">OpenSSLCryptoKeyRSA</a>(EVP_PKEY *k);
00260 
00262 
00263 <span class="keyword">private</span>:
00264 
00265     RSA                             * mp_rsaKey;
00266     <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>                   * mp_oaepParams;
00267     <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>                    m_oaepParamsLen;
00268 
00269 };
00270 
00271 <span class="preprocessor">#endif </span><span class="comment">/* HAVE_OPENSSL */</span>
00272 <span class="preprocessor">#endif </span><span class="comment">/* OPENSSLCRYPTOKEYRSA_INCLUDE */</span>
</pre></div><hr size="1"><address style="align: right;"><small>Generated on Sun Jul 3 17:37:26 2005 for XML-Security-C by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.4.2 </small></address>
</body>
</html>