/*
* 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.openejb.maven.plugin;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugin.logging.Log;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.openejb.assembler.Deployer;
import org.apache.openejb.assembler.classic.AppInfo;
import org.apache.openejb.assembler.classic.EjbJarInfo;
import org.apache.openejb.assembler.classic.EnterpriseBeanInfo;
import org.apache.openejb.table.Line;
import org.apache.openejb.table.Lines;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.util.Arrays;
import java.util.Collection;
/**
* Highly inspired from openejb command helper but with some different data.
* List deployed EJB in a running TomEE.
*/
@Mojo(name = "list")
public class ListEjbMojo extends AbstractCommandMojo {
@Override
public void execute() throws MojoExecutionException, MojoFailureException {
final Deployer deployer = (Deployer) lookup("openejb/DeployerBusinessRemote");
final Collection<AppInfo> infos = deployer.getDeployedApps();
final Lines lines = new Lines();
lines.add(new Line("Name", "Class", "Interface Type", "Bean Type"));
for (final AppInfo info : infos) {
for (final EjbJarInfo ejbJar : info.ejbJars) {
for (final EnterpriseBeanInfo bean : ejbJar.enterpriseBeans) {
lines.add(new Line(bean.ejbDeploymentId, bean.ejbClass, getType(bean), componentType(bean)));
}
}
}
lines.print(new LogPrinterStream(getLog()));
}
private static String componentType(final EnterpriseBeanInfo bean) {
return bean.getClass().getSimpleName().replace("Info", "").replace("Bean", " Bean");
}
private static String getType(final EnterpriseBeanInfo bc) {
boolean empty = true;
final StringBuilder sb = new StringBuilder();
if (bc.localbean) {
sb.append("Local Bean");
empty = false;
}
if (bc.businessLocal != null && !bc.businessLocal.isEmpty()) {
if (!empty) {
sb.append(", ");
}
sb.append("Local").append(Arrays.asList(bc.businessLocal));
empty = false;
}
if (bc.businessRemote != null && !bc.businessRemote.isEmpty()) {
if (!empty) {
sb.append(", ");
}
sb.append("Remote").append(Arrays.asList(bc.businessRemote));
}
return sb.toString();
}
private static class LogPrinterStream extends PrintStream {
private Log logger;
public LogPrinterStream(final Log log) {
super(new NullOuputStream());
logger = log;
}
@Override
public void print(final String s) {
logger.info(s.replace(System.getProperty("line.separator"), ""));
}
private static class NullOuputStream extends OutputStream {
@Override
public void write(final int b) throws IOException {
// no-op
}
}
}
}