
com.yammer.dropwizard.AbstractService Maven / Gradle / Ivy
package com.yammer.dropwizard;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.yammer.dropwizard.cli.Command;
import com.yammer.dropwizard.cli.ConfiguredCommand;
import com.yammer.dropwizard.cli.ServerCommand;
import com.yammer.dropwizard.cli.UsagePrinter;
import com.yammer.dropwizard.config.Configuration;
import com.yammer.dropwizard.config.Environment;
import com.yammer.dropwizard.config.LoggingFactory;
import java.lang.reflect.ParameterizedType;
import java.util.Arrays;
import java.util.List;
import java.util.SortedMap;
/**
* The base class for both Java and Scala services. Do not extend this directly. Use {@link Service}
* instead.
*
* @param the type of configuration class for this service
*/
@SuppressWarnings("EmptyMethod")
public abstract class AbstractService {
static {
// make sure spinning up Hibernate Validator doesn't yell at us
LoggingFactory.bootstrap();
}
private final String name;
private final List bundles;
private final List> configuredBundles;
private final SortedMap commands;
/**
* Creates a new service with the given name.
*
* @param name the service's name
*/
protected AbstractService(String name) {
this.name = name;
this.bundles = Lists.newArrayList();
this.configuredBundles = Lists.newArrayList();
this.commands = Maps.newTreeMap();
addCommand(new ServerCommand(getConfigurationClass()));
}
/**
* A simple reminder that this particular class isn't meant to be extended by non-DW classes.
*/
protected abstract void subclassServiceInsteadOfThis();
public final String getName() {
return name;
}
/**
* Returns the {@link Class} of the configuration class type parameter.
*
* @return the configuration class
* @see Super Type Tokens
*/
@SuppressWarnings("unchecked")
public final Class getConfigurationClass() {
return (Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
}
/**
* Registers a {@link Bundle} to be used in initializing the service's {@link Environment}.
*
* @param bundle a bundle
* @see Bundle
*/
protected final void addBundle(Bundle bundle) {
bundles.add(bundle);
}
/**
* Registers a {@link ConfiguredBundle} to be used in initializing the service's
* {@link Environment}.
*
* @param bundle a bundle
* @see ConfiguredBundle
*/
protected final void addBundle(ConfiguredBundle super T> bundle) {
configuredBundles.add(bundle);
}
/**
* Returns a list of registered {@link Command} instances.
*
* @return a list of commands
*/
public final ImmutableList getCommands() {
return ImmutableList.copyOf(commands.values());
}
/**
* Registers a {@link Command} which the service will provide.
*
* @param command a command
*/
protected final void addCommand(Command command) {
commands.put(command.getName(), command);
}
/**
* Registers a {@link ConfiguredCommand} which the service will provide.
*
* @param command a command
*/
protected final void addCommand(ConfiguredCommand command) {
commands.put(command.getName(), command);
}
/**
* When the service runs, this is called after the {@link Bundle}s are run. Override it to add
* providers, resources, etc. for your service.
*
* @param configuration the parsed {@link Configuration} object
* @param environment the service's {@link Environment}
* @throws Exception if something goes wrong
*/
protected abstract void initialize(T configuration, Environment environment) throws Exception;
/**
* Initializes the given {@link Environment} given a {@link Configuration} instances. First the
* bundles are initialized in the order they were added, then the service's
* {@link #initialize(Configuration, Environment)} method is called.
*
* @param configuration the parsed {@link Configuration} object
* @param environment the service's {@link Environment}
* @throws Exception if something goes wrong
*/
public final void initializeWithBundles(T configuration, Environment environment) throws Exception {
for (Bundle bundle : bundles) {
bundle.initialize(environment);
}
for (ConfiguredBundle super T> bundle : configuredBundles) {
bundle.initialize(configuration, environment);
}
initialize(configuration, environment);
}
/**
* Parses command-line arguments and runs the service. Call this method from a
* {@code public static void main} entry point in your application.
*
* @param arguments the command-line arguments
* @throws Exception if something goes wrong
*/
public final void run(String[] arguments) throws Exception {
if (isHelp(arguments)) {
UsagePrinter.printRootHelp(this);
} else {
final Command cmd = commands.get(arguments[0]);
if (cmd != null) {
cmd.run(this, Arrays.copyOfRange(arguments, 1, arguments.length));
} else {
UsagePrinter.printRootHelp(this);
}
}
}
private static boolean isHelp(String[] arguments) {
return (arguments.length == 0) ||
((arguments.length == 1) &&
("-h".equals(arguments[0]) ||
"--help".equals(arguments[0])));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy