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

com.anaptecs.spring.service.restproxy.PathlessServiceRESTProxyReactive Maven / Gradle / Ivy

There is a newer version: 1.24.1
Show newest version
/*
 * anaptecs GmbH, Ricarda-Huch-Str. 71, 72760 Reutlingen, Germany
 *
 * Copyright 2004 - 2019. All rights reserved.
 */
package com.anaptecs.spring.service.restproxy;

import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.OffsetDateTime;
import java.time.OffsetTime;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;

import org.springframework.stereotype.Service;

import com.anaptecs.jeaf.rest.executor.api.ContentType;
import com.anaptecs.jeaf.rest.executor.api.HttpMethod;
import com.anaptecs.jeaf.rest.executor.api.ObjectType;
import com.anaptecs.jeaf.rest.executor.api.RESTRequest;
import com.anaptecs.jeaf.rest.executor.api.reactive.RESTRequestExecutorReactive;
import com.anaptecs.jeaf.validation.api.ValidationExecutor;
import com.anaptecs.spring.base.BookingID;
import com.anaptecs.spring.base.DoubleCode;
import com.anaptecs.spring.base.IntegerCodeType;
import com.anaptecs.spring.base.LongCode;
import com.anaptecs.spring.base.StringCode;
import com.anaptecs.spring.base.TimeUnit;
import com.anaptecs.spring.service.DataTypesQueryBean;
import com.anaptecs.spring.service.MultiValuedHeaderBeanParam;
import com.anaptecs.spring.service.PathlessService;
import com.anaptecs.spring.service.PathlessServiceReactive;
import reactor.core.publisher.Mono;

/**
 * Class implements a proxy for REST Service {@link PathlessService}. The proxy is implemented as Spring services. This
 * way to developers it looks like a plain Spring Service.
 *
 * This implementation deals with everything that is required to call the external REST service including the following
 * things:
 * 
    *
  • Serialization / deserialization between Java and JSON
  • *
  • Proper connection pooling and timeouts for HTTP requests
  • *
  • Proper setting of HTTP header
  • *
  • Circuit breaker in case of availabilities problems of the REST service
  • *
* * However, as an transactional context can not be propagated to another REST resource developers still have to take * care about proper transaction handling if needed. */ @Service public class PathlessServiceRESTProxyReactive implements PathlessServiceReactive { /** * REST request executor is used to send REST request to the proxied REST resource. Depending on the Spring * configuration the matching implementation will be injected here. */ private final RESTRequestExecutorReactive requestExecutor; /** * REST Service Proxy was generated with request / response validation enabled. The actual validation will be * delegated to the implementation of this interface. */ private final ValidationExecutor validationExecutor; /** * Initialize object. * * @param pRequestExecutor Dependency on concrete {@link RESTRequestExecutor} implementation that should be used. */ public PathlessServiceRESTProxyReactive( RESTRequestExecutorReactive pRequestExecutor, ValidationExecutor pValidationExecutor ) { requestExecutor = pRequestExecutor; validationExecutor = pValidationExecutor; } /** * @return {@link String} */ @Override public Mono getSomething( ) { // Create builder for GET request RESTRequest.Builder lRequestBuilder = RESTRequest.builder(PathlessService.class, HttpMethod.GET, ContentType.JSON); // Build path of request StringBuilder lPathBuilder = new StringBuilder(); lPathBuilder.append('/'); lPathBuilder.append("doSomething"); lRequestBuilder.setPath(lPathBuilder.toString()); // Execute request and return result. RESTRequest lRequest = lRequestBuilder.build(); ObjectType lObjectType = ObjectType.createObjectType(String.class); Mono lResult = requestExecutor.executeSingleObjectResultRequest(lRequest, 200, lObjectType); // Validate response and return it. validationExecutor.validateResponse(PathlessService.class, lResult); return lResult; } /** * @param pHeaderBean * @param pTechContext */ @Override public Mono processTechParam( MultiValuedHeaderBeanParam pHeaderBean ) { // Validate request parameter(s). validationExecutor.validateRequest(PathlessService.class, pHeaderBean); // Create builder for POST request RESTRequest.Builder lRequestBuilder = RESTRequest.builder(PathlessService.class, HttpMethod.POST, ContentType.JSON); // Build path of request StringBuilder lPathBuilder = new StringBuilder(); lPathBuilder.append('/'); lPathBuilder.append("processTechParam"); lRequestBuilder.setPath(lPathBuilder.toString()); // Set HTTP header(s) if (pHeaderBean != null) { if (pHeaderBean.getNames() != null) { lRequestBuilder.setHeader("names", pHeaderBean.getNames()); } if (pHeaderBean.getInts() != null) { lRequestBuilder.setHeader("ints", pHeaderBean.getInts()); } if (pHeaderBean.getDoubles() != null) { lRequestBuilder.setHeader("doubles", pHeaderBean.getDoubles()); } if (pHeaderBean.getCodes() != null) { List lValues = new ArrayList(); for (StringCode lNext : pHeaderBean.getCodes()) { lValues.add(lNext.getCode()); } lRequestBuilder.setHeader("codes", lValues); } if (pHeaderBean.getStringCodeList() != null) { List lValues = new ArrayList(); for (StringCode lNext : pHeaderBean.getStringCodeList()) { lValues.add(lNext.getCode()); } lRequestBuilder.setHeader("stringCodeList", lValues); } if (pHeaderBean.getStartDate() != null) { lRequestBuilder.setHeader("startDate", DateTimeFormatter.ISO_DATE.format(pHeaderBean.getStartDate())); } if (pHeaderBean.getDates() != null) { List lValues = new ArrayList(); for (LocalDate lNext : pHeaderBean.getDates()) { lValues.add(DateTimeFormatter.ISO_DATE.format(lNext)); } lRequestBuilder.setHeader("dates", lValues); } if (pHeaderBean.getTimestamps() != null) { List lValues = new ArrayList(); for (LocalDateTime lNext : pHeaderBean.getTimestamps()) { lValues.add(DateTimeFormatter.ISO_DATE_TIME.format(lNext)); } lRequestBuilder.setHeader("timestamps", lValues); } if (pHeaderBean.getCalendars() != null) { List lValues = new ArrayList(); for (Calendar lNext : pHeaderBean.getCalendars()) { lValues.add(new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSXXX").format(lNext.getTime())); } lRequestBuilder.setHeader("calendars", lValues); } if (pHeaderBean.getUtilDates() != null) { List lValues = new ArrayList(); for (Date lNext : pHeaderBean.getUtilDates()) { lValues.add(new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSXXX").format(lNext)); } lRequestBuilder.setHeader("utilDates", lValues); } if (pHeaderBean.getSqlTimestamps() != null) { List lValues = new ArrayList(); for (Timestamp lNext : pHeaderBean.getSqlTimestamps()) { lValues.add(lNext.toString()); } lRequestBuilder.setHeader("sqlTimestamps", lValues); } if (pHeaderBean.getTimeUnits() != null) { List lValues = new ArrayList(); for (TimeUnit lNext : pHeaderBean.getTimeUnits()) { lValues.add(lNext); } lRequestBuilder.setHeader("timeUnits", lValues); } if (pHeaderBean.getTimeUnitArray() != null) { List lValues = new ArrayList(); for (TimeUnit lNext : pHeaderBean.getTimeUnitArray()) { lValues.add(lNext); } lRequestBuilder.setHeader("timeUnitArray", lValues); } if (pHeaderBean.getBase64() != null) { lRequestBuilder.setHeader("base64", pHeaderBean.getBase64()); } } // Execute request. RESTRequest lRequest = lRequestBuilder.build(); ObjectType lObjectType = ObjectType.createObjectType(void.class); Mono lResult = requestExecutor.executeSingleObjectResultRequest(lRequest, 204, lObjectType); // Validate response and return it. validationExecutor.validateResponse(PathlessService.class, lResult); return lResult; } /** * @param pQuery * @return {@link String} */ @Override public Mono testQueryBeanParam( DataTypesQueryBean pQuery ) { // Validate request parameter(s). validationExecutor.validateRequest(PathlessService.class, pQuery); // Create builder for GET request RESTRequest.Builder lRequestBuilder = RESTRequest.builder(PathlessService.class, HttpMethod.GET, ContentType.JSON); // Build path of request StringBuilder lPathBuilder = new StringBuilder(); lPathBuilder.append('/'); lPathBuilder.append("test-query-bean-param"); lRequestBuilder.setPath(lPathBuilder.toString()); // Add query parameter(s) to request if (pQuery != null) { if (pQuery.getLongCodes() != null) { List lValues = new ArrayList(); for (LongCode lNext : pQuery.getLongCodes()) { lValues.add(lNext.getCode().toString()); } lRequestBuilder.setQueryParameter("longCodes", lValues); } if (pQuery.getCodes() != null) { List lValues = new ArrayList(); for (IntegerCodeType lNext : pQuery.getCodes()) { lValues.add(String.valueOf(lNext.getCode())); } lRequestBuilder.setQueryParameter("codes", lValues); } if (pQuery.getDoubleCodes() != null) { List lValues = new ArrayList(); for (DoubleCode lNext : pQuery.getDoubleCodes()) { lValues.add(lNext.getCode().toString()); } lRequestBuilder.setQueryParameter("doubleCodes", lValues); } if (pQuery.getBookingIDs() != null) { List lValues = new ArrayList(); for (BookingID lNext : pQuery.getBookingIDs()) { lValues.add(lNext.getBookingID()); } lRequestBuilder.setQueryParameter("bookingIDs", lValues); } if (pQuery.getBookingIDsArray() != null) { List lValues = new ArrayList(); for (BookingID lNext : pQuery.getBookingIDsArray()) { lValues.add(lNext.getBookingID()); } lRequestBuilder.setQueryParameter("bookingIDsArray", lValues); } if (pQuery.getOffsetDateTime() != null) { lRequestBuilder.setQueryParameter("offsetDateTime", DateTimeFormatter.ISO_OFFSET_DATE_TIME.format(pQuery.getOffsetDateTime())); } if (pQuery.getOffsetTime() != null) { lRequestBuilder.setQueryParameter("offsetTime", DateTimeFormatter.ISO_OFFSET_TIME.format(pQuery.getOffsetTime())); } if (pQuery.getLocalDateTime() != null) { lRequestBuilder.setQueryParameter("localDateTime", DateTimeFormatter.ISO_DATE_TIME.format(pQuery.getLocalDateTime())); } if (pQuery.getLocalTime() != null) { lRequestBuilder.setQueryParameter("localTime", DateTimeFormatter.ISO_TIME.format(pQuery.getLocalTime())); } if (pQuery.getTimestamps() != null) { List lValues = new ArrayList(); for (LocalDateTime lNext : pQuery.getTimestamps()) { lValues.add(DateTimeFormatter.ISO_DATE_TIME.format(lNext)); } lRequestBuilder.setQueryParameter("timestamps", lValues); } if (pQuery.getTimes() != null) { List lValues = new ArrayList(); for (OffsetTime lNext : pQuery.getTimes()) { lValues.add(DateTimeFormatter.ISO_OFFSET_TIME.format(lNext)); } lRequestBuilder.setQueryParameter("times", lValues); } if (pQuery.getStartTimestamps() != null) { List lValues = new ArrayList(); for (OffsetDateTime lNext : pQuery.getStartTimestamps()) { lValues.add(DateTimeFormatter.ISO_OFFSET_DATE_TIME.format(lNext)); } lRequestBuilder.setQueryParameter("startTimestamps", lValues); } } // Execute request and return result. RESTRequest lRequest = lRequestBuilder.build(); ObjectType lObjectType = ObjectType.createObjectType(String.class); Mono lResult = requestExecutor.executeSingleObjectResultRequest(lRequest, 200, lObjectType); // Validate response and return it. validationExecutor.validateResponse(PathlessService.class, lResult); return lResult; } }