/*
* 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.jse.provider;
import java.io.IOException;
import java.io.NotSerializableException;
import java.io.ObjectOutputStream;
import java.math.BigInteger;
import java.security.interfaces.RSAPrivateKey;
import es.gob.jmulticard.card.CryptoCard;
import es.gob.jmulticard.card.Location;
import es.gob.jmulticard.card.dnie.DniePrivateKeyReference;
/** Clave privada de un DNIe. La clase no contiene la clave privada en si, sino
* una referencia a ella y una referencia al propio DNIe, con el canal seguro
* establecido.
* @author Tomás García-Merás. */
public final class DniePrivateKey implements RSAPrivateKey {
private static final long serialVersionUID = 4403051294889801855L;
private final CryptoCard dnie;
/** Identificador de la clave. */
private final byte[] id;
/** Ruta de la clave. */
private final Location path;
/** Etiqueta de la clave. */
private final String name;
/** Crea una clave privada de DNIe.
* @param keyReference Referencia a la clave privada del DNIe. */
DniePrivateKey(final DniePrivateKeyReference keyReference) {
this.dnie = keyReference.getDnieCard();
this.id = keyReference.getIdentifier();
this.path = keyReference.getKeyPath();
this.name = keyReference.getLabel();
}
/** {@inheritDoc} */
@Override
public String getAlgorithm() {
return "RSA"; //$NON-NLS-1$
}
/** Obtiene la tarjeta capaz de operar con esta clave.
* @return Tarjeta capaz de operar con esta clave. */
CryptoCard getCryptoCard() {
return this.dnie;
}
/** {@inheritDoc} */
@Override
public byte[] getEncoded() {
return null;
}
/** {@inheritDoc} */
@Override
public String getFormat() {
return null;
}
/** Recupera el identificador de la clave.
* @return Identificador de la clave. */
byte[] getId() {
return this.id;
}
/** Método no soportado. */
@Override
public BigInteger getModulus() {
throw new UnsupportedOperationException();
}
/** Recupera la ruta hacia la clave.
* @return Ruta de la clave. */
Location getPath() {
return this.path;
}
/** Método no soportado. */
@Override
public BigInteger getPrivateExponent() {
throw new UnsupportedOperationException();
}
/** {@inheritDoc} */
@Override
public String toString() {
return this.name;
}
@SuppressWarnings({ "static-method", "unused" })
private void writeObject(final ObjectOutputStream out) throws IOException {
throw new NotSerializableException();
}
}