protected void performRuntime(OperationContext context, ModelNode operation, ModelNode model, ServiceVerificationHandler verificationHandler, List<ServiceController<?>> newControllers)
throws OperationFailedException {
// Read the full model
ModelNode config = Resource.Tools.readModel(context.readResource(PathAddress.EMPTY_ADDRESS));
// Create the builder
HotRodServerConfigurationBuilder configurationBuilder = new HotRodServerConfigurationBuilder();
configureProtocolServer(configurationBuilder, config);
configureProtocolServerAuthentication(configurationBuilder, config);
configureProtocolServerEncryption(configurationBuilder, config);
configureProtocolServerTopology(configurationBuilder, config);
// Create the service
final ProtocolServerService service = new ProtocolServerService(getServiceName(operation), HotRodServer.class, configurationBuilder);
// Setup the various dependencies with injectors and install the service
final ServiceName hotRodServerServiceName = EndpointUtils.getServiceName(operation, "hotrod");
ServiceBuilder<?> builder = context.getServiceTarget().addService(hotRodServerServiceName, service);
String cacheContainerName = getCacheContainerName(operation);
EndpointUtils.addCacheContainerConfigurationDependency(builder, cacheContainerName, service.getCacheManagerConfiguration());
EndpointUtils.addCacheContainerDependency(builder, cacheContainerName, service.getCacheManager());
EndpointUtils.addCacheDependency(builder, cacheContainerName, null);
EndpointUtils.addSocketBindingDependency(builder, getSocketBindingName(operation), service.getSocketBinding());
if (config.hasDefined(ModelKeys.ENCRYPTION) && config.get(ModelKeys.ENCRYPTION, ModelKeys.ENCRYPTION_NAME).isDefined()) {
EndpointUtils.addSecurityRealmDependency(builder, config.get(ModelKeys.ENCRYPTION, ModelKeys.ENCRYPTION_NAME, ModelKeys.SECURITY_REALM).asString(), service.getEncryptionSecurityRealm());
}
if (config.hasDefined(ModelKeys.AUTHENTICATION) && config.get(ModelKeys.AUTHENTICATION, ModelKeys.AUTHENTICATION_NAME).isDefined()) {
ModelNode authentication = config.get(ModelKeys.AUTHENTICATION, ModelKeys.AUTHENTICATION_NAME);
EndpointUtils.addSecurityRealmDependency(builder, authentication.get(ModelKeys.SECURITY_REALM).asString(), service.getAuthenticationSecurityRealm());
if (authentication.hasDefined(ModelKeys.SASL) && authentication.get(ModelKeys.SASL, ModelKeys.SASL_NAME).isDefined()) {
AuthenticationConfigurationBuilder authenticationBuilder = configurationBuilder.authentication();
ModelNode sasl = authentication.get(ModelKeys.SASL, ModelKeys.SASL_NAME);
if (sasl.hasDefined(ModelKeys.SERVER_CONTEXT_NAME)) {
String serverContextName = sasl.get(ModelKeys.SERVER_CONTEXT_NAME).asString();
service.setServerContextName(serverContextName);
EndpointUtils.addSecurityDomainDependency(builder, serverContextName, service.getSaslSecurityDomain()); // FIXME: needed ???