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 Page</a> | <a class="qindex" href="modules.html">Modules</a> | <a class="qindex" href="hierarchy.html">Class Hierarchy</a> | <a class="qindex" href="annotated.html">Class List</a> | <a class="qindex" href="dirs.html">Directories</a> | <a class="qindex" href="files.html">File List</a> | <a class="qindex" href="functions.html">Class Members</a> | <a class="qindex" href="globals.html">File Members</a> | <a class="qindex" href="pages.html">Related Pages</a></div>
<div class="nav">
<a class="el" href="dir_000000.html">src</a> / <a class="el" href="dir_000002.html">enc</a> / <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 <xsec/enc/XSECCryptoKeyRSA.hpp></span>
00032
00033 <span class="preprocessor">#if defined (HAVE_OPENSSL)</span>
00034 <span class="preprocessor"></span><span class="preprocessor">#include <openssl/evp.h></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
<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>
|