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

com.romanpierson.vertx.web.accesslogger.configuration.element.impl.DurationElement Maven / Gradle / Ivy

/*
 * Copyright (c) 2016-2024 Roman Pierson
 * ------------------------------------------------------
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Apache License v2.0 
 * which accompanies this distribution.
 *
 *     The Apache License v2.0 is available at
 *     http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */
package com.romanpierson.vertx.web.accesslogger.configuration.element.impl;

import java.util.ArrayList;
import java.util.Collection;

import com.romanpierson.vertx.web.accesslogger.AccessLoggerConstants.Request.Data;
import com.romanpierson.vertx.web.accesslogger.configuration.element.AccessLogElement;
import com.romanpierson.vertx.web.accesslogger.configuration.pattern.ExtractedPosition;
import static com.romanpierson.vertx.web.accesslogger.configuration.pattern.PatternResolver.extractBestPositionFromFixPatternIfApplicable;

import io.vertx.core.json.JsonObject;

public class DurationElement implements AccessLogElement{

	private enum TimeUnit{
		
		SECONDS,
		MILLISECONDS
		
	}
	
	private TimeUnit timeUnit;
	
	public static DurationElement of(final TimeUnit timeUnit){
		
		DurationElement element = new DurationElement();
		element.timeUnit = timeUnit;
		
		return element;
	}
	
	
	@Override
	public Collection findInRawPatternInternal(final String rawPattern) {
		
		Collection foundPositions = new ArrayList<>(2);
		
		extractBestPositionFromFixPatternIfApplicable(rawPattern, "%D", () -> DurationElement.of(TimeUnit.MILLISECONDS)).ifPresent(foundPositions::add);
		extractBestPositionFromFixPatternIfApplicable(rawPattern, "%T", () -> DurationElement.of(TimeUnit.SECONDS)).ifPresent(foundPositions::add);
		
		return foundPositions;
	}
	
	@Override
	public Object getNativeValue(final JsonObject values) {
		
		final Long startTS = values.getLong(Data.Type.START_TS_MILLIS.getFieldName());
		final Long endTS = values.getLong(Data.Type.END_TS_MILLIS.getFieldName());
		
		long duration = endTS.longValue() - startTS.longValue();
		
		if(TimeUnit.SECONDS.equals(this.timeUnit)){
			duration = duration / 1000;
		}
		
		return duration > 0 ? duration : Long.valueOf(0);
	}
	

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy