/*
* 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 <http://www.gnu.org/licenses/>.
*
* Deberia recibir una copia de la European Union Public License, si aplica, junto
* con este programa. Si no, consultelo en <http://joinup.ec.europa.eu/software/page/eupl>.
*
* 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;
import es.gob.jmulticard.HexUtils;
import es.gob.jmulticard.asn1.Asn1Exception;
import es.gob.jmulticard.asn1.DecoderObject;
import es.gob.jmulticard.asn1.Tlv;
import es.gob.jmulticard.asn1.TlvException;
/** Tipo ASN.1 específico del contexto.
* @author Tomás García-Merás */
public abstract class ContextSpecific extends DecoderObject {
private DecoderObject object = null;
protected DecoderObject getObject() {
if (this.object == null) {
throw new IllegalStateException();
}
return this.object;
}
@Override
protected void decodeValue() throws Asn1Exception, TlvException {
final Tlv tlv = new Tlv(this.getRawDerValue());
final DecoderObject tmpDo;
try {
tmpDo = this.elementType.getConstructor().newInstance();
}
catch (final Exception e) {
throw new Asn1Exception(
"No se ha podido instanciar un " + this.elementType.getName() + " en el contexto especifico: " + e, e //$NON-NLS-1$ //$NON-NLS-2$
);
}
tmpDo.setDerValue(tlv.getValue());
this.object = tmpDo;
}
private final Class<? extends DecoderObject> elementType;
/** Construye un tipo ASN.1 específico del contexto.
* @param type Tipo de elemento contenido dentro de este objeto. */
public ContextSpecific(final Class<? extends DecoderObject> type) {
super();
if (type == null) {
throw new IllegalArgumentException(
"El tipo contenido dentro de ContextSpecific no puede ser nulo" //$NON-NLS-1$
);
}
this.elementType = type;
}
@Override
protected byte getDefaultTag() {
throw new UnsupportedOperationException("No hay tipo por defecto"); //$NON-NLS-1$
}
/** {@inheritDoc} */
@Override
public void checkTag(final byte tag) throws Asn1Exception {
if ((tag & 0x0c0) != 0x080) {
throw new Asn1Exception(
"La etiqueta " + HexUtils.hexify(new byte[] { tag}, false) + //$NON-NLS-1$
" no es valida para un objeto especifico del contexto" //$NON-NLS-1$
);
}
}
}