Description
KeyInfo is an 
optional element that enables the recipient(s) to obtain
the key needed to validate the signature.  KeyInfo may contain keys,
names, certificates and other public key management information, such as
in-band key distribution or key agreement data.
Schema Definition:
DTD:
 
Functions
xmlSecKeyInfoNodeRead ()
int
xmlSecKeyInfoNodeRead (xmlNodePtr keyInfoNode,
                       xmlSecKeyPtr key,
                       xmlSecKeyInfoCtxPtr keyInfoCtx);
Parses the <dsig:KeyInfo/> element keyInfoNode
, extracts the key data
and stores into key
.
Returns
 0 on success or -1 if an error occurs.
 
 
xmlSecKeyInfoNodeWrite ()
int
xmlSecKeyInfoNodeWrite (xmlNodePtr keyInfoNode,
                        xmlSecKeyPtr key,
                        xmlSecKeyInfoCtxPtr keyInfoCtx);
Writes the key
 into the <dsig:KeyInfo/> element template keyInfoNode
.
Returns
 0 on success or -1 if an error occurs.
 
 
xmlSecKeyInfoCtxReset ()
void
xmlSecKeyInfoCtxReset (xmlSecKeyInfoCtxPtr keyInfoCtx);
Resets the keyInfoCtx
 state. User settings are not changed.
 
xmlSecKeyInfoCtxCopyUserPref ()
int
xmlSecKeyInfoCtxCopyUserPref (xmlSecKeyInfoCtxPtr dst,
                              xmlSecKeyInfoCtxPtr src);
Copies user preferences from src
 context to dst
 context.
Returns
 0 on success and a negative value if an error occurs.
 
 
xmlSecKeyInfoCtxDebugDump ()
void
xmlSecKeyInfoCtxDebugDump (xmlSecKeyInfoCtxPtr keyInfoCtx,
                           FILE *output);
Prints user settings and current context state to output
.
 
xmlSecKeyInfoCtxDebugXmlDump ()
void
xmlSecKeyInfoCtxDebugXmlDump (xmlSecKeyInfoCtxPtr keyInfoCtx,
                              FILE *output);
Prints user settings and current context state in XML format to output
.
 
