org.jboss.as.clustering.controller.OperationHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of wildfly-clustering-common Show documentation
Show all versions of wildfly-clustering-common Show documentation
The code in this module is not explicitly related to clustering, but rather contains resuable code used by clustering modules
and any modules that integrate with clustering.
The newest version!
/*
* Copyright The WildFly Authors
* SPDX-License-Identifier: Apache-2.0
*/
package org.jboss.as.clustering.controller;
import java.util.Arrays;
import java.util.Collection;
import java.util.EnumSet;
import java.util.HashMap;
import java.util.Map;
import org.jboss.as.controller.AbstractRuntimeOnlyHandler;
import org.jboss.as.controller.OperationContext;
import org.jboss.as.controller.OperationFailedException;
import org.jboss.as.controller.descriptions.ModelDescriptionConstants;
import org.jboss.as.controller.registry.ManagementResourceRegistration;
import org.jboss.dmr.ModelNode;
/**
* Generic {@link org.jboss.as.controller.OperationStepHandler} for runtime operations.
* @author Paul Ferraro
*/
public class OperationHandler extends AbstractRuntimeOnlyHandler implements ManagementRegistrar {
private final Collection extends Operation> operations;
private final Map> executables = new HashMap<>();
private final OperationExecutor executor;
public & Operation> OperationHandler(OperationExecutor executor, Class operationClass) {
this(executor, EnumSet.allOf(operationClass));
}
public OperationHandler(OperationExecutor executor, Operation[] operations) {
this(executor, Arrays.asList(operations));
}
public OperationHandler(OperationExecutor executor, Collection extends Operation> operations) {
this.executor = executor;
for (Operation executable : operations) {
this.executables.put(executable.getName(), executable);
}
this.operations = operations;
}
@Override
public void register(ManagementResourceRegistration registration) {
for (Operation operation : this.operations) {
registration.registerOperationHandler(operation.getDefinition(), this);
}
}
@Override
protected void executeRuntimeStep(OperationContext context, ModelNode operation) {
String name = operation.get(ModelDescriptionConstants.OP).asString();
Operation executable = this.executables.get(name);
try {
ModelNode result = this.executor.execute(context, operation, executable);
if (result != null) {
context.getResult().set(result);
}
} catch (OperationFailedException e) {
context.getFailureDescription().set(e.getLocalizedMessage());
}
context.completeStep(OperationContext.ResultHandler.NOOP_RESULT_HANDLER);
}
}