001 /**
002 *
003 * Copyright 2003-2004 The Apache Software Foundation
004 *
005 * Licensed under the Apache License, Version 2.0 (the "License");
006 * you may not use this file except in compliance with the License.
007 * You may obtain a copy of the License at
008 *
009 * http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017 package org.apache.geronimo.security.jaas;
018
019 import java.io.Externalizable;
020 import java.io.Serializable;
021 import java.rmi.Remote;
022 import java.util.HashMap;
023 import java.util.HashSet;
024 import java.util.Iterator;
025 import java.util.Map;
026 import java.util.Set;
027 import javax.security.auth.Subject;
028
029 import org.apache.geronimo.security.jaas.server.JaasLoginModuleConfiguration;
030
031
032 /**
033 * Helper class the computes the login result across a number of separate
034 * login modules.
035 *
036 * @version $Rev: 355877 $ $Date: 2005-12-10 18:48:27 -0800 (Sat, 10 Dec 2005) $
037 */
038 public class LoginUtils {
039 public static void copyPrincipals(Subject to, Subject from) {
040 to.getPrincipals().addAll(from.getPrincipals());
041 }
042
043 public static Map getSerializableCopy(Map from) {
044 Map to = new HashMap();
045 for (Iterator it = from.keySet().iterator(); it.hasNext();) {
046 String key = (String) it.next();
047 Object value = from.get(key);
048 if (value instanceof Serializable || value instanceof Externalizable || value instanceof Remote) {
049 to.put(key, value);
050 }
051 }
052 return to;
053 }
054
055 public static Set getSerializableCopy(Set from) {
056 Set to = new HashSet();
057 for (Iterator it = from.iterator(); it.hasNext();) {
058 Object value = it.next();
059 if (value instanceof Serializable || value instanceof Externalizable || value instanceof Remote) {
060 to.add(value);
061 }
062 }
063 return to;
064 }
065
066 /**
067 * Strips out stuff that isn't serializable so this can be safely passed to
068 * a remote server.
069 */
070 public static JaasLoginModuleConfiguration getSerializableCopy(JaasLoginModuleConfiguration config) {
071 return new JaasLoginModuleConfiguration(config.getLoginModuleClassName(),
072 config.getFlag(),
073 LoginUtils.getSerializableCopy(config.getOptions()),
074 config.isServerSide(),
075 config.getLoginDomainName(),
076 config.isWrapPrincipals(),
077 null);
078 }
079 }