001 /*
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements. See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership. The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing,
013 * software distributed under the License is distributed on an
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
015 * KIND, either express or implied. See the License for the
016 * specific language governing permissions and limitations
017 * under the License.
018 */
019
020
021 package org.apache.geronimo.security.credentialstore;
022
023 import java.util.Map;
024 import java.util.HashMap;
025 import java.lang.reflect.Constructor;
026 import java.lang.reflect.InvocationTargetException;
027 import java.security.Principal;
028
029 import javax.security.auth.Subject;
030 import javax.security.auth.login.LoginException;
031
032 import org.apache.geronimo.common.DeploymentException;
033 import org.apache.geronimo.gbean.GBeanInfo;
034 import org.apache.geronimo.gbean.GBeanInfoBuilder;
035
036 /**
037 * Hopefully this will only be used for tests where you need to set up a simple credential store
038 * but don't want to set up a login configuration
039 *
040 * @version $Rev: 545781 $ $Date: 2007-06-09 13:44:02 -0400 (Sat, 09 Jun 2007) $
041 */
042 public class DirectConfigurationCredentialStoreImpl implements CredentialStore {
043
044 private final Map<String, Map<String, Subject>> subjectStore = new HashMap<String, Map<String, Subject>>();
045
046 public DirectConfigurationCredentialStoreImpl(Map<String, Map<String, Map<String, String>>> subjectInfo, ClassLoader cl) throws DeploymentException, ClassNotFoundException, NoSuchMethodException, IllegalAccessException, InvocationTargetException, InstantiationException {
047 if (cl == null) {
048 cl = getClass().getClassLoader();
049 }
050 for (Map.Entry<String, Map<String, Map<String, String>>> realmEntry: subjectInfo.entrySet()) {
051 Map<String, Subject> realm = new HashMap<String, Subject>();
052 for (Map.Entry<String, Map<String, String>> subjectEntry: realmEntry.getValue().entrySet()) {
053 String id = subjectEntry.getKey();
054 Map<String, String> principals = subjectEntry.getValue();
055 Subject subject = new Subject();
056 for (Map.Entry<String, String> principalInfo: principals.entrySet()) {
057 String className = principalInfo.getKey();
058 String principalName = principalInfo.getValue();
059 Class<? extends Principal> clazz = (Class<? extends Principal>) cl.loadClass(className);
060 Constructor<? extends Principal> c = clazz.getConstructor(new Class[] {String.class});
061 Principal p = c.newInstance(new Object[] {principalName});
062 subject.getPrincipals().add(p);
063 }
064 realm.put(id, subject);
065 }
066 subjectStore.put(realmEntry.getKey(), realm);
067 }
068 }
069
070 public Subject getSubject(String realm, String id) throws LoginException {
071 Map<String, Subject> realmMap = subjectStore.get(realm);
072 if (realmMap == null) {
073 throw new LoginException("Unknown realm : " + realm);
074 }
075 Subject subject = realmMap.get(id);
076 if (subject == null) {
077 throw new LoginException("Unknown id: " + id + " in realm: " + realm);
078 }
079 return subject;
080 }
081
082 public static final GBeanInfo GBEAN_INFO;
083
084 static {
085 GBeanInfoBuilder infoBuilder = GBeanInfoBuilder.createStatic(DirectConfigurationCredentialStoreImpl.class);
086
087 infoBuilder.addAttribute("credentialStore", Map.class, true);
088 infoBuilder.addAttribute("classLoader", ClassLoader.class, false);
089
090 infoBuilder.setConstructor(new String[]{"credentialStore", "classLoader"});
091
092 GBEAN_INFO = infoBuilder.getBeanInfo();
093 }
094
095 public static GBeanInfo getGBeanInfo() {
096 return GBEAN_INFO;
097 }
098
099 }