xmlSecKeyDataNameGetKlass ()
xmlSecKeyDataId
xmlSecKeyDataNameGetKlass (void);
The <dsig:KeyName/> element key data klass
(http://www.w3.org/TR/xmldsig-core/sec-KeyName):
The KeyName element contains a string value (in which white space is
significant) which may be used by the signer to communicate a key
identifier to the recipient. Typically, KeyName contains an identifier
related to the key pair used to sign the message, but it may contain
other protocol-related information that indirectly identifies a key pair.
(Common uses of KeyName include simple string names for keys, a key index,
a distinguished name (DN), an email address, etc.)
 
xmlSecKeyDataValueGetKlass ()
xmlSecKeyDataId
xmlSecKeyDataValueGetKlass (void);
The <dsig:KeyValue/> element key data klass
(http://www.w3.org/TR/xmldsig-core/sec-KeyValue):
The KeyValue element contains a single public key that may be useful in
validating the signature.
 
xmlSecKeyDataRetrievalMethodGetKlass ()
xmlSecKeyDataId
xmlSecKeyDataRetrievalMethodGetKlass (void);
The <dsig:RetrievalMethod/> element key data klass
(http://www.w3.org/TR/xmldsig-core/sec-RetrievalMethod):
A RetrievalMethod element within KeyInfo is used to convey a reference to
KeyInfo information that is stored at another location. For example,
several signatures in a document might use a key verified by an X.509v3
certificate chain appearing once in the document or remotely outside the
document; each signature's KeyInfo can reference this chain using a single
RetrievalMethod element instead of including the entire chain with a
sequence of X509Certificate elements.
RetrievalMethod uses the same syntax and dereferencing behavior as
Reference's URI and The Reference Processing Model.
 
xmlSecKeyDataEncryptedKeyGetKlass ()
xmlSecKeyDataId
xmlSecKeyDataEncryptedKeyGetKlass (void);
The <enc:EncryptedKey/> element key data klass
(http://www.w3.org/TR/xmlenc-core/sec-EncryptedKey):
The EncryptedKey element is used to transport encryption keys from
the originator to a known recipient(s). It may be used as a stand-alone
XML document, be placed within an application document, or appear inside
an EncryptedData element as a child of a ds:KeyInfo element. The key value
is always encrypted to the recipient(s). When EncryptedKey is decrypted the
resulting octets are made available to the EncryptionMethod algorithm
without any additional processing.
 
 
Types and Values
enum xmlSecKeyInfoMode
The xmlSecKeyInfoCtx
 operation mode (read or write).
 
XMLSEC_KEYINFO_FLAGS_DONT_STOP_ON_KEY_FOUND
#define XMLSEC_KEYINFO_FLAGS_DONT_STOP_ON_KEY_FOUND             0x00000001
If flag is set then we will continue reading <dsig:KeyInfo />
element even when key is already found.
 
XMLSEC_KEYINFO_FLAGS_STOP_ON_UNKNOWN_CHILD
#define XMLSEC_KEYINFO_FLAGS_STOP_ON_UNKNOWN_CHILD              0x00000002
If flag is set then we abort if an unknown <dsig:KeyInfo />
child is found.
 
XMLSEC_KEYINFO_FLAGS_KEYNAME_STOP_ON_UNKNOWN
#define XMLSEC_KEYINFO_FLAGS_KEYNAME_STOP_ON_UNKNOWN            0x00000004
If flags is set then we abort if an unknown key name
(content of <dsig:KeyName /> element) is found.
 
XMLSEC_KEYINFO_FLAGS_KEYVALUE_STOP_ON_UNKNOWN_CHILD
#define XMLSEC_KEYINFO_FLAGS_KEYVALUE_STOP_ON_UNKNOWN_CHILD     0x00000008
If flags is set then we abort if an unknown <dsig:KeyValue />
child is found.
 
XMLSEC_KEYINFO_FLAGS_RETRMETHOD_STOP_ON_UNKNOWN_HREF
#define XMLSEC_KEYINFO_FLAGS_RETRMETHOD_STOP_ON_UNKNOWN_HREF    0x00000010
If flag is set then we abort if an unknown href attribute
of <dsig:RetrievalMethod /> element is found.
 
XMLSEC_KEYINFO_FLAGS_RETRMETHOD_STOP_ON_MISMATCH_HREF
#define XMLSEC_KEYINFO_FLAGS_RETRMETHOD_STOP_ON_MISMATCH_HREF   0x00000020
If flag is set then we abort if an href attribute <dsig:RetrievalMethod />
element does not match the real key data type.
 
XMLSEC_KEYINFO_FLAGS_X509DATA_STOP_ON_UNKNOWN_CHILD
#define XMLSEC_KEYINFO_FLAGS_X509DATA_STOP_ON_UNKNOWN_CHILD     0x00000100
If flags is set then we abort if an unknown <dsig:X509Data />
child is found.
 
XMLSEC_KEYINFO_FLAGS_X509DATA_DONT_VERIFY_CERTS
#define XMLSEC_KEYINFO_FLAGS_X509DATA_DONT_VERIFY_CERTS         0x00000200
If flag is set then we'll load certificates from <dsig:X509Data />
element without verification.
 
XMLSEC_KEYINFO_FLAGS_X509DATA_STOP_ON_INVALID_CERT
#define XMLSEC_KEYINFO_FLAGS_X509DATA_STOP_ON_INVALID_CERT      0x00000800
If the flag is set then we'll stop when <dsig:X509Data /> element
processing does not return a verified certificate.
 
XMLSEC_KEYINFO_FLAGS_ENCKEY_DONT_STOP_ON_FAILED_DECRYPTION
#define XMLSEC_KEYINFO_FLAGS_ENCKEY_DONT_STOP_ON_FAILED_DECRYPTION 0x00001000
If the flag is set then we'll stop when <enc:EncryptedKey /> element
processing fails.
 
XMLSEC_KEYINFO_FLAGS_STOP_ON_EMPTY_NODE
#define XMLSEC_KEYINFO_FLAGS_STOP_ON_EMPTY_NODE                 0x00002000
If the flag is set then we'll stop when we found an empty node.
Otherwise we just ignore it.
 
XMLSEC_KEYINFO_FLAGS_X509DATA_SKIP_STRICT_CHECKS
#define XMLSEC_KEYINFO_FLAGS_X509DATA_SKIP_STRICT_CHECKS        0x00004000
If the flag is set then we'll skip strict checking of certs and CRLs
 
struct xmlSecKeyInfoCtx
struct xmlSecKeyInfoCtx {
    void*                               userData;
    unsigned int                        flags;
    unsigned int                        flags2;
    xmlSecKeysMngrPtr                   keysMngr;
    xmlSecKeyInfoMode                   mode;
    xmlSecPtrList                       enabledKeyData;
    int                                 base64LineSize;
    /* RetrievalMethod */
    xmlSecTransformCtx                  retrievalMethodCtx;
    int                                 maxRetrievalMethodLevel;
    /* EncryptedKey */
    xmlSecEncCtxPtr                     encCtx;
    int                                 maxEncryptedKeyLevel;
    /* x509 certificates */
    time_t                              certsVerificationTime;
    int                                 certsVerificationDepth;
    /* PGP */
    void*                               pgpReserved;    /* TODO */
    /* internal data */
    int                                 curRetrievalMethodLevel;
    int                                 curEncryptedKeyLevel;
    xmlSecKeyReq                        keyReq;
    /* for the future */
    void*                               reserved0;
    void*                               reserved1;
};
The <dsig:KeyInfo /> reading or writing context.
 
xmlSecKeyDataNameId
#define xmlSecKeyDataNameId             xmlSecKeyDataNameGetKlass()
The <dsig:KeyName/> processing class.
 
xmlSecKeyDataValueId
#define xmlSecKeyDataValueId            xmlSecKeyDataValueGetKlass()
The <dsig:KeyValue/> processing class.
 
xmlSecKeyDataRetrievalMethodId
#define xmlSecKeyDataRetrievalMethodId  xmlSecKeyDataRetrievalMethodGetKlass()
The <dsig:RetrievalMethod/> processing class.
 
xmlSecKeyDataEncryptedKeyId
#define xmlSecKeyDataEncryptedKeyId     xmlSecKeyDataEncryptedKeyGetKlass()
The <enc:EncryptedKey/> processing class.