
io.datakernel.launchers.rpc.RpcServerLauncher Maven / Gradle / Ivy
package io.datakernel.launchers.rpc;
import com.google.inject.Inject;
import com.google.inject.Module;
import com.google.inject.Provides;
import com.google.inject.Singleton;
import io.datakernel.async.Stage;
import io.datakernel.config.Config;
import io.datakernel.config.ConfigModule;
import io.datakernel.eventloop.Eventloop;
import io.datakernel.eventloop.ThrottlingController;
import io.datakernel.jmx.JmxModule;
import io.datakernel.launcher.Launcher;
import io.datakernel.rpc.server.RpcServer;
import io.datakernel.service.ServiceGraphModule;
import io.datakernel.trigger.TriggerRegistry;
import io.datakernel.trigger.TriggersModule;
import io.datakernel.util.Initializer;
import io.datakernel.util.guice.OptionalDependency;
import io.datakernel.util.guice.SimpleModule;
import java.util.Collection;
import static com.google.inject.util.Modules.combine;
import static com.google.inject.util.Modules.override;
import static io.datakernel.config.Config.ofProperties;
import static io.datakernel.launchers.Initializers.*;
import static java.lang.Boolean.parseBoolean;
import static java.util.Arrays.asList;
import static java.util.Collections.emptyList;
import static java.util.Collections.singletonList;
@SuppressWarnings("SimplifiableConditionalExpression")
public abstract class RpcServerLauncher extends Launcher {
public static final String EAGER_SINGLETONS_MODE = "eagerSingletonsMode";
public static final String PROPERTIES_FILE = "rpc-server.properties";
public static final String BUSINESS_MODULE_PROP = "businessLogicModule";
@Inject
RpcServer rpcServer;
@Override
protected final Collection getModules() {
return asList(
override(getBaseModules()).with(getOverrideModules()),
combine(getBusinessLogicModules()));
}
private Collection getBaseModules() {
return asList(
ServiceGraphModule.defaultInstance(),
JmxModule.create(),
TriggersModule.defaultInstance(),
ConfigModule.create(() ->
Config.create()
.override(ofProperties(PROPERTIES_FILE, true))
.override(ofProperties(System.getProperties()).getChild("config")))
.printEffectiveConfig(),
new SimpleModule() {
@Provides
@Singleton
public Eventloop provide(Config config,
OptionalDependency maybeThrottlingController,
TriggerRegistry triggerRegistry) {
return Eventloop.create()
.initialize(ofEventloop(config.getChild("eventloop")))
.initialize(ofEventloopTriggers(triggerRegistry, config.getChild("triggers.eventloop")))
.initialize(eventloop -> maybeThrottlingController.ifPresent(eventloop::withThrottlingController));
}
@Provides
@Singleton
RpcServer provideRpcServer(Config config, Eventloop eventloop, Initializer rpcServerInitializer) {
return RpcServer.create(eventloop)
.initialize(ofRpcServer(config))
.initialize(rpcServerInitializer);
}
}
);
}
protected Collection getOverrideModules() {
return emptyList();
}
protected abstract Collection getBusinessLogicModules();
@Override
protected void run() throws Exception {
awaitShutdown();
}
public static void main(String[] args) throws Exception {
String businessLogicModuleName = System.getProperty(BUSINESS_MODULE_PROP);
Module businessLogicModule = businessLogicModuleName != null ?
(Module) Class.forName(businessLogicModuleName).newInstance() :
new SimpleModule() {
@Provides
Initializer rpcServerInitializer() {
return server -> server
.withMessageTypes(String.class)
.withHandler(String.class, String.class,
req -> Stage.of("Request: " + req));
}
};
Launcher launcher = new RpcServerLauncher() {
@Override
protected Collection getBusinessLogicModules() {
return singletonList(businessLogicModule);
}
};
launcher.launch(parseBoolean(System.getProperty(EAGER_SINGLETONS_MODE)), args);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy