/**
* 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.activemq.apollo.amqp.joram;
import org.apache.activemq.apollo.broker.Broker;
import org.apache.activemq.apollo.broker.BrokerFactory;
import org.apache.activemq.apollo.util.ServiceControl;
import org.apache.qpid.amqp_1_0.jms.impl.ConnectionFactoryImpl;
import org.apache.qpid.amqp_1_0.jms.impl.QueueImpl;
import org.apache.qpid.amqp_1_0.jms.impl.TopicImpl;
import org.objectweb.jtests.jms.admin.Admin;
import javax.jms.ConnectionFactory;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
import java.net.InetSocketAddress;
import java.util.Hashtable;
import java.util.logging.*;
/**
*
* @author <a href="http://hiramchirino.com">Hiram Chirino</a>
*/
public class ApolloAdmin implements Admin {
Context context;
{
// enableJMSFrameTracing();
try {
// Use the jetty JNDI context since it's mutable.
final Hashtable<String, String> env = new Hashtable<String, String>();
env.put("java.naming.factory.initial", "org.eclipse.jetty.jndi.InitialContextFactory");
env.put("java.naming.factory.url.pkgs", "org.eclipse.jetty.jndi");;
context = new InitialContext(env);
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
static public void enableJMSFrameTracing() throws FileNotFoundException {
final SimpleFormatter formatter = new SimpleFormatter();
final PrintStream out = new PrintStream(new FileOutputStream(new File("/tmp/amqp-trace.txt")));
Handler handler = new Handler() {
@Override
public void publish(LogRecord r) {
out.println(String.format("%s:%s", r.getLoggerName(), r.getMessage()));
}
@Override
public void flush() {
out.flush();
}
@Override
public void close() throws SecurityException {
}
};
Logger log = Logger.getLogger("FRM");
log.addHandler(handler);
log.setLevel(Level.FINEST);
}
public String brokerConfig = "xml:classpath:apollo-amqp.xml";
public String getName() {
return getClass().getName();
}
static Broker broker;
static int port;
public void startServer() throws Exception {
// if( broker!=null ) {
// stopServer();
// }
broker = createBroker();
ServiceControl.start(broker);
port = ((InetSocketAddress) broker.get_socket_address()).getPort();
}
protected Broker createBroker() throws Exception {
if (System.getProperty("basedir") == null) {
File file = new File(".");
System.setProperty("basedir", file.getAbsolutePath());
}
return BrokerFactory.createBroker(brokerConfig);
}
public void stopServer() throws Exception {
ServiceControl.stop(broker);
broker = null;
}
public void start() throws Exception {
}
public void stop() throws Exception {
}
public Context createContext() throws NamingException {
return context;
}
public void createQueue(String name) {
try {
context.bind(name, new QueueImpl("queue://"+name));
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void createTopic(String name) {
try {
context.bind(name, new TopicImpl("topic://"+name));
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void deleteQueue(String name) {
// BrokerTestSupport.delete_queue((Broker)base.broker, name);
try {
context.unbind(name);
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void deleteTopic(String name) {
try {
context.unbind(name);
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void createConnectionFactory(String name) {
try {
final ConnectionFactory factory = new ConnectionFactoryImpl("localhost", port, null, null);
context.bind(name, factory);
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void deleteConnectionFactory(String name) {
try {
context.unbind(name);
} catch (NamingException e) {
throw new RuntimeException(e);
}
}
public void createQueueConnectionFactory(String name) {
createConnectionFactory(name);
}
public void createTopicConnectionFactory(String name) {
createConnectionFactory(name);
}
public void deleteQueueConnectionFactory(String name) {
deleteConnectionFactory(name);
}
public void deleteTopicConnectionFactory(String name) {
deleteConnectionFactory(name);
}
}