All Downloads are FREE. Search and download functionalities are using the official Maven repository.

es.gob.jmulticard.asn1.der.pkcs15.X509CertificateAttributes Maven / Gradle / Ivy

There is a newer version: 1.8
Show newest version
/*
 * Controlador Java de la Secretaria de Estado de Administraciones Publicas
 * para el DNI electronico.
 *
 * El Controlador Java para el DNI electronico es un proveedor de seguridad de JCA/JCE
 * que permite el acceso y uso del DNI electronico en aplicaciones Java de terceros
 * para la realizacion de procesos de autenticacion, firma electronica y validacion
 * de firma. Para ello, se implementan las funcionalidades KeyStore y Signature para
 * el acceso a los certificados y claves del DNI electronico, asi como la realizacion
 * de operaciones criptograficas de firma con el DNI electronico. El Controlador ha
 * sido disenado para su funcionamiento independiente del sistema operativo final.
 *
 * Copyright (C) 2012 Direccion General de Modernizacion Administrativa, Procedimientos
 * e Impulso de la Administracion Electronica
 *
 * Este programa es software libre y utiliza un licenciamiento dual (LGPL 2.1+
 * o EUPL 1.1+), lo cual significa que los usuarios podran elegir bajo cual de las
 * licencias desean utilizar el codigo fuente. Su eleccion debera reflejarse
 * en las aplicaciones que integren o distribuyan el Controlador, ya que determinara
 * su compatibilidad con otros componentes.
 *
 * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la
 * Lesser GNU General Public License publicada por la Free Software Foundation,
 * tanto en la version 2.1 de la Licencia, o en una version posterior.
 *
 * El Controlador puede ser redistribuido y/o modificado bajo los terminos de la
 * European Union Public License publicada por la Comision Europea,
 * tanto en la version 1.1 de la Licencia, o en una version posterior.
 *
 * Deberia recibir una copia de la GNU Lesser General Public License, si aplica, junto
 * con este programa. Si no, consultelo en .
 *
 * Deberia recibir una copia de la European Union Public License, si aplica, junto
 * con este programa. Si no, consultelo en .
 *
 * Este programa es distribuido con la esperanza de que sea util, pero
 * SIN NINGUNA GARANTIA; incluso sin la garantia implicita de comercializacion
 * o idoneidad para un proposito particular.
 */
package es.gob.jmulticard.asn1.der.pkcs15;

import java.math.BigInteger;

import es.gob.jmulticard.asn1.DecoderObject;
import es.gob.jmulticard.asn1.OptionalDecoderObjectElement;
import es.gob.jmulticard.asn1.der.DerInteger;
import es.gob.jmulticard.asn1.der.Sequence;
import es.gob.jmulticard.asn1.der.x509.RdnSequence;

/** Tipo ASN.1 PKCS#15 X509CertificateAttributes.
 * 
 *  X509CertificateAttributes ::= SEQUENCE {
 *    value ObjectValue { Certificate },
 *    subject Name,
 *    issuer [0] Name,
 *    serialNumber INTEGER
 *  }
 *  Name ::= CHOICE {
 *    rdnSequence RDNSequence
 *  }
 * 
* @author Gonzalo Henríquez Manzano */ public final class X509CertificateAttributes extends Sequence { /** Crea un objeto ASN.1 PKCS#15 X509CertificateAttributes. */ public X509CertificateAttributes() { super( new OptionalDecoderObjectElement[] { new OptionalDecoderObjectElement( Path.class, false ), new OptionalDecoderObjectElement( RdnSequence.class, true ), new OptionalDecoderObjectElement( CertificateIssuerContextSpecific.class, true ), new OptionalDecoderObjectElement( DerInteger.class, true ) } ); } /** Proporciona el nombre X.500 del emisor del certificado * @return Nombre X.500 del emisor del certificado */ String getIssuer() { final DecoderObject d = getObject(CertificateIssuerContextSpecific.class); if (d==null) { return null; } return d.toString(); } /** Proporciona el nombre X.500 del titular del certificado * @return Nombre X.500 del emisor del certificado */ String getSubject() { final DecoderObject d = getObject(RdnSequence.class); if (d==null) { return null; } return d.toString(); } /** Devuelve la ruta del certificado. * @return Ruta (path) del certificado */ String getPath() { final DecoderObject d = getObject(Path.class); if (d==null) { return null; } return ((Path)d).getPathString(); } /** Devuelve la ruta del certificado como array de octetos. * @return Ruta (path) del certificado como array de octetos*/ byte[] getPathBytes() { final DecoderObject d = getObject(Path.class); if (d==null) { return null; } return ((Path)d).getPathBytes(); } /** Obtiene el número de serie del Certificado. * @return Número de serie del Certificado */ BigInteger getSerialNumber() { final DecoderObject d = getObject(DerInteger.class); if (d==null) { return null; } return ((DerInteger)d).getIntegerValue(); } private DecoderObject getObject(final Class objectType) { if (objectType == null) { return null; } for (int i=0;i




© 2015 - 2025 Weber Informatics LLC | Privacy Policy