![JAR search and dependency download from the Maven repository](/logo.png)
es.gob.jmulticard.ui.passwordcallback.gui.UIPasswordCallbackAccessibility Maven / Gradle / Ivy
/*
* 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.ui.passwordcallback.gui;
import java.awt.Component;
import javax.security.auth.callback.PasswordCallback;
/** PasswordCallbak que muestra un diálogo accesible para
* solicitar una contraseña. */
public final class UIPasswordCallbackAccessibility extends PasswordCallback {
private static final long serialVersionUID = 1719174318602363633L;
/** Mensaje que se va a mostrar. */
private transient final String message;
/** Atajo para el campo de inserción de contrasenia. */
private transient final int mnemonic;
/** Componente padre sobre el que se mostrará el diálogo para
* la inserción de la contraseña. */
private transient final Component parent;
/** Título del diálogo. */
private transient final String title;
/** Ruta hacia el fichero de icono del diálogo. */
private transient final String iconPath;
/** Si se permite o no cachear el PIN. */
private transient final boolean allowUseCache;
/** Si por defecto se debe mostrar o no la casilla "No volver a preguntar" para
* cachear el PIN. */
private transient final boolean defaultUseCache;
/** Si se muestra o no la casilla "No volver a preguntar" para cachear el PIN. */
private transient boolean useCache;
/** Crea una Callback para solicitar al usuario una contraseña
* mediante un diálogo gráfico. La contraseña no se
* retiene ni almacena internamente en ningún momento.
* @param prompt Texto del diálogo para solicitar la contraseña.
* @param parentComponent Componente padre para la modalidad del diálogo.
* @param dialogMessage Mensaje.
* @param textFieldMnemonic Mnemónico para el propio campo de texto.
* @param dialogTitle Título del diálogo.
* @param iconFileName Ruta hacia el icono del diálogo.
* @param allowDniCache Hace mostrarse la casilla para seleccionar el cacheo del PIN.
* @param defaultDniCache Valor por defecto de la opción de cacheo de PIN. */
public UIPasswordCallbackAccessibility(final String prompt,
final Component parentComponent,
final String dialogMessage,
final int textFieldMnemonic,
final String dialogTitle,
final String iconFileName,
final boolean allowDniCache,
final boolean defaultDniCache) {
super(prompt, false);
this.parent = parentComponent;
if (prompt != null) {
this.message = prompt;
}
else {
this.message = dialogMessage;
}
this.mnemonic = textFieldMnemonic;
this.title = dialogTitle;
this.iconPath = iconFileName;
this.allowUseCache = allowDniCache;
this.defaultUseCache = defaultDniCache;
this.useCache = false;
}
@Override
public char[] getPassword() {
PasswordResult result = InputPasswordSmartcardDialog.showInputPasswordDialog(
this.parent,
true, // Modal
this.message,
this.mnemonic,
this.title,
this.iconPath,
this.allowUseCache,
this.defaultUseCache
);
this.useCache = result.isUseCache();
final char[] password = result.getPassword();
result.clear();
result = null;
return password;
}
/** Indica si está establecido el uso de caché en el PIN.
* @return true
si está establecido el uso de caché en el PIN,
* false
en caso contrario. */
public boolean isUseCacheChecked() {
return this.useCache;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy