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

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