org.jboss.as.clustering.controller.MetricHandler 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 metrics.
* @author Paul Ferraro
*/
public class MetricHandler extends AbstractRuntimeOnlyHandler implements ManagementRegistrar {
private final Collection extends Metric> metrics;
private final Map> executables = new HashMap<>();
private final Executor> executor;
public & Metric> MetricHandler(MetricExecutor executor, Class metricClass) {
this(executor, EnumSet.allOf(metricClass));
}
public MetricHandler(MetricExecutor executor, Metric[] metrics) {
this(executor, Arrays.asList(metrics));
}
public MetricHandler(MetricExecutor executor, Collection extends Metric> metrics) {
this.executor = executor;
for (Metric executable : metrics) {
this.executables.put(executable.getName(), executable);
}
this.metrics = metrics;
}
@Override
public void register(ManagementResourceRegistration registration) {
for (Metric metric : this.metrics) {
registration.registerMetric(metric.getDefinition(), this);
}
}
@Override
protected void executeRuntimeStep(OperationContext context, ModelNode operation) {
String name = operation.get(ModelDescriptionConstants.NAME).asString();
Metric executable = this.executables.get(name);
try {
ModelNode result = this.executor.execute(context, executable);
if (result != null) {
context.getResult().set(result);
}
} catch (OperationFailedException e) {
context.getFailureDescription().set(e.getLocalizedMessage());
}
context.completeStep(OperationContext.ResultHandler.NOOP_RESULT_HANDLER);
}
}