public class RevokedCertificatesCRLListener extends java.lang.Object implements CRLListener
X509CRLStream for a sample.
 This implementation can also handle indirect CRLs.
 Derived classes should take into account the behavior of 
 revokedCertificate(byte[], int, int, int, int) and
 revokedCertificate(RevokedCertificate).
 If a class wants to receive all entries, it should implement the
 CRLListener interface directly.
| Constructor and Description | 
|---|
| RevokedCertificatesCRLListener(X509Certificate[] consideredCertificates,
                              java.security.PublicKey issuerKey)Create a CRL listener which searches for entries in the CRL which refer to
 any of the certificates in the array  consideredCertificates. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | extensions(X509Extensions extensions)The implementation of this method stores the given extensions for latter
 retrieval. | 
| X509Certificate[] | getConsideredCertificates() | 
| X509Extensions | getExtensions() | 
| Name | getIssuer() | 
| java.security.PublicKey | getIssuerKey() | 
| java.util.Date | getNextUpdate() | 
| java.util.Hashtable | getRevokedCertificates()Through this method, the application can get information about the
 concerned certificates; i.e. | 
| AlgorithmID | getSignature() | 
| java.security.Signature | getSignature(AlgorithmID signatureAlgorithm)This implementation of
  CRLListener.getSignature(iaik.asn1.structures.AlgorithmID)tries to
 instantiate aSignatureobject from theIAIKprovider for the given signature algorithm if the issuer public key has
 been specified in the constructor. | 
| AlgorithmID | getSignatureAlgorithm() | 
| byte[] | getSignatureValue() | 
| java.util.Date | getThisUpdate() | 
| int | getVersion() | 
| void | header(int version,
      Name issuer,
      java.util.Date thisUpdate,
      java.util.Date nextUpdate)This implementation of this method simply stores the given parameters
 in member variables for later retrieval. | 
| boolean | isIndirect()trueif there is at least one entry in the CRL which contains
 aCertificateIssuerextension. | 
| boolean | isVerified() | 
| void | revokedCertificate(byte[] buffer,
                  int offset,
                  int length,
                  int serialOffset,
                  int serialLength)The CRL stream parser calls this listener method for each CRL entry exactly
 once and in the order in which they appear in the CRL. | 
| void | revokedCertificate(RevokedCertificate entry)This implementation looks if the given  entryrefers to a
 certificate in the list of concerned certificates which has been passed
 to the constructor. | 
| void | signature(AlgorithmID signatureAlgorithm,
         byte[] signatureValue,
         boolean verified)The implementation of this method stores the given information
 about the signature for latter retrievement. | 
public RevokedCertificatesCRLListener(X509Certificate[] consideredCertificates, java.security.PublicKey issuerKey)
consideredCertificates.
 issuerKey specifies the public key which should be used
 to verify the signature of the CRL; e.g. the public key out of the CRL
 issuer certificate. If the key is null, the signature will
 not be verified. However, the application may verify the signature itself.consideredCertificates - The list of certificates which should should be searched for in
          the CRL.issuerKey - The public key to use for verifying the CRL signature.public java.security.Signature getSignature(AlgorithmID signatureAlgorithm) throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
CRLListener.getSignature(iaik.asn1.structures.AlgorithmID)tries to
 instantiate a Signatureobject from the IAIK
 provider for the given signature algorithm if the issuer public key has
 been specified in the constructor. If the public key has not been
 specified, this method returns null.getSignature in interface CRLListenersignatureAlgorithm - The signature algorithm. This is the signature algorithm as
          encoded in the signature field of the
          TBSCertList of the CRL.IAIK provider
         which has already been initialized for signature verification.java.security.NoSuchAlgorithmException - If there is no implementation available for the requested
           algorithm.java.security.InvalidKeyException - If the verification key does not suit for the algorithm.CRLListener.getSignature(iaik.asn1.structures.AlgorithmID)public void header(int version,
          Name issuer,
          java.util.Date thisUpdate,
          java.util.Date nextUpdate)
header in interface CRLListenerversion - The version number; e.g. 1 for a v2 CRL.
          -1 if unavailable.issuer - The issuer name of the CRL.thisUpdate - The thisUpdate value of the CRL.nextUpdate - The nextUpdate value of the CRL or null if not
          present.CRLListener.header(int,
      iaik.asn1.structures.Name,
      java.util.Date, java.util.Date)public void revokedCertificate(byte[] buffer,
                      int offset,
                      int length,
                      int serialOffset,
                      int serialLength)
                        throws java.security.cert.CRLException,
                               X509ExtensionException
X509CRLStream.parse(java.io.InputStream) method
 calls this method for all entries and not directly the 
 revokedCertificate(RevokedCertificate) method. This method
 investigates the encoded CRL entry. If it finds out that the entry
 matches one of the considered certificates, it will parse the entry
 and call revokedCertificate(RevokedCertificate).buffer - The buffer that contains the CRL entry. It may contain extensions.offset - The offset in the buffer where the encoded entry begins.length - The length of the encoded entry in the buffer.serialOffset - The offset in the buffer where the encoded serial number of the entry begins
          , excluding tag and encoded length of the INTEGER.serialLength - The number of octet that the serial number occupies starting from
          serialOffset.java.security.cert.CRLException - If the entry is invalid.X509ExtensionException - If the entry has invalid extensions.public void revokedCertificate(RevokedCertificate entry) throws java.security.cert.CRLException, X509ExtensionException
entry refers to a
 certificate in the list of concerned certificates which has been passed
 to the constructor. If this is the case, the entry will be stored
 in a table for later retrieval using the 
 getRevokedCertificates() method.
 
 This class has an improved mechanism for parsing the CRL entries.
 The X509CRLStream.parse(java.io.InputStream) method calls the
 revokedCertificate(byte[], int, int, int, int). If it
 method realizes that this entry is of interest, it calls this
 method with the parsed entry object.
revokedCertificate in interface CRLListenerentry - The current CRL entry. This may contain also extensions.java.security.cert.CRLException - If the entry is invalid.X509ExtensionException - If the entry has invalid extensions.CRLListener.revokedCertificate(iaik.x509.RevokedCertificate)public void extensions(X509Extensions extensions)
extensions in interface CRLListenerextensions - The extensions of the parsed CRL or null if there
          are no extensions.CRLListener.extensions(iaik.x509.X509Extensions)public void signature(AlgorithmID signatureAlgorithm, byte[] signatureValue, boolean verified) throws java.security.cert.CRLException
signature in interface CRLListenersignatureAlgorithm - The signature algorithm as encoded in the
          CertificateList of the CRL.signatureValue - The signature value as encoded in the CRL.verified - true if the CRL parser has already verified the
          signature value, false if it has not been verified.
          In the latter case, the listener can verify the signature value on
          its own.java.security.cert.CRLExceptionCRLListener.signature(iaik.asn1.structures.AlgorithmID,
      byte[], boolean)public java.util.Hashtable getRevokedCertificates()
 The table contains an entry for each certificate which has been listed
 in the CRL. The key for the table is the X509Certificate object
 as passed to the constructor. The value is a RevokedCertificate
 object if the CRL contains the certificate. The value is
 null if the CRL does not contain an entry which
 refers to the certificate. 
 
Please note that the table only contains information about those certificates which have been passed to the constructor as considered certificates.
X509Certificate objects to
         RevokedCertificate objects.public X509Certificate[] getConsideredCertificates()
public X509Extensions getExtensions()
RevokedCertificate objects which are stored in the table
         returned by getRevokedCertificates().public boolean isIndirect()
true if there is at least one entry in the CRL which contains
 a CertificateIssuer extension.true if the CRL is an indirect CRL.public Name getIssuer()
public java.security.PublicKey getIssuerKey()
null if the signature verification key has not been specified.public java.util.Date getNextUpdate()
nextUpdate field of the CRL or 
         null if it is not included in the CRL.public AlgorithmID getSignature()
CertificateList of the CRL.public AlgorithmID getSignatureAlgorithm()
signature field of the TBSCertList of
         the CRL.public byte[] getSignatureValue()
public java.util.Date getThisUpdate()
thisUpdate field of the CRL.public boolean isVerified()
true if the signature of the CRL has already
         been verified successfully. It is false, if the 
         signature is invalid. 
         public int getVersion()
1 if the
         CRL is a v2 CRL. 
         -1 if unavailable.