All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.anotheria.anosite.handler.BoxHandlerProducer Maven / Gradle / Ivy

The newest version!
package net.anotheria.anosite.handler;

import net.anotheria.anosite.content.bean.BoxBean;
import net.anotheria.anosite.gen.aswebdata.data.Box;
import net.anotheria.anosite.util.AnositeConstants;
import net.anotheria.moskito.core.calltrace.CurrentlyTracedCall;
import net.anotheria.moskito.core.calltrace.RunningTraceContainer;
import net.anotheria.moskito.core.calltrace.TraceStep;
import net.anotheria.moskito.core.calltrace.TracedCall;
import net.anotheria.moskito.core.context.CurrentMeasurement;
import net.anotheria.moskito.core.context.MoSKitoContext;
import net.anotheria.moskito.core.predefined.ActionStats;
import net.anotheria.moskito.core.predefined.Constants;
import net.anotheria.moskito.core.producers.IStats;
import net.anotheria.moskito.core.producers.IStatsProducer;
import net.anotheria.moskito.core.registry.ProducerRegistryFactory;
import net.anotheria.moskito.core.stats.Interval;

import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.List;

/**
 * A stats producer for boxhandler for embedding into moskito.
 * @author another
 *
 */
public class BoxHandlerProducer implements IStatsProducer {
	/**
	 * The id of the producer.
	 */
	private String producerId;
	/**
	 * Stats for process method.
	 */
	private ActionStats processStats;
	/**
	 * Stats for submit method.
	 */
	private ActionStats submitStats;
	/**
	 * Cached list with stats.
	 */
	private final List myStats;
	
	public BoxHandlerProducer (String aProducerId){
		producerId = aProducerId;
		
		processStats = new ActionStats("process", getMonitoringIntervals());
		submitStats = new ActionStats("submit", getMonitoringIntervals());
		
		myStats = new ArrayList();
		myStats.add(processStats);
		myStats.add(submitStats);
		
		ProducerRegistryFactory.getProducerRegistryInstance().registerProducer(this);
	}
	
	protected Interval[] getMonitoringIntervals(){
		return Constants.getDefaultIntervals();
	}
	
	@Override public String getCategory() {
		return "box-handler";
	}

	@Override public String getProducerId() {
		return producerId;
	}

	@Override public List getStats() {
		return myStats;
	}

	@Override public String getSubsystem() {
		return AnositeConstants.AS_MOSKITO_SUBSYSTEM;
	}
	
	BoxHandlerResponse process(HttpServletRequest req, HttpServletResponse res, Box box, BoxBean bean, BoxHandler target){
		MoSKitoContext moSKitoContext = MoSKitoContext.get();
		CurrentMeasurement cm = moSKitoContext.notifyProducerEntry(this);
		if (cm.isFirst()){
			cm.setCallDescription("process Box: "+box.getName()+" ["+box.getId()+"]");
		}

		processStats.addRequest();
		long startTime = System.nanoTime();
		TracedCall aRunningUseCase = RunningTraceContainer.getCurrentlyTracedCall();
		TraceStep currentElement = null;
		CurrentlyTracedCall runningUseCase = aRunningUseCase.callTraced() ? 
				(CurrentlyTracedCall)aRunningUseCase : null;
		if (runningUseCase !=null)
			currentElement = runningUseCase.startStep(new StringBuilder(getProducerId()).append('.').append("process").toString(), this, "process");
		try {
			return target.process(req, res, box, bean);
		}  catch (Exception e) {
			processStats.notifyError();
			return new ResponseAbort(e);
		} finally {
			long duration = System.nanoTime() - startTime;

			moSKitoContext.notifyProducerExit(this);
			cm.notifyProducerFinished();

			processStats.addExecutionTime(duration);
			processStats.notifyRequestFinished();
			if (currentElement!=null)
				currentElement.setDuration(duration);
			if (runningUseCase !=null)
				runningUseCase.endStep();
		}
		
	}
	
	BoxHandlerResponse submit(HttpServletRequest req, HttpServletResponse res, Box box, BoxHandler target){
		MoSKitoContext moSKitoContext = MoSKitoContext.get();
		CurrentMeasurement cm = moSKitoContext.notifyProducerEntry(this);
		if (cm.isFirst()){//actually a box should never be first producer.
			cm.setCallDescription("submit Box: "+box.getName()+" ["+box.getId()+"]");
		}

		submitStats.addRequest();
		long startTime = System.nanoTime();
		TracedCall aRunningUseCase = RunningTraceContainer.getCurrentlyTracedCall();
		TraceStep currentElement = null;
		CurrentlyTracedCall runningUseCase = aRunningUseCase.callTraced() ? 
				(CurrentlyTracedCall)aRunningUseCase : null; 
		if (runningUseCase !=null)
			currentElement = runningUseCase.startStep(new StringBuilder(getProducerId()).append('.').append("submit").toString(), this, "submit");
		try {
			return target.submit(req, res, box);
		}  catch (Exception e) {
			processStats.notifyError();
			return new ResponseAbort(e);
		} finally {
			long duration = System.nanoTime() - startTime;

			moSKitoContext.notifyProducerExit(this);

			submitStats.addExecutionTime(duration);
			submitStats.notifyRequestFinished();
			if (currentElement!=null)
				currentElement.setDuration(duration);
			if (runningUseCase !=null)
				runningUseCase.endStep();
		}
		
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy