/*
* Copyright 2011-2013 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.xd.analytics.metrics.integration;
import java.text.ParseException;
import org.joda.time.format.DateTimeFormat;
import org.joda.time.format.DateTimeFormatter;
import org.joda.time.format.ISODateTimeFormat;
import org.springframework.expression.Expression;
import org.springframework.messaging.Message;
import org.springframework.util.Assert;
import org.springframework.xd.analytics.metrics.core.AggregateCounterRepository;
/**
* Handles incoming messages for the {@code aggregate-counter} module, resolves SpEL expressions
* as needed and delegate the heavy lifting to an {@link AggregateCounterRepository}.
*
* @author Luke Taylor
* @author Eric Bottard
*/
public class AggregateCounterHandler extends AbstractMetricHandler {
private final AggregateCounterRepository aggregateCounterRepository;
private DateTimeFormatter dateFormat = ISODateTimeFormat.dateTime();
private final Expression incrementExpression;
public AggregateCounterHandler(AggregateCounterRepository aggregateCounterRepository, String nameExpression,
String incrementExpression) {
super(nameExpression);
Assert.notNull(aggregateCounterRepository, "Aggregate Counter Repository can not be null");
Assert.notNull(incrementExpression, "Increment expression can not be null");
this.aggregateCounterRepository = aggregateCounterRepository;
this.incrementExpression = spelExpressionParser.parseExpression(incrementExpression);
}
public void setDateFormat(String pattern) {
Assert.hasText(pattern, "dateFormat pattern must not be empty");
this.dateFormat = DateTimeFormat.forPattern(pattern);
}
public Message<?> process(Message<?> message, String timeField) throws ParseException {
if (message == null) {
return null;
}
Double increment = incrementExpression.getValue(evaluationContext, message, Double.class);
String counterName = computeMetricName(message);
if (timeField == null) {
this.aggregateCounterRepository.increment(counterName, increment.longValue());
}
else {
this.aggregateCounterRepository.increment(counterName, increment.longValue(),
dateFormat.parseDateTime(timeField));
}
return message;
}
}