From 6950845e98c0fed35709b442951aff7fe84b3dc1 Mon Sep 17 00:00:00 2001 From: bcamposf_meli Date: Tue, 24 Oct 2023 09:54:34 -0300 Subject: [PATCH 1/2] modify send method and addDefaultHeaders method --- .../mercadopago/client/MercadoPagoClient.java | 109 ++++++++++-------- .../client/preference/PreferenceClientIT.java | 20 +++- 2 files changed, 82 insertions(+), 47 deletions(-) diff --git a/src/main/java/com/mercadopago/client/MercadoPagoClient.java b/src/main/java/com/mercadopago/client/MercadoPagoClient.java index d9487acd..8da6ab99 100644 --- a/src/main/java/com/mercadopago/client/MercadoPagoClient.java +++ b/src/main/java/com/mercadopago/client/MercadoPagoClient.java @@ -1,5 +1,9 @@ package com.mercadopago.client; +import static java.util.Objects.nonNull; +import static org.apache.commons.collections.MapUtils.isNotEmpty; +import static org.apache.commons.lang3.StringUtils.isNotBlank; + import com.google.gson.JsonObject; import com.mercadopago.MercadoPagoConfig; import com.mercadopago.core.MPRequestOptions; @@ -14,7 +18,6 @@ import com.mercadopago.net.UrlFormatter; import java.util.HashMap; import java.util.Map; -import java.util.Objects; /** Mercado Pago client class. */ public abstract class MercadoPagoClient { @@ -51,18 +54,7 @@ public MercadoPagoClient(MPHttpClient httpClient) { * @throws MPException exception */ protected MPResponse send(MPRequest request) throws MPException, MPApiException { - String uri = UrlFormatter.format(request.getUri(), request.getQueryParams()); - - return httpClient.send( - MPRequest.builder() - .uri(uri) - .method(request.getMethod()) - .headers(addDefaultHeaders(request)) - .payload(request.getPayload()) - .connectionRequestTimeout(addConnectionRequestTimeout(request, null)) - .connectionTimeout(addConnectionTimeout(request, null)) - .socketTimeout(addSocketTimeout(request, null)) - .build()); + return this.send(request, null); } /** @@ -75,13 +67,21 @@ protected MPResponse send(MPRequest request) throws MPException, MPApiException */ protected MPResponse send(MPRequest request, MPRequestOptions requestOptions) throws MPException, MPApiException { - return this.send( - this.buildRequest( - request.getUri(), - request.getMethod(), - request.getPayload(), - request.getQueryParams(), - requestOptions)); + String uri = UrlFormatter.format(request.getUri(), request.getQueryParams()); + Map addHeadersByDefault = addDefaultHeaders(request, requestOptions); // esse metodo teria um melhor nome sendo addDefaultHeader? + Map defaultAndCustomHeaders = addCustomHeaders(addHeadersByDefault, uri, requestOptions); + + return httpClient.send( + MPRequest.builder() + .uri(uri) + .accessToken(getAccessToken(requestOptions)) + .method(request.getMethod()) + .headers(defaultAndCustomHeaders) + .payload(request.getPayload()) + .connectionRequestTimeout(addConnectionRequestTimeout(request, requestOptions)) + .connectionTimeout(addConnectionTimeout(request, requestOptions)) + .socketTimeout(addSocketTimeout(request, requestOptions)) + .build()); } /** @@ -150,7 +150,7 @@ protected MPResponse search( String path, MPSearchRequest searchRequest, MPRequestOptions requestOptions) throws MPException, MPApiException { Map queryParams = - Objects.nonNull(searchRequest) ? searchRequest.getParameters() : null; + nonNull(searchRequest) ? searchRequest.getParameters() : null; return this.send(path, HttpMethod.GET, null, queryParams, requestOptions); } @@ -204,7 +204,7 @@ private MPRequest buildRequest( .payload(payload) .method(method) .queryParams(queryParams) - .headers(addCustomHeaders(path, requestOptions)) + .headers(addCustomHeaders(defaultHeaders, path, requestOptions)) .connectionRequestTimeout(addConnectionRequestTimeout(null, requestOptions)) .connectionTimeout(addConnectionTimeout(null, requestOptions)) .socketTimeout(addSocketTimeout(null, requestOptions)) @@ -212,11 +212,11 @@ private MPRequest buildRequest( } private int addSocketTimeout(MPRequest request, MPRequestOptions requestOptions) { - if (Objects.nonNull(requestOptions) && requestOptions.getSocketTimeout() > 0) { + if (nonNull(requestOptions) && requestOptions.getSocketTimeout() > 0) { return requestOptions.getSocketTimeout(); } - if (Objects.nonNull(request) && request.getSocketTimeout() > 0) { + if (nonNull(request) && request.getSocketTimeout() > 0) { return request.getSocketTimeout(); } @@ -224,11 +224,11 @@ private int addSocketTimeout(MPRequest request, MPRequestOptions requestOptions) } private int addConnectionTimeout(MPRequest request, MPRequestOptions requestOptions) { - if (Objects.nonNull(requestOptions) && requestOptions.getConnectionTimeout() > 0) { + if (nonNull(requestOptions) && requestOptions.getConnectionTimeout() > 0) { return requestOptions.getConnectionTimeout(); } - if (Objects.nonNull(request) && request.getConnectionTimeout() > 0) { + if (nonNull(request) && request.getConnectionTimeout() > 0) { return request.getConnectionTimeout(); } @@ -236,38 +236,34 @@ private int addConnectionTimeout(MPRequest request, MPRequestOptions requestOpti } private int addConnectionRequestTimeout(MPRequest request, MPRequestOptions requestOptions) { - if (Objects.nonNull(requestOptions) && requestOptions.getConnectionRequestTimeout() > 0) { + if (nonNull(requestOptions) && requestOptions.getConnectionRequestTimeout() > 0) { return requestOptions.getConnectionRequestTimeout(); } - if (Objects.nonNull(request) && request.getConnectionRequestTimeout() > 0) { + if (nonNull(request) && request.getConnectionRequestTimeout() > 0) { return request.getConnectionRequestTimeout(); } return MercadoPagoConfig.getConnectionRequestTimeout(); } - private Map addCustomHeaders(String uri, MPRequestOptions requestOptions) { - Map headers = new HashMap<>(); - if (Objects.nonNull(requestOptions) && Objects.nonNull(requestOptions.getCustomHeaders())) { - for (Map.Entry entry : requestOptions.getCustomHeaders().entrySet()) { - headers.put(entry.getKey().toLowerCase(), entry.getValue()); - } - } + public Map addDefaultHeaders(MPRequest request, MPRequestOptions requestOptions) { + Map headers = + nonNull(request.getHeaders()) ? request.getHeaders() : new HashMap<>(); - if (!uri.contains("/oauth/token")) { - headers.put(Headers.AUTHORIZATION, String.format("Bearer %s", getAccessToken(requestOptions))); + headers.putAll(defaultHeaders); + + if (isNotBlank(MercadoPagoConfig.getCorporationId())) { + headers.put(Headers.CORPORATION_ID, MercadoPagoConfig.getCorporationId()); } - return headers; - } - private Map addDefaultHeaders(MPRequest request) { - Map headers = - Objects.nonNull(request.getHeaders()) ? request.getHeaders() : new HashMap<>(); + if (isNotBlank(MercadoPagoConfig.getIntegratorId())) { + headers.put(Headers.INTEGRATOR_ID, MercadoPagoConfig.getIntegratorId()); + } - for (Map.Entry entry : defaultHeaders.entrySet()) { - headers.put(entry.getKey(), entry.getValue()); + if (isNotBlank(MercadoPagoConfig.getPlatformId())) { + headers.put(Headers.PLATFORM_ID, MercadoPagoConfig.getPlatformId()); } if (shouldAddIdempotencyKey(request, headers)) { @@ -278,6 +274,27 @@ private Map addDefaultHeaders(MPRequest request) { headers.put(Headers.AUTHORIZATION, String.format("Bearer %s", getAccessToken(null))); } + if (nonNull(requestOptions) && isNotEmpty(requestOptions.getCustomHeaders()) ) { + for (Map.Entry header : requestOptions.getCustomHeaders().entrySet()) { // ver essa regra aqui + if (!headers.containsKey(header.getKey()) && !Headers.CONTENT_TYPE.equalsIgnoreCase(header.getKey())) { + headers.put(header.getKey().toLowerCase(), header.getValue()); + } + } + } + + return headers; + } + + private Map addCustomHeaders(Map headers, String uri, MPRequestOptions requestOptions) { + if (nonNull(requestOptions) && nonNull(requestOptions.getCustomHeaders())) { + for (Map.Entry entry : requestOptions.getCustomHeaders().entrySet()) { + headers.put(entry.getKey().toLowerCase(), entry.getValue()); + } + } + + if (!uri.contains("/oauth/token")) { + headers.put(Headers.AUTHORIZATION, String.format("Bearer %s", getAccessToken(requestOptions))); + } return headers; } @@ -292,8 +309,8 @@ private boolean shouldAddIdempotencyKey(MPRequest request, Map headers) { } private String getAccessToken(MPRequestOptions requestOptions) { - return Objects.nonNull(requestOptions) - && Objects.nonNull(requestOptions.getAccessToken()) + return nonNull(requestOptions) + && nonNull(requestOptions.getAccessToken()) && !requestOptions.getAccessToken().isEmpty() ? requestOptions.getAccessToken() : MercadoPagoConfig.getAccessToken(); diff --git a/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java b/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java index 47136559..4dcf48f1 100644 --- a/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java +++ b/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java @@ -11,15 +11,20 @@ import com.mercadopago.client.common.AddressRequest; import com.mercadopago.client.common.IdentificationRequest; import com.mercadopago.client.common.PhoneRequest; +import com.mercadopago.core.MPRequestOptions; import com.mercadopago.exceptions.MPApiException; import com.mercadopago.exceptions.MPException; +import com.mercadopago.net.Headers; import com.mercadopago.net.MPElementsResourcesPage; import com.mercadopago.net.MPSearchRequest; import com.mercadopago.resources.preference.Preference; import com.mercadopago.resources.preference.PreferenceSearch; import java.math.BigDecimal; import java.util.ArrayList; +import java.util.HashMap; import java.util.List; +import java.util.Map; +import java.util.UUID; import org.junit.jupiter.api.Test; /** PreferenceClientIT class. */ @@ -82,11 +87,24 @@ void createSuccess() { void createWithRequestOptionsSuccess() { try { PreferenceRequest preferenceRequest = buildPreferenceRequest(); - Preference preference = client.create(preferenceRequest, buildRequestOptions()); + + String idempotency = UUID.randomUUID().toString(); + Map idempotencyKey = new HashMap<>(); + idempotencyKey.put(Headers.IDEMPOTENCY_KEY, idempotency); + MPRequestOptions mpRequestOptions = MPRequestOptions + .builder() + .customHeaders(idempotencyKey) + .build(); + + Preference preference = client.create(preferenceRequest, mpRequestOptions); assertNotNull(preference.getResponse()); assertEquals(CREATED, preference.getResponse().getStatusCode()); assertNotNull(preference.getId()); + System.out.println(idempotency); + System.out.println(idempotencyKey); + System.out.println(mpRequestOptions); + System.out.println("preference: " + preference.getResponse().getHeaders()); } catch (MPApiException mpApiException) { fail(mpApiException.getApiResponse().getContent()); } catch (MPException mpException) { From b8d43d0bd5b0e3deb8af0cbfd0cac59e46489972 Mon Sep 17 00:00:00 2001 From: bcamposf_meli Date: Tue, 24 Oct 2023 19:31:50 -0300 Subject: [PATCH 2/2] refactor add request header methods --- .../mercadopago/client/MercadoPagoClient.java | 51 +++++++++++-------- .../client/preference/PreferenceClientIT.java | 4 -- 2 files changed, 31 insertions(+), 24 deletions(-) diff --git a/src/main/java/com/mercadopago/client/MercadoPagoClient.java b/src/main/java/com/mercadopago/client/MercadoPagoClient.java index 8da6ab99..03470cb1 100644 --- a/src/main/java/com/mercadopago/client/MercadoPagoClient.java +++ b/src/main/java/com/mercadopago/client/MercadoPagoClient.java @@ -24,6 +24,8 @@ public abstract class MercadoPagoClient { private static final String ACCEPT_HEADER_VALUE = "application/json"; private static final String CONTENT_TYPE_HEADER_VALUE = "application/json; charset=UTF-8"; + private static final String BEARER = "Bearer %s"; + private static final String OAUTH_TOKEN = "/oauth/token"; protected final MPHttpClient httpClient; @@ -68,15 +70,13 @@ protected MPResponse send(MPRequest request) throws MPException, MPApiException protected MPResponse send(MPRequest request, MPRequestOptions requestOptions) throws MPException, MPApiException { String uri = UrlFormatter.format(request.getUri(), request.getQueryParams()); - Map addHeadersByDefault = addDefaultHeaders(request, requestOptions); // esse metodo teria um melhor nome sendo addDefaultHeader? - Map defaultAndCustomHeaders = addCustomHeaders(addHeadersByDefault, uri, requestOptions); return httpClient.send( MPRequest.builder() .uri(uri) .accessToken(getAccessToken(requestOptions)) .method(request.getMethod()) - .headers(defaultAndCustomHeaders) + .headers(addRequestHeaders(request, requestOptions)) .payload(request.getPayload()) .connectionRequestTimeout(addConnectionRequestTimeout(request, requestOptions)) .connectionTimeout(addConnectionTimeout(request, requestOptions)) @@ -204,7 +204,7 @@ private MPRequest buildRequest( .payload(payload) .method(method) .queryParams(queryParams) - .headers(addCustomHeaders(defaultHeaders, path, requestOptions)) + .headers(addCustomHeaders(path, requestOptions)) .connectionRequestTimeout(addConnectionRequestTimeout(null, requestOptions)) .connectionTimeout(addConnectionTimeout(null, requestOptions)) .socketTimeout(addSocketTimeout(null, requestOptions)) @@ -247,12 +247,12 @@ private int addConnectionRequestTimeout(MPRequest request, MPRequestOptions requ return MercadoPagoConfig.getConnectionRequestTimeout(); } + private Map addRequestHeaders(MPRequest request, MPRequestOptions requestOptions) { - public Map addDefaultHeaders(MPRequest request, MPRequestOptions requestOptions) { Map headers = nonNull(request.getHeaders()) ? request.getHeaders() : new HashMap<>(); - headers.putAll(defaultHeaders); + headers.putAll(addDefaultHeaders(request)); if (isNotBlank(MercadoPagoConfig.getCorporationId())) { headers.put(Headers.CORPORATION_ID, MercadoPagoConfig.getCorporationId()); @@ -266,40 +266,51 @@ public Map addDefaultHeaders(MPRequest request, MPRequestOptions headers.put(Headers.PLATFORM_ID, MercadoPagoConfig.getPlatformId()); } - if (shouldAddIdempotencyKey(request, headers)) { - headers.put(Headers.IDEMPOTENCY_KEY, request.createIdempotencyKey()); - } - - if (!request.getUri().contains("/oauth/token") && !headers.containsKey(Headers.AUTHORIZATION)) { - headers.put(Headers.AUTHORIZATION, String.format("Bearer %s", getAccessToken(null))); - } - if (nonNull(requestOptions) && isNotEmpty(requestOptions.getCustomHeaders()) ) { - for (Map.Entry header : requestOptions.getCustomHeaders().entrySet()) { // ver essa regra aqui + for (Map.Entry header : requestOptions.getCustomHeaders().entrySet()) { if (!headers.containsKey(header.getKey()) && !Headers.CONTENT_TYPE.equalsIgnoreCase(header.getKey())) { headers.put(header.getKey().toLowerCase(), header.getValue()); } } } + headers.putAll(addCustomHeaders(request.getUri(), requestOptions)); return headers; } - private Map addCustomHeaders(Map headers, String uri, MPRequestOptions requestOptions) { + private Map addDefaultHeaders(MPRequest request) { + Map headers = new HashMap<>(defaultHeaders); + if (shouldAddIdempotencyKey(request)) { + headers.put(Headers.IDEMPOTENCY_KEY, request.createIdempotencyKey()); + } + + if (!request.getUri().contains(OAUTH_TOKEN) && !headers.containsKey(Headers.AUTHORIZATION)) { + headers.put(Headers.AUTHORIZATION, String.format(BEARER, getAccessToken(null))); + } + return headers; + } + + private Map addCustomHeaders(String uri, MPRequestOptions requestOptions) { + Map headers = new HashMap<>(); if (nonNull(requestOptions) && nonNull(requestOptions.getCustomHeaders())) { for (Map.Entry entry : requestOptions.getCustomHeaders().entrySet()) { headers.put(entry.getKey().toLowerCase(), entry.getValue()); } } - if (!uri.contains("/oauth/token")) { - headers.put(Headers.AUTHORIZATION, String.format("Bearer %s", getAccessToken(requestOptions))); + if (!uri.contains(OAUTH_TOKEN)) { + headers.put(Headers.AUTHORIZATION, String.format(BEARER, getAccessToken(requestOptions))); } + return headers; } - private boolean shouldAddIdempotencyKey(MPRequest request, Map headers) { - boolean containsIdempotency = headers.containsKey(Headers.IDEMPOTENCY_KEY.toLowerCase()); + private boolean shouldAddIdempotencyKey(MPRequest request) { + + boolean containsIdempotency = false; + if (nonNull(request) && nonNull(request.getHeaders())) { + containsIdempotency = request.getHeaders().containsKey(Headers.IDEMPOTENCY_KEY.toLowerCase()); + } if (containsIdempotency) return false; diff --git a/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java b/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java index 4dcf48f1..f0f228e8 100644 --- a/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java +++ b/src/test/java/com/mercadopago/client/preference/PreferenceClientIT.java @@ -101,10 +101,6 @@ void createWithRequestOptionsSuccess() { assertNotNull(preference.getResponse()); assertEquals(CREATED, preference.getResponse().getStatusCode()); assertNotNull(preference.getId()); - System.out.println(idempotency); - System.out.println(idempotencyKey); - System.out.println(mpRequestOptions); - System.out.println("preference: " + preference.getResponse().getHeaders()); } catch (MPApiException mpApiException) { fail(mpApiException.getApiResponse().getContent()); } catch (MPException mpException) {