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
|
<!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: XSECCryptoKeyRSA.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></div>
<h1>XSECCryptoKeyRSA.hpp</h1><a href="XSECCryptoKeyRSA_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: XSECCryptoKeyRSA.hpp,v 1.10 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 XSECCRYPTOKEYRSA_INCLUDE</span>
00029 <span class="preprocessor"></span><span class="preprocessor">#define XSECCRYPTOKEYRSA_INCLUDE</span>
00030 <span class="preprocessor"></span>
00031 <span class="preprocessor">#include <xsec/enc/XSECCryptoKey.hpp></span>
00032
<a name="l00044"></a><a class="code" href="classXSECCryptoKeyRSA.html">00044</a> <span class="keyword">class </span><a class="code" href="XSECDefs_8hpp.html#a9">DSIG_EXPORT</a> <a class="code" href="classXSECCryptoKeyRSA.html">XSECCryptoKeyRSA</a> : <span class="keyword">public</span> <a class="code" href="classXSECCryptoKey.html">XSECCryptoKey</a> {
00045
00046 <span class="keyword">public</span> :
00047
<a name="l00054"></a><a class="code" href="classXSECCryptoKeyRSA.html#w3">00054</a> <span class="keyword">enum</span> PaddingType {
00055
00056 PAD_NONE = 0,
00057 PAD_PKCS_1_5 = 1,
00058 PAD_OAEP_MGFP1 = 2
00060 };
00061
00064
<a name="l00065"></a><a class="code" href="classXSECCryptoKeyRSA.html#z166_0">00065</a> <a class="code" href="classXSECCryptoKeyRSA.html">XSECCryptoKeyRSA</a>() {};
<a name="l00066"></a><a class="code" href="classXSECCryptoKeyRSA.html#z166_1">00066</a> <span class="keyword">virtual</span> ~<a class="code" href="classXSECCryptoKeyRSA.html">XSECCryptoKeyRSA</a>() {};
00067
00069
00072
<a name="l00080"></a><a class="code" href="classXSECCryptoKeyRSA.html#z167_0">00080</a> <span class="keyword">virtual</span> <a class="code" href="classXSECCryptoKey.html#w9">XSECCryptoKey::KeyType</a> <a class="code" href="classXSECCryptoKey.html#z158_0">getKeyType</a>() {<span class="keywordflow">return</span> KEY_NONE;}
00081
00086 <span class="keyword">virtual</span> <a class="code" href="classXSECCryptoKey.html">XSECCryptoKey</a> * <a class="code" href="classXSECCryptoKey.html#z158_2">clone</a>() = 0;
00087
00089
00095
00109 <span class="keyword">virtual</span> <span class="keywordtype">void</span> setOAEPparams(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * params, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> paramsLen) = 0;
00110
00117 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> getOAEPparamsLen(<span class="keywordtype">void</span>) = 0;
00118
00126 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * getOAEPparams(<span class="keywordtype">void</span>) = 0;
00127
00141 <span class="keyword">virtual</span> <span class="keywordtype">bool</span> verifySHA1PKCS1Base64Signature(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * hashBuf,
00142 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> hashLen,
00143 <span class="keyword">const</span> <span class="keywordtype">char</span> * base64Signature,
00144 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> sigLen) = 0;
00145
00165 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> signSHA1PKCS1Base64Signature(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * hashBuf,
00166 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> hashLen,
00167 <span class="keywordtype">char</span> * base64SignatureBuf,
00168 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> base64SignatureBufLen) = 0;
00169
00185 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> privateDecrypt(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * inBuf,
00186 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * plainBuf,
00187 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> inLength,
00188 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxOutLength,
00189 PaddingType padding,
00190 <a class="code" href="DSIGConstants_8hpp.html#a104">hashMethod</a> hm) = 0;
00191
00208 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> publicEncrypt(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * inBuf,
00209 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> * cipherBuf,
00210 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> inLength,
00211 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxOutLength,
00212 PaddingType padding,
00213 <a class="code" href="DSIGConstants_8hpp.html#a104">hashMethod</a> hm) = 0;
00214
00221 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> getLength(<span class="keywordtype">void</span>) = 0;
00222
00224
00236
00246 <span class="keyword">virtual</span> <span class="keywordtype">void</span> loadPublicModulusBase64BigNums(<span class="keyword">const</span> <span class="keywordtype">char</span> * b64, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> len) = 0;
00247
00257 <span class="keyword">virtual</span> <span class="keywordtype">void</span> loadPublicExponentBase64BigNums(<span class="keyword">const</span> <span class="keywordtype">char</span> * b64, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> len) = 0;
00258
00260
00261 };
00262
00263
00264
00265 <span class="preprocessor">#endif </span><span class="comment">/* XSECCRYPTOKEYRSA_INCLUDE */</span>
</pre></div><hr size="1"><address style="align: right;"><small>Generated on Sun Jul 3 17:37:28 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>
|