data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
org.jsoftware.restclient.plugins.RequestTimePlugin Maven / Gradle / Ivy
The newest version!
package org.jsoftware.restclient.plugins;
import org.apache.http.client.methods.HttpRequestBase;
import org.jetbrains.annotations.TestOnly;
import org.jsoftware.restclient.RestClientPlugin;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.time.Clock;
/**
* Log response time.
* @author szalik
*/
public class RequestTimePlugin implements RestClientPlugin {
private final Clock clock;
private final Logger logger = LoggerFactory.getLogger(getClass());
public RequestTimePlugin() {
this(Clock.systemDefaultZone());
}
@TestOnly
protected RequestTimePlugin(Clock clock) {
this.clock = clock;
}
@Override
public void plugin(PluginContext context, PluginChain chain) throws Exception {
long start = clock.millis();
try {
chain.continueChain();
} finally {
long time = clock.millis() - start;
HttpRequestBase request = context.getRequest();
logTime(request, time);
}
}
protected void logTime(HttpRequestBase request, long timeMs) {
logger.info("Request time for {} {} was {}ms.", request.getMethod(), request.getURI(), timeMs);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy