org.hawkular.apm.server.jms.TraceCompletionStoreMDB Maven / Gradle / Ivy
/*
* Copyright 2015-2016 Red Hat, Inc. and/or its affiliates
* and other contributors as indicated by the @author tags.
*
* 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.hawkular.apm.server.jms;
import java.util.List;
import javax.annotation.PostConstruct;
import javax.ejb.ActivationConfigProperty;
import javax.ejb.MessageDriven;
import javax.inject.Inject;
import javax.jms.MessageListener;
import org.hawkular.apm.api.model.events.CompletionTime;
import org.hawkular.apm.api.services.AnalyticsService;
import org.hawkular.apm.api.services.StoreException;
import org.hawkular.apm.server.api.task.AbstractProcessor;
import org.hawkular.apm.server.api.task.Processor.ProcessorType;
import org.hawkular.apm.server.api.task.RetryAttemptException;
import com.fasterxml.jackson.core.type.TypeReference;
/**
* @author gbrown
*/
@MessageDriven(name = "TraceCompletions_Store", messageListenerInterface = MessageListener.class, activationConfig = {
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Topic"),
@ActivationConfigProperty(propertyName = "destination", propertyValue = "TraceCompletions"),
@ActivationConfigProperty(propertyName = "subscriptionDurability", propertyValue = "Durable"),
@ActivationConfigProperty(propertyName = "clientID", propertyValue = TraceCompletionStoreMDB.SUBSCRIBER),
@ActivationConfigProperty(propertyName = "subscriptionName", propertyValue = TraceCompletionStoreMDB.SUBSCRIBER),
@ActivationConfigProperty(propertyName = "messageSelector", propertyValue = "subscriber IS NULL OR subscriber = '"+TraceCompletionStoreMDB.SUBSCRIBER+"'")
})
public class TraceCompletionStoreMDB extends RetryCapableMDB {
@Inject
private TraceCompletionPublisherJMS traceCompletionTimePublisher;
@Inject
private AnalyticsService analyticsService;
public static final String SUBSCRIBER = "TraceCompletionStore";
public TraceCompletionStoreMDB() {
super(SUBSCRIBER);
}
@PostConstruct
public void init() {
setRetryPublisher(traceCompletionTimePublisher);
setTypeReference(new TypeReference>() {
});
setProcessor(new AbstractProcessor(ProcessorType.ManyToMany) {
@Override
public List processManyToMany(String tenantId, List items)
throws RetryAttemptException {
try {
analyticsService.storeTraceCompletions(tenantId, items);
} catch (StoreException se) {
throw new RetryAttemptException(se);
}
return null;
}
});
}
}