be.fedict.hsm.ws.impl.NamePasswordCallbackHandler.java Source code

Java tutorial

Introduction

Here is the source code for be.fedict.hsm.ws.impl.NamePasswordCallbackHandler.java

Source

/*
 * HSM Proxy Project.
 * Copyright (C) 2013 Frank Cornelis.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License version
 * 3.0 as published by the Free Software Foundation.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, see 
 * http://www.gnu.org/licenses/.
 */

package be.fedict.hsm.ws.impl;

import java.io.IOException;

import javax.security.auth.callback.Callback;
import javax.security.auth.callback.CallbackHandler;
import javax.security.auth.callback.NameCallback;
import javax.security.auth.callback.PasswordCallback;
import javax.security.auth.callback.UnsupportedCallbackException;

import org.apache.commons.codec.binary.Hex;
import org.apache.commons.codec.digest.DigestUtils;

/**
 * JAAS callback handler based on the application X509 credential.
 * 
 * @author Frank Cornelis
 * 
 */
public class NamePasswordCallbackHandler implements CallbackHandler {

    private final String name;
    private final char[] password;

    public NamePasswordCallbackHandler(byte[] encodedCertificate) {
        this.name = DigestUtils.sha1Hex(encodedCertificate);
        this.password = Hex.encodeHex(encodedCertificate);
    }

    @Override
    public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
        for (Callback callback : callbacks) {
            if (callback instanceof NameCallback) {
                NameCallback nameCallback = (NameCallback) callback;
                nameCallback.setName(this.name);
            } else if (callback instanceof PasswordCallback) {
                PasswordCallback passwordCallback = (PasswordCallback) callback;
                passwordCallback.setPassword(this.password);
            }
        }
    }
}