2 * Copyright 2001-2007 Internet2
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 * @file xmltooling/signature/KeyInfo.h
20 * XMLObjects representing XML Digital Signature, version 20020212, KeyInfo element
21 * and related content.
24 #if !defined(__xmltooling_keyinfo_h__) && !defined(XMLTOOLING_NO_XMLSEC)
25 #define __xmltooling_keyinfo_h__
27 #include <xmltooling/ConcreteXMLObjectBuilder.h>
28 #include <xmltooling/ElementProxy.h>
29 #include <xmltooling/util/XMLConstants.h>
32 * Macro for declaring signature builders.
34 * @param cname name of class being built
36 #define DECL_XMLSIGOBJECTBUILDER(cname) \
37 DECL_XMLOBJECTBUILDER(XMLTOOL_API,cname,xmlconstants::XMLSIG_NS,xmlconstants::XMLSIG_PREFIX)
40 * Macro for declaring signature builders.
42 * @param cname name of class being built
44 #define DECL_XMLSIG11OBJECTBUILDER(cname) \
45 DECL_XMLOBJECTBUILDER(XMLTOOL_API,cname,xmlconstants::XMLSIG11_NS,xmlconstants::XMLSIG11_PREFIX)
47 namespace xmlsignature {
49 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,KeyName,Name,XML Digital Signature version 20020212 KeyName element);
50 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,MgmtData,Data,XML Digital Signature version 20020212 MgmtData element);
51 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,Modulus,Value,XML Digital Signature version 20020212 Modulus element);
52 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,Exponent,Value,XML Digital Signature version 20020212 Exponent element);
53 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,Seed,Value,XML Digital Signature version 20020212 Seed element);
54 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,PgenCounter,Value,XML Digital Signature version 20020212 PgenCounter element);
55 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,P,Value,XML Digital Signature version 20020212 P element);
56 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,Q,Value,XML Digital Signature version 20020212 Q element);
57 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,G,Value,XML Digital Signature version 20020212 G element);
58 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,Y,Value,XML Digital Signature version 20020212 Y element);
59 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,J,Value,XML Digital Signature version 20020212 J element);
60 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,XPath,Expression,XML Digital Signature version 20020212 XPath element);
61 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509IssuerName,Name,XML Digital Signature version 20020212 X509IssuerName element);
62 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509SerialNumber,SerialNumber,XML Digital Signature version 20020212 X509SerialNumber element);
63 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509SKI,Value,XML Digital Signature version 20020212 X509SKI element);
64 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509SubjectName,Name,XML Digital Signature version 20020212 X509SubjectName element);
65 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509Certificate,Value,XML Digital Signature version 20020212 X509Certificate element);
66 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,X509CRL,Value,XML Digital Signature version 20020212 X509CRL element);
67 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,SPKISexp,Value,XML Digital Signature version 20020212 SPKISexp element);
68 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,PGPKeyID,ID,XML Digital Signature version 20020212 PGPKeyID element);
69 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,PGPKeyPacket,Packet,XML Digital Signature version 20020212 PGPKeyPacket element);
71 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,OCSPResponse,Response,XML Digital Signature version 1.1 OCSPResponse element);
72 DECL_XMLOBJECT_SIMPLE(XMLTOOL_API,PublicKey,Value,XML Digital Signature version 1.1 PublicKey element);
74 BEGIN_XMLOBJECT(XMLTOOL_API,DSAKeyValue,xmltooling::XMLObject,XML Digital Signature version 20020212 DSAKeyValue element);
80 DECL_TYPED_CHILD(Seed);
81 DECL_TYPED_CHILD(PgenCounter);
82 /** DSAKeyValueType local name */
83 static const XMLCh TYPE_NAME[];
86 BEGIN_XMLOBJECT(XMLTOOL_API,RSAKeyValue,xmltooling::XMLObject,XML Digital Signature version 20020212 RSAKeyValue element);
87 DECL_TYPED_CHILD(Modulus);
88 DECL_TYPED_CHILD(Exponent);
89 /** RSAKeyValueType local name */
90 static const XMLCh TYPE_NAME[];
93 BEGIN_XMLOBJECT(XMLTOOL_API,NamedCurve,xmltooling::XMLObject,XML Digital Signature version 1.1 NamedCurve element);
94 DECL_STRING_ATTRIB(URI,URI);
95 /** NamedCurveType local name */
96 static const XMLCh TYPE_NAME[];
99 BEGIN_XMLOBJECT(XMLTOOL_API,ECKeyValue,xmltooling::XMLObject,XML Digital Signature version 1.1 ECKeyValue element);
100 DECL_STRING_ATTRIB(Id,ID);
101 DECL_XMLOBJECT_CHILD(ECParameters);
102 DECL_TYPED_CHILD(NamedCurve);
103 DECL_TYPED_CHILD(PublicKey);
104 /** ECKeyValueType local name */
105 static const XMLCh TYPE_NAME[];
108 BEGIN_XMLOBJECT(XMLTOOL_API,KeyValue,xmltooling::XMLObject,XML Digital Signature version 20020212 KeyValue element);
109 DECL_TYPED_CHILD(DSAKeyValue);
110 DECL_TYPED_CHILD(RSAKeyValue);
111 DECL_TYPED_CHILD(ECKeyValue);
112 DECL_XMLOBJECT_CHILD(UnknownXMLObject);
113 /** KeyValueType local name */
114 static const XMLCh TYPE_NAME[];
117 BEGIN_XMLOBJECT(XMLTOOL_API,Transform,xmltooling::ElementExtensibleXMLObject,XML Digital Signature version 20020212 Transform element);
118 DECL_STRING_ATTRIB(Algorithm,ALGORITHM);
119 DECL_TYPED_CHILDREN(XPath);
120 /** TransformType local name */
121 static const XMLCh TYPE_NAME[];
124 BEGIN_XMLOBJECT(XMLTOOL_API,Transforms,xmltooling::XMLObject,XML Digital Signature version 20020212 Transforms element);
125 DECL_TYPED_CHILDREN(Transform);
126 /** TransformsType local name */
127 static const XMLCh TYPE_NAME[];
130 BEGIN_XMLOBJECT(XMLTOOL_API,RetrievalMethod,xmltooling::XMLObject,XML Digital Signature version 20020212 RetrievalMethod element);
131 DECL_STRING_ATTRIB(URI,URI);
132 DECL_STRING_ATTRIB(Type,TYPE);
133 DECL_TYPED_CHILD(Transforms);
134 /** RetrievalMethodType local name */
135 static const XMLCh TYPE_NAME[];
136 /** DSAKeyValue RetrievalMethod Type */
137 static const XMLCh TYPE_DSAKEYVALUE[];
138 /** RSAKeyValue RetrievalMethod Type */
139 static const XMLCh TYPE_RSAKEYVALUE[];
140 /** X509Data RetrievalMethod Type */
141 static const XMLCh TYPE_X509DATA[];
144 BEGIN_XMLOBJECT(XMLTOOL_API,X509IssuerSerial,xmltooling::XMLObject,XML Digital Signature version 20020212 X509IssuerSerial element);
145 DECL_TYPED_CHILD(X509IssuerName);
146 DECL_TYPED_CHILD(X509SerialNumber);
147 /** X509IssuerSerialType local name */
148 static const XMLCh TYPE_NAME[];
151 BEGIN_XMLOBJECT(XMLTOOL_API,X509Data,xmltooling::ElementExtensibleXMLObject,XML Digital Signature version 20020212 X509Data element);
152 DECL_TYPED_CHILDREN(X509IssuerSerial);
153 DECL_TYPED_CHILDREN(X509SKI);
154 DECL_TYPED_CHILDREN(X509SubjectName);
155 DECL_TYPED_CHILDREN(X509Certificate);
156 DECL_TYPED_CHILDREN(X509CRL);
157 DECL_TYPED_CHILDREN(OCSPResponse);
158 /** X509DataType local name */
159 static const XMLCh TYPE_NAME[];
162 BEGIN_XMLOBJECT(XMLTOOL_API,SPKIData,xmltooling::XMLObject,XML Digital Signature version 20020212 SPKIData element);
163 /** SPKIDataType local name */
164 static const XMLCh TYPE_NAME[];
166 /** Returns modifiable collection of SPKIsexp/XMLObject pairs. */
167 virtual VectorOfPairs(SPKISexp,xmltooling::XMLObject) getSPKISexps()=0;
169 /** Returns reference to immutable collection of SPKIsexp/XMLObject pairs. */
170 virtual const std::vector< std::pair<SPKISexp*,xmltooling::XMLObject*> >& getSPKISexps() const=0;
173 BEGIN_XMLOBJECT(XMLTOOL_API,PGPData,xmltooling::ElementExtensibleXMLObject,XML Digital Signature version 20020212 PGPData element);
174 DECL_TYPED_CHILD(PGPKeyID);
175 DECL_TYPED_CHILD(PGPKeyPacket);
176 /** PGPDataType local name */
177 static const XMLCh TYPE_NAME[];
180 BEGIN_XMLOBJECT(XMLTOOL_API,DEREncodedKeyValue,xmltooling::XMLObject,XML Digital Signature version 1.1 DEREncodedKeyValue element);
181 DECL_STRING_ATTRIB(Id,ID);
182 DECL_SIMPLE_CONTENT(Value);
183 /** DEREncodedKeyValueType local name */
184 static const XMLCh TYPE_NAME[];
187 BEGIN_XMLOBJECT(XMLTOOL_API,KeyInfoReference,xmltooling::XMLObject,XML Digital Signature version 1.1 KeyInfoReference element);
188 DECL_STRING_ATTRIB(Id,ID);
189 DECL_STRING_ATTRIB(URI,URI);
190 /** KeyInfoReferenceType local name */
191 static const XMLCh TYPE_NAME[];
194 BEGIN_XMLOBJECT(XMLTOOL_API,KeyInfo,xmltooling::ElementExtensibleXMLObject,XML Digital Signature version 20020212 KeyInfo element);
195 DECL_STRING_ATTRIB(Id,ID);
196 DECL_TYPED_CHILDREN(X509Data);
197 DECL_TYPED_CHILDREN(KeyName);
198 DECL_TYPED_CHILDREN(KeyValue);
199 DECL_TYPED_CHILDREN(DEREncodedKeyValue);
200 DECL_TYPED_CHILDREN(RetrievalMethod);
201 DECL_TYPED_CHILDREN(MgmtData);
202 DECL_TYPED_CHILDREN(PGPData);
203 DECL_TYPED_CHILDREN(SPKIData);
204 DECL_TYPED_CHILDREN(KeyInfoReference);
205 /** KeyInfoType local name */
206 static const XMLCh TYPE_NAME[];
209 DECL_XMLSIGOBJECTBUILDER(PGPData);
210 DECL_XMLSIGOBJECTBUILDER(PGPKeyID);
211 DECL_XMLSIGOBJECTBUILDER(PGPKeyPacket);
212 DECL_XMLSIGOBJECTBUILDER(SPKIData);
213 DECL_XMLSIGOBJECTBUILDER(SPKISexp);
214 DECL_XMLSIGOBJECTBUILDER(X509IssuerSerial);
215 DECL_XMLSIGOBJECTBUILDER(X509IssuerName);
216 DECL_XMLSIGOBJECTBUILDER(X509SerialNumber);
217 DECL_XMLSIGOBJECTBUILDER(X509SKI);
218 DECL_XMLSIGOBJECTBUILDER(X509SubjectName);
219 DECL_XMLSIGOBJECTBUILDER(X509Certificate);
220 DECL_XMLSIGOBJECTBUILDER(X509CRL);
221 DECL_XMLSIGOBJECTBUILDER(X509Data);
222 DECL_XMLSIGOBJECTBUILDER(XPath);
223 DECL_XMLSIGOBJECTBUILDER(Transform);
224 DECL_XMLSIGOBJECTBUILDER(Transforms);
225 DECL_XMLSIGOBJECTBUILDER(RetrievalMethod);
226 DECL_XMLSIGOBJECTBUILDER(KeyName);
227 DECL_XMLSIGOBJECTBUILDER(MgmtData);
228 DECL_XMLSIGOBJECTBUILDER(Modulus);
229 DECL_XMLSIGOBJECTBUILDER(Exponent);
230 DECL_XMLSIGOBJECTBUILDER(Seed);
231 DECL_XMLSIGOBJECTBUILDER(PgenCounter);
232 DECL_XMLSIGOBJECTBUILDER(P);
233 DECL_XMLSIGOBJECTBUILDER(Q);
234 DECL_XMLSIGOBJECTBUILDER(G);
235 DECL_XMLSIGOBJECTBUILDER(Y);
236 DECL_XMLSIGOBJECTBUILDER(J);
237 DECL_XMLSIGOBJECTBUILDER(DSAKeyValue);
238 DECL_XMLSIGOBJECTBUILDER(RSAKeyValue);
239 DECL_XMLSIGOBJECTBUILDER(KeyValue);
240 DECL_XMLSIGOBJECTBUILDER(KeyInfo);
242 DECL_XMLSIG11OBJECTBUILDER(DEREncodedKeyValue);
243 DECL_XMLSIG11OBJECTBUILDER(ECKeyValue);
244 DECL_XMLSIG11OBJECTBUILDER(KeyInfoReference);
245 DECL_XMLSIG11OBJECTBUILDER(NamedCurve);
246 DECL_XMLSIG11OBJECTBUILDER(OCSPResponse);
247 DECL_XMLSIG11OBJECTBUILDER(PublicKey);
250 * Registers builders and validators for KeyInfo classes into the runtime.
252 void XMLTOOL_API registerKeyInfoClasses();
256 #endif /* __xmltooling_keyinfo_h__ */