File: XSECCryptoKeyRSA_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 (113 lines) | stat: -rw-r--r-- 9,586 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
<!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&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></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 &lt;xsec/enc/XSECCryptoKey.hpp&gt;</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&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>