
com.github.marschall.jfr.resttemplate.JfrRestOperations Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jfr-resttemplate Show documentation
Show all versions of jfr-resttemplate Show documentation
A RestTemplate that generates JFR events.
The newest version!
package com.github.marschall.jfr.resttemplate;
import java.lang.reflect.Array;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.net.URI;
import java.util.Collection;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
import org.springframework.core.ParameterizedTypeReference;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.RequestEntity;
import org.springframework.http.ResponseEntity;
import org.springframework.web.client.RequestCallback;
import org.springframework.web.client.ResponseExtractor;
import org.springframework.web.client.RestOperations;
import jdk.jfr.Category;
import jdk.jfr.Description;
import jdk.jfr.Event;
import jdk.jfr.Label;
/**
* An implementation of {@link RestOperations} that generates JFR events.
* The events are generated in the "Spring REST" category.
*/
public final class JfrRestOperations implements RestOperations {
private final RestOperations delegate;
/**
* Constructs a new {@link JfrRestOperations}.
*
* @param delegate the actual {@link RestOperations} implementation, not {@code null}
*/
public JfrRestOperations(RestOperations delegate) {
Objects.requireNonNull(delegate, "delegate");
this.delegate = delegate;
}
@Override
public T getForObject(String url, Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("GET");
event.setOperationName("getForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.getForObject(url, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T getForObject(String url, Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("GET");
event.setOperationName("getForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.getForObject(url, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T getForObject(URI url, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("GET");
event.setOperationName("getForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.getForObject(url, responseType);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity getForEntity(String url, Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("GET");
event.setOperationName("getForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.getForEntity(url, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity getForEntity(String url, Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("GET");
event.setOperationName("getForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.getForEntity(url, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity getForEntity(URI url, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("GET");
event.setOperationName("getForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.getForEntity(url, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public HttpHeaders headForHeaders(String url, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("HEAD");
event.setOperationName("headForHeaders");
event.setResponseType(HttpHeaders.class);
event.begin();
try {
HttpHeaders headers = this.delegate.headForHeaders(url, uriVariables);
event.setObjectCount(headers.size());
return headers;
} finally {
event.end();
event.commit();
}
}
@Override
public HttpHeaders headForHeaders(String url, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("HEAD");
event.setOperationName("headForHeaders");
event.setResponseType(HttpHeaders.class);
event.begin();
try {
HttpHeaders headers = this.delegate.headForHeaders(url, uriVariables);
event.setObjectCount(headers.size());
return headers;
} finally {
event.end();
event.commit();
}
}
@Override
public HttpHeaders headForHeaders(URI url) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("HEAD");
event.setOperationName("headForHeaders");
event.setResponseType(HttpHeaders.class);
event.begin();
try {
HttpHeaders headers = this.delegate.headForHeaders(url);
event.setObjectCount(headers.size());
return headers;
} finally {
event.end();
event.commit();
}
}
@Override
public URI postForLocation(String url, Object request, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForLocation");
event.setResponseType(URI.class);
event.begin();
try {
return this.delegate.postForLocation(url, request, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public URI postForLocation(String url, Object request, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForLocation");
event.setResponseType(URI.class);
event.begin();
try {
return this.delegate.postForLocation(url, request, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public URI postForLocation(URI url, Object request) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("POST");
event.setOperationName("postForLocation");
event.setResponseType(URI.class);
event.begin();
try {
return this.delegate.postForLocation(url, request);
} finally {
event.end();
event.commit();
}
}
@Override
public T postForObject(String url, Object request, Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.postForObject(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T postForObject(String url, Object request, Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.postForObject(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T postForObject(URI url, Object request, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("POST");
event.setOperationName("postForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.postForObject(url, request, responseType);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity postForEntity(String url, Object request, Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.postForEntity(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity postForEntity(String url, Object request, Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("POST");
event.setOperationName("postForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.postForEntity(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity postForEntity(URI url, Object request, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("POST");
event.setOperationName("postForEntity");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.postForEntity(url, request, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public void put(String url, Object request, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("PUT");
event.setOperationName("put");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.put(url, request, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public void put(String url, Object request, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("PUT");
event.setOperationName("put");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.put(url, request, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public void put(URI url, Object request) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("PUT");
event.setOperationName("put");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.put(url, request);
} finally {
event.end();
event.commit();
}
}
@Override
public T patchForObject(String url, Object request, Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("PATCH");
event.setOperationName("patchForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.patchForObject(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T patchForObject(String url, Object request, Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("PATCH");
event.setOperationName("patchForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.patchForObject(url, request, responseType, uriVariables);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public T patchForObject(URI url, Object request, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("PATCH");
event.setOperationName("patchForObject");
event.setResponseType(responseType);
event.begin();
try {
T object = this.delegate.patchForObject(url, request, responseType);
event.setObjectCount(getObjectCount(object));
return object;
} finally {
event.end();
event.commit();
}
}
@Override
public void delete(String url, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("DELETE");
event.setOperationName("delete");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.delete(url, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public void delete(String url, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("DELETE");
event.setOperationName("delete");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.delete(url, uriVariables);
} finally {
event.end();
event.commit();
}
}
@Override
public void delete(URI url) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("DELETE");
event.setOperationName("delete");
event.setResponseType(Void.class);
event.begin();
try {
this.delegate.delete(url);
} finally {
event.end();
event.commit();
}
}
@Override
public Set optionsForAllow(String url, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("OPTIONS");
event.setOperationName("optionsForAllow");
event.setResponseType(Set.class);
event.begin();
try {
Set allow = this.delegate.optionsForAllow(url, uriVariables);
event.setObjectCount(allow.size());
return allow;
} finally {
event.end();
event.commit();
}
}
@Override
public Set optionsForAllow(String url, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod("OPTIONS");
event.setOperationName("optionsForAllow");
event.setResponseType(Set.class);
event.begin();
try {
Set allow = this.delegate.optionsForAllow(url, uriVariables);
event.setObjectCount(allow.size());
return allow;
} finally {
event.end();
event.commit();
}
}
@Override
public Set optionsForAllow(URI url) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod("OPTIONS");
event.setOperationName("optionsForAllow");
event.setResponseType(Set.class);
event.begin();
try {
Set allow = this.delegate.optionsForAllow(url);
event.setObjectCount(allow.size());
return allow;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(String url, HttpMethod method, HttpEntity> requestEntity,
Class responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(String url, HttpMethod method, HttpEntity> requestEntity,
Class responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(URI url, HttpMethod method, HttpEntity> requestEntity, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(String url, HttpMethod method, HttpEntity> requestEntity,
ParameterizedTypeReference responseType, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(extractResponseType(responseType));
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(String url, HttpMethod method, HttpEntity> requestEntity,
ParameterizedTypeReference responseType, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(extractResponseType(responseType));
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType, uriVariables);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(URI url, HttpMethod method, HttpEntity> requestEntity,
ParameterizedTypeReference responseType) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod(method.name());
event.setOperationName("exchange");
event.setResponseType(extractResponseType(responseType));
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(url, method, requestEntity, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(RequestEntity> requestEntity, Class responseType) {
RestEvent event = new RestEvent();
event.setUri(requestEntity.getUrl().toString());
event.setMethod(requestEntity.getMethod().name());
event.setOperationName("exchange");
event.setResponseType(responseType);
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(requestEntity, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public ResponseEntity exchange(RequestEntity> requestEntity, ParameterizedTypeReference responseType) {
RestEvent event = new RestEvent();
event.setUri(requestEntity.getUrl().toString());
event.setMethod(requestEntity.getMethod().name());
event.setOperationName("exchange");
event.setResponseType(extractResponseType(responseType));
event.begin();
try {
ResponseEntity entity = this.delegate.exchange(requestEntity, responseType);
event.setObjectCount(getObjectCount(entity));
return entity;
} finally {
event.end();
event.commit();
}
}
@Override
public T execute(String url, HttpMethod method, RequestCallback requestCallback,
ResponseExtractor responseExtractor, Object... uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.begin();
try {
T response = this.delegate.execute(url, method, requestCallback, responseExtractor, uriVariables);
if (response != null) {
event.setResponseType(response.getClass());
}
event.setObjectCount(getObjectCount(response));
return response;
} finally {
event.end();
event.commit();
}
}
@Override
public T execute(String url, HttpMethod method, RequestCallback requestCallback,
ResponseExtractor responseExtractor, Map uriVariables) {
RestEvent event = new RestEvent();
event.setUri(url);
event.setMethod(method.name());
event.setOperationName("exchange");
event.begin();
try {
T response = this.delegate.execute(url, method, requestCallback, responseExtractor, uriVariables);
if (response != null) {
event.setResponseType(response.getClass());
}
event.setObjectCount(getObjectCount(response));
return response;
} finally {
event.end();
event.commit();
}
}
@Override
public T execute(URI url, HttpMethod method, RequestCallback requestCallback,
ResponseExtractor responseExtractor) {
RestEvent event = new RestEvent();
event.setUri(url.toString());
event.setMethod(method.name());
event.setOperationName("exchange");
event.begin();
try {
T response = this.delegate.execute(url, method, requestCallback, responseExtractor);
if (response != null) {
event.setResponseType(response.getClass());
}
event.setObjectCount(getObjectCount(response));
return response;
} finally {
event.end();
event.commit();
}
}
private static Class> extractResponseType(ParameterizedTypeReference> responseType) {
Type type = responseType.getType();
if (type instanceof Class) {
return (Class>) type;
}
if (type instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) type;
Type rawType = parameterizedType.getRawType();
if (rawType instanceof Class) {
return (Class>) rawType;
}
}
return null;
}
static int getObjectCount(HttpEntity> entity) {
if (entity.hasBody()) {
Object body = entity.getBody();
return getObjectCount(body);
} else {
return 0;
}
}
static int getObjectCount(Object o) {
if (o == null) {
return 0;
}
if (o instanceof Collection) {
return ((Collection>) o).size();
}
if (o instanceof Map) {
return ((Map, ?>) o).size();
}
if (o.getClass().isArray()) {
return Array.getLength(o);
}
return 1;
}
@Label("Operation")
@Description("A REST Operation")
@Category("Spring REST")
static class RestEvent extends Event {
@Label("Method")
@Description("The name of the HTTP method")
private String method;
@Label("URI")
@Description("The HTTP URI")
private String uri;
@Label("Operation Name")
@Description("The name of the REST operation")
private String operationName;
@Label("Response Type")
@Description("The response type")
private Class> responseType;
@Label("Object Count")
@Description("The number of objects returned")
private int objectCount;
String getOperationName() {
return this.operationName;
}
void setOperationName(String operationName) {
this.operationName = operationName;
}
String getMethod() {
return this.method;
}
void setMethod(String method) {
this.method = method;
}
String getUri() {
return this.uri;
}
void setUri(String uri) {
this.uri = uri;
}
Class> getResponseType() {
return this.responseType;
}
void setResponseType(Class> responseType) {
this.responseType = responseType;
}
int getObjectCount() {
return this.objectCount;
}
void setObjectCount(int objectCount) {
this.objectCount = objectCount;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy