blob: a64ab620ab6c393f32ead0e70bf5652edcfe89e7 [file] [log] [blame]
/*
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*/
package org.apache.qpid.server.util;
import java.net.SocketAddress;
import java.util.Collections;
import java.util.Map;
import org.apache.commons.configuration.ConfigurationException;
import org.apache.qpid.server.configuration.ServerConfiguration;
import org.apache.qpid.server.configuration.plugins.ConfigurationPlugin;
import org.apache.qpid.server.logging.NullRootMessageLogger;
import org.apache.qpid.server.logging.actors.BrokerActor;
import org.apache.qpid.server.logging.actors.CurrentActor;
import org.apache.qpid.server.logging.actors.GenericActor;
import org.apache.qpid.server.plugins.PluginManager;
import org.apache.qpid.server.registry.ApplicationRegistry;
import org.apache.qpid.server.security.auth.database.PropertiesPrincipalDatabase;
import org.apache.qpid.server.security.auth.manager.AuthenticationManager;
import org.apache.qpid.server.security.auth.manager.IAuthenticationManagerRegistry;
import org.apache.qpid.server.security.auth.manager.PrincipalDatabaseAuthenticationManager;
import java.util.Properties;
public class TestApplicationRegistry extends ApplicationRegistry
{
public TestApplicationRegistry(ServerConfiguration config) throws ConfigurationException
{
super(config);
}
@Override
public void initialise() throws Exception
{
CurrentActor.setDefault(new BrokerActor(new NullRootMessageLogger()));
GenericActor.setDefaultMessageLogger(new NullRootMessageLogger());
super.initialise();
}
@Override
protected IAuthenticationManagerRegistry createAuthenticationManagerRegistry(
ServerConfiguration _configuration, PluginManager _pluginManager)
throws ConfigurationException
{
final Properties users = new Properties();
users.put("guest","guest");
users.put("admin","admin");
final PropertiesPrincipalDatabase ppd = new PropertiesPrincipalDatabase(users);
final AuthenticationManager pdam = new PrincipalDatabaseAuthenticationManager()
{
/**
* @see org.apache.qpid.server.security.auth.manager.PrincipalDatabaseAuthenticationManager#configure(org.apache.qpid.server.configuration.plugins.ConfigurationPlugin)
*/
@Override
public void configure(ConfigurationPlugin config) throws ConfigurationException
{
// We don't pass configuration to this test instance.
}
@Override
public void initialise()
{
setPrincipalDatabase(ppd);
super.initialise();
}
};
pdam.initialise();
return new IAuthenticationManagerRegistry()
{
@Override
public void close()
{
pdam.close();
}
@Override
public AuthenticationManager getAuthenticationManager(
SocketAddress address)
{
return pdam;
}
@Override
public Map<String, AuthenticationManager> getAvailableAuthenticationManagers()
{
return Collections.singletonMap(pdam.getClass().getName(), pdam);
}
@Override
public void addRegistryChangeListener(RegistryChangeListener listener)
{
}
};
}
}