package com.trusteq.test;
import java.util.HashMap;
import java.util.Map;
import java.util.Iterator;
import javax.security.auth.Subject;
import javax.security.auth.callback.Callback;
import javax.security.auth.callback.PasswordCallback;
import javax.security.auth.login.LoginException;
import com.sun.identity.authentication.spi.AMLoginModule;
import com.sun.identity.authentication.spi.AuthLoginException;
import com.sun.identity.authentication.spi.RedirectCallback;
import com.sun.identity.wss.security.SecurityPrincipal;
import com.iplanet.am.util.Debug;
public class LoginModuleSample extends AMLoginModule {
    private String userTokenId;
    private String userName = "test";
    private String userPassword;
    private String status;
    private java.security.Principal userPrincipal = null;
    private static final String amAuthLoginModuleSample = "amAuthLoginModuleSample";
    private static Debug debug = Debug.getInstance(amAuthLoginModuleSample);
        
    public LoginModuleSample() throws LoginException{
        debug.message("LoginModuleSample()");
    }
    public void init(Subject subject, Map sharedState, Map options) {
        debug.message("LoginModuleSample initialization");
    } 
    public int process(Callback[] callbacks, int state) throws AuthLoginException {
        int currentState = state;
        debug.message("LoginModuleSample process");
        if (currentState == 1) {
            
            userPassword = charToString(((PasswordCallback)
                    callbacks[1]).getPassword(), callbacks[1]);
            debug.message("userName : " + userName);
            debug.message("userPassword : " + userPassword);
            
            if (userName.length() == 0 || userPassword.length() == 0) {
                throw new AuthLoginException("names must not be empty");
            }            
            
            if (userPassword != null && userPassword.equals("payit")) {
                debug.message("Replace redirect data with : " + userName);
                // set #REPLACE# text in next state
                Callback[] callbacks2 = getCallback(2);
                RedirectCallback rc = (RedirectCallback)callbacks2[0];
                Map redirectdata = rc.getRedirectData();
                debug.message("Old RedirectData : " + redirectdata);
                Map newRedirectData = new HashMap();
                if (redirectdata != null) {
                    for (Iterator nvp = redirectdata.entrySet().iterator(); 
                        nvp.hasNext();) {
                        Map.Entry me = (Map.Entry)nvp.next();
                        String key = (String) me.getKey();
                        String value = (String) me.getValue();                    
                        int i = value.indexOf("#REPLACE#");
                        String newValue = value;
                        if (i != -1) {
                            newValue = userName;
                        }
                        newRedirectData.put(key,newValue);
                    }
                } 
                debug.message("newRedirectData : " + newRedirectData);
                RedirectCallback rcNew = new RedirectCallback(rc.getRedirectUrl(),
                    newRedirectData,
                    rc.getMethod(),
                    rc.getStatusParameter(),
                    rc.getRedirectBackUrlCookieName());
            
                replaceCallback(2, 0, rcNew);
                       
                return 2;
            } else {
                userTokenId = userName;
                // return -1 for login successful
                return -1;
            }
        } else if (currentState == 2) {
            RedirectCallback rc1 = (RedirectCallback) callbacks[0];
            status = rc1.getStatus();
            debug.message("LoginModuleSample status :" + status);
            if (status != null && status.equals(rc1.SUCCESS)) {
                userTokenId = userName;
                // return -1 for login successful
                return -1;
            } else {
                throw new AuthLoginException("FAILED"); 
            }
        } 
        throw new AuthLoginException("Invalid state : " + currentState);       
    }
    
    public java.security.Principal getPrincipal() {
        if (userPrincipal != null) {
            return userPrincipal;
        } else if (userTokenId != null) {
            userPrincipal = new SecurityPrincipal(userTokenId);
            return userPrincipal;
        } else {
            return null;
        }
    }
    
    private String charToString(char[] tmpPassword, Callback cbk) {
        if (tmpPassword == null) {
            // treat a NULL password as an empty password
            tmpPassword = new char[0];
        }
        char[] pwd = new char[tmpPassword.length];
        System.arraycopy(tmpPassword, 0, pwd, 0, tmpPassword.length);
        ((PasswordCallback) cbk).clearPassword();
        return new String(pwd);
    }
}
Binary Search Tree
9 years ago
 
