|  |  | 
|  |  | 
|  |  | 
|  |  */ | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  */ | 
|  | package com.sun.org.apache.xml.internal.security.keys.content.x509; | 
|  |  | 
|  | import java.security.MessageDigest; | 
|  | import java.security.cert.X509Certificate; | 
|  |  | 
|  | import com.sun.org.apache.xml.internal.security.algorithms.JCEMapper; | 
|  | import com.sun.org.apache.xml.internal.security.exceptions.XMLSecurityException; | 
|  | import com.sun.org.apache.xml.internal.security.utils.Constants; | 
|  | import com.sun.org.apache.xml.internal.security.utils.Signature11ElementProxy; | 
|  | import org.w3c.dom.Attr; | 
|  | import org.w3c.dom.Document; | 
|  | import org.w3c.dom.Element; | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  */ | 
|  | public class XMLX509Digest extends Signature11ElementProxy implements XMLX509DataContent { | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public XMLX509Digest(Element element, String baseURI) throws XMLSecurityException { | 
|  |         super(element, baseURI); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public XMLX509Digest(Document doc, byte[] digestBytes, String algorithmURI) { | 
|  |         super(doc); | 
|  |         this.addBase64Text(digestBytes); | 
|  |         setLocalAttribute(Constants._ATT_ALGORITHM, algorithmURI); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public XMLX509Digest(Document doc, X509Certificate x509certificate, String algorithmURI) throws XMLSecurityException { | 
|  |         super(doc); | 
|  |         this.addBase64Text(getDigestBytesFromCert(x509certificate, algorithmURI)); | 
|  |         setLocalAttribute(Constants._ATT_ALGORITHM, algorithmURI); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public Attr getAlgorithmAttr() { | 
|  |         return getElement().getAttributeNodeNS(null, Constants._ATT_ALGORITHM); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public String getAlgorithm() { | 
|  |         return this.getAlgorithmAttr().getNodeValue(); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public byte[] getDigestBytes() throws XMLSecurityException { | 
|  |         return this.getBytesFromTextChild(); | 
|  |     } | 
|  |  | 
|  |      | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |      */ | 
|  |     public static byte[] getDigestBytesFromCert(X509Certificate cert, String algorithmURI) throws XMLSecurityException { | 
|  |         String jcaDigestAlgorithm = JCEMapper.translateURItoJCEID(algorithmURI); | 
|  |         if (jcaDigestAlgorithm == null) { | 
|  |             Object[] exArgs = {algorithmURI}; | 
|  |             throw new XMLSecurityException("XMLX509Digest.UnknownDigestAlgorithm", exArgs); | 
|  |         } | 
|  |  | 
|  |         try { | 
|  |             MessageDigest md = MessageDigest.getInstance(jcaDigestAlgorithm); | 
|  |             return md.digest(cert.getEncoded()); | 
|  |         } catch (Exception e) { | 
|  |             Object[] exArgs = {jcaDigestAlgorithm}; | 
|  |             throw new XMLSecurityException("XMLX509Digest.FailedDigest", exArgs); | 
|  |         } | 
|  |  | 
|  |     } | 
|  |  | 
|  |      | 
|  |     public String getBaseLocalName() { | 
|  |         return Constants._TAG_X509DIGEST; | 
|  |     } | 
|  | } |