diff --git a/scripts/native/file/dom-legal-customer-product-directory-1.0-native-quarkus-jdk17-runner b/scripts/native/file/dom-legal-customer-product-directory-1.0-native-quarkus-jdk17-runner index 5b12a69..42cab02 100644 Binary files a/scripts/native/file/dom-legal-customer-product-directory-1.0-native-quarkus-jdk17-runner and b/scripts/native/file/dom-legal-customer-product-directory-1.0-native-quarkus-jdk17-runner differ diff --git a/src/main/java/com/banesco/common/application/helper/MessageHelper.java b/src/main/java/com/banesco/common/application/helper/MessageHelper.java index 2bf57bc..7d7e5bd 100644 --- a/src/main/java/com/banesco/common/application/helper/MessageHelper.java +++ b/src/main/java/com/banesco/common/application/helper/MessageHelper.java @@ -40,6 +40,14 @@ public class MessageHelper { this.errorMappings = initializeErrorMappings(); } + public Response handleSuccess(Object data, String statusCode) { + log.info( + "Respuesta exitosa controlada: {}", + statusCode + ); + return buildResponse(data, statusCode); + } + public Response handleException(HttpStatusCodeException exception) { log.error( "Error interno controlado: {} -> {}", @@ -106,8 +114,27 @@ public class MessageHelper { ); return Response.status(mapping.getHttpCode()) - .entity(new ApiResponse<>(status)) - .build(); + .entity(new ApiResponse<>(status)) + .build(); + } + + private Response buildResponse(Object data, String statusCode) { + ErrorMapping mapping = errorMappings.getOrDefault( + statusCode, errorMappings.getOrDefault( + statusCode, createDefaultMapping() + ) + ); + StatusResponse status = createError(mapping, null); + + log.error( + "[Success] Message {} -> {}", + statusCode, + status.getMessage() + ); + + return Response.status(mapping.getHttpCode()) + .entity(new ApiResponse<>(data, status)) + .build(); } private Map initializeErrorMappings() { diff --git a/src/main/java/com/banesco/common/domain/model/Device.java b/src/main/java/com/banesco/common/domain/model/Device.java new file mode 100644 index 0000000..8299a06 --- /dev/null +++ b/src/main/java/com/banesco/common/domain/model/Device.java @@ -0,0 +1,17 @@ +package com.banesco.common.domain.model; + +import io.quarkus.runtime.annotations.RegisterForReflection; +import lombok.*; + +@Getter +@ToString +@Builder +@NoArgsConstructor +@AllArgsConstructor +@RegisterForReflection +public class Device { + private String deviceType; + private String deviceDescription; + private String deviceIp; + private String deviceSessionReference; +} diff --git a/src/main/java/com/banesco/common/infrastructure/context/RequestContext.java b/src/main/java/com/banesco/common/infrastructure/context/RequestContext.java index 633fd0f..bf29549 100644 --- a/src/main/java/com/banesco/common/infrastructure/context/RequestContext.java +++ b/src/main/java/com/banesco/common/infrastructure/context/RequestContext.java @@ -6,7 +6,9 @@ public class RequestContext { private RequestContext() {} - private static final String REQUEST_ID = "requestId"; + public static final String REQUEST_ID = "requestId"; + public static final String DEVICE = "device"; + public static final String DEVICE_SESSION_REFERENCE = "deviceSessionReference"; public static String getRequestId() { return MDC.get(REQUEST_ID); diff --git a/src/main/java/com/banesco/common/infrastructure/filter/RequestIdFilter.java b/src/main/java/com/banesco/common/infrastructure/filter/RequestIdFilter.java index c6090ec..e14b02b 100644 --- a/src/main/java/com/banesco/common/infrastructure/filter/RequestIdFilter.java +++ b/src/main/java/com/banesco/common/infrastructure/filter/RequestIdFilter.java @@ -6,15 +6,88 @@ import jakarta.ws.rs.container.ContainerRequestFilter; import jakarta.ws.rs.container.ContainerResponseContext; import jakarta.ws.rs.container.ContainerResponseFilter; import jakarta.ws.rs.ext.Provider; +import lombok.extern.slf4j.Slf4j; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.nio.charset.StandardCharsets; import java.util.UUID; +@Slf4j @Provider public class RequestIdFilter implements ContainerRequestFilter, ContainerResponseFilter { @Override public void filter(ContainerRequestContext requestContext) { - RequestContext.setRequestId(UUID.randomUUID().toString().substring(0, 13)); + String requestId = requestContext.getHeaderString(RequestContext.DEVICE_SESSION_REFERENCE); + + if (isEmpty(requestId)) { + requestId = requestContext.getUriInfo() + .getQueryParameters() + .getFirst(RequestContext.DEVICE_SESSION_REFERENCE); + } + + if (isEmpty(requestId) && hasJsonBody(requestContext)) { + requestId = extractRequestIdFromBody(requestContext); + } + + if (isEmpty(requestId)) { + requestId = UUID.randomUUID().toString().substring(0, 13); + } + + RequestContext.setRequestId(requestId); + } + + private boolean isEmpty(String value) { + return value == null || value.trim().isEmpty(); + } + + private boolean hasJsonBody(ContainerRequestContext context) { + try { + String method = context.getMethod(); + String contentType = context.getHeaderString("Content-Type"); + + return ("POST".equals(method) || "PUT".equals(method)) + && contentType != null + && contentType.contains("application/json"); + } catch (Exception e) { + log.warn("La peticion no es un POST o PUT: {}", e.getMessage()); + return false; + } + } + + private String extractRequestIdFromBody(ContainerRequestContext context) { + try { + ByteArrayOutputStream buffer = new ByteArrayOutputStream(); + context.getEntityStream().transferTo(buffer); + byte[] bodyBytes = buffer.toByteArray(); + + context.setEntityStream(new ByteArrayInputStream(bodyBytes)); + + String bodyString = new String(bodyBytes, StandardCharsets.UTF_8); + io.vertx.core.json.JsonObject jsonObject = new io.vertx.core.json.JsonObject(bodyString); + + if (jsonObject.containsKey(RequestContext.DEVICE)) { + io.vertx.core.json.JsonObject device = jsonObject.getJsonObject(RequestContext.DEVICE); + + if (device.containsKey(RequestContext.DEVICE_SESSION_REFERENCE)) { + return device.getString(RequestContext.DEVICE_SESSION_REFERENCE); + } + } + + if (jsonObject.containsKey(RequestContext.REQUEST_ID)) { + return jsonObject.getString(RequestContext.REQUEST_ID); + } + + if (jsonObject.containsKey(RequestContext.DEVICE_SESSION_REFERENCE)) { + return jsonObject.getString(RequestContext.DEVICE_SESSION_REFERENCE); + } + + return null; + } catch (Exception e) { + log.error("Error extrayendo el requestId del cuerpo de la peticion: {}", e.getMessage()); + return null; + } } @Override @@ -22,6 +95,10 @@ public class RequestIdFilter implements ContainerRequestFilter, ContainerRespons ContainerRequestContext requestContext, ContainerResponseContext responseContext ) { - RequestContext.clear(); + try { + RequestContext.clear(); + } catch (Exception e) { + log.error("Error limpiando el filtro: {}", e.getMessage()); + } } -} +} \ No newline at end of file diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/application/service/LegalCustomerProductDirectoryService.java b/src/main/java/com/banesco/module/legal_customer_product_directory/application/service/LegalCustomerProductDirectoryService.java index 907f73f..e1e25e9 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/application/service/LegalCustomerProductDirectoryService.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/application/service/LegalCustomerProductDirectoryService.java @@ -7,8 +7,10 @@ import com.banesco.module.legal_customer_product_directory.application.repositor import com.banesco.module.legal_customer_product_directory.application.usecase.LegalCustomerProductDirectoryUseCase; import com.banesco.module.legal_customer_product_directory.domain.dto.request.LegalCustomerProductDirectoryRequest; import com.banesco.module.legal_customer_product_directory.domain.dto.response.LegalCustomerProductDirectoryResponse; +import io.netty.util.internal.StringUtil; import jakarta.enterprise.context.ApplicationScoped; import jakarta.inject.Inject; +import jakarta.ws.rs.core.Response; import lombok.extern.slf4j.Slf4j; @Slf4j @@ -28,23 +30,37 @@ public class LegalCustomerProductDirectoryService implements LegalCustomerProduc } @Override - public ApiResponse execute( + public Response execute( LegalCustomerProductDirectoryRequest request ) { log.info("Iniciando ejecucion para el cliente: {}", request.getCustomerId()); + Response response; + try { - return storeProcedure(request); + if(StringUtil.isNullOrEmpty(request.getCustomerId())) { + log.error("Error en el codigo del cliente vacio"); + throw HttpStatusCodeException.badRequest("VRN01"); + } + + ApiResponse apiResponse = storeProcedure(request); + + response = messageHelper.handleSuccess( + apiResponse.getData(), + apiResponse.getStatusResponse().getStatusCode() + ); } catch (PersistenceException e) { log.warn("Excepcion de la persistencia del sp: {} -> {}", e.getErrorCode(), e.getMessage()); - throw HttpStatusCodeException.badRequest(e.getErrorCode()); + response = messageHelper.handleException(HttpStatusCodeException.badRequest(e.getErrorCode())); } catch (HttpStatusCodeException e) { - log.error("Excepcion HTTP del api de dominio: {} - {}", e.getStatusCode(), e.getErrorCode()); - throw e; + log.error("Excepcion HTTP del api privada: {} - {}", e.getStatusCode(), e.getErrorCode()); + response = messageHelper.handleException(e); } catch (Exception e) { - log.error("Excepcion generica del api de dominio: {}", e.getMessage()); - throw e; + log.error("Excepcion generica del api privada: {}", e.getMessage()); + response = messageHelper.handleGenericException(e); } + + return response; } private ApiResponse storeProcedure( diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/application/usecase/LegalCustomerProductDirectoryUseCase.java b/src/main/java/com/banesco/module/legal_customer_product_directory/application/usecase/LegalCustomerProductDirectoryUseCase.java index 6313926..824bc34 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/application/usecase/LegalCustomerProductDirectoryUseCase.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/application/usecase/LegalCustomerProductDirectoryUseCase.java @@ -1,11 +1,10 @@ package com.banesco.module.legal_customer_product_directory.application.usecase; -import com.banesco.common.domain.model.ApiResponse; import com.banesco.module.legal_customer_product_directory.domain.dto.request.LegalCustomerProductDirectoryRequest; -import com.banesco.module.legal_customer_product_directory.domain.dto.response.LegalCustomerProductDirectoryResponse; +import jakarta.ws.rs.core.Response; public interface LegalCustomerProductDirectoryUseCase { - ApiResponse execute( + Response execute( LegalCustomerProductDirectoryRequest request ); } diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/domain/dto/request/LegalCustomerProductDirectoryRequest.java b/src/main/java/com/banesco/module/legal_customer_product_directory/domain/dto/request/LegalCustomerProductDirectoryRequest.java index 06dcc26..5c42e52 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/domain/dto/request/LegalCustomerProductDirectoryRequest.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/domain/dto/request/LegalCustomerProductDirectoryRequest.java @@ -1,5 +1,6 @@ package com.banesco.module.legal_customer_product_directory.domain.dto.request; +import com.banesco.common.domain.model.Device; import io.quarkus.runtime.annotations.RegisterForReflection; import lombok.*; @@ -15,7 +16,9 @@ public class LegalCustomerProductDirectoryRequest { @NonNull private String appId; // Header obligatorio @NonNull - private String customerId; // VCUSCUN - Obligatorio (Numero de cliente IBS) + private String customerId; // VCUSCUN - Obligatorio (Numero de cliente IBS) + @NonNull + private Device device; private String bankNumber; // VACMBNK - Numero de Banco (filtro) private String currencyCode; // VACMCCY - Moneda (filtro) diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/adapter/PersistenceAdapter.java b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/adapter/PersistenceAdapter.java index 177e0fa..bc236bb 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/adapter/PersistenceAdapter.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/adapter/PersistenceAdapter.java @@ -41,7 +41,7 @@ public class PersistenceAdapter implements PersistenceRepository { log.info("Cuentas obtenidas por el SP: {}", accountsFromSP.size()); if(accountsFromSP.isEmpty()) { - throw HttpStatusCodeException.badRequest("400"); + throw HttpStatusCodeException.noContent("VRN02"); } return CustomerProductAndServiceDirectory.builder() diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/persistence/repository/AccountRepository.java b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/persistence/repository/AccountRepository.java index 80d4875..9dc0895 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/persistence/repository/AccountRepository.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/persistence/repository/AccountRepository.java @@ -63,7 +63,7 @@ public class AccountRepository { !StringUtil.isNullOrEmpty(results.get(0).getDscError()) && results.get(0).getDscError().toUpperCase().equals(dataSourceConfig.getSpIbsError()) ) { - throw new PersistenceException("ERROR", results.get(0).getDscError()); + throw new PersistenceException("VRN01", results.get(0).getDscError()); } } catch (SQLException e) { log.error("Error en conexion o ejecucion del SP {}: {}", spCall, e.getMessage()); diff --git a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/resource/LegalCustomerProductDirectoryResource.java b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/resource/LegalCustomerProductDirectoryResource.java index 83d5307..75e0263 100644 --- a/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/resource/LegalCustomerProductDirectoryResource.java +++ b/src/main/java/com/banesco/module/legal_customer_product_directory/infrastructure/resource/LegalCustomerProductDirectoryResource.java @@ -1,8 +1,7 @@ package com.banesco.module.legal_customer_product_directory.infrastructure.resource; -import com.banesco.common.application.helper.MessageHelper; -import com.banesco.common.domain.exception.HttpStatusCodeException; import com.banesco.common.domain.model.ApiResponse; +import com.banesco.common.domain.model.Device; import com.banesco.common.domain.model.StatusResponse; import com.banesco.module.legal_customer_product_directory.application.usecase.LegalCustomerProductDirectoryUseCase; import com.banesco.module.legal_customer_product_directory.domain.dto.request.LegalCustomerProductDirectoryRequest; @@ -30,14 +29,11 @@ import java.util.Objects; public class LegalCustomerProductDirectoryResource { private final LegalCustomerProductDirectoryUseCase useCase; - private final MessageHelper messageHelper; @Inject public LegalCustomerProductDirectoryResource( - MessageHelper messageHelper, LegalCustomerProductDirectoryUseCase useCase ) { - this.messageHelper = messageHelper; this.useCase = useCase; } @@ -45,7 +41,7 @@ public class LegalCustomerProductDirectoryResource { @Path("/retrieve/{customerId : (?!retrieve$).*}") @Operation( summary = "Recuperar productos de cliente legal", - description = "Consulta masiva de cuentas por numero de cliente IBS" + description = "Consulta masiva de cuentas por numero de cliente " ) @APIResponses(value = { @APIResponse( @@ -322,7 +318,7 @@ public class LegalCustomerProductDirectoryResource { }) public Response retrieve( @PathParam("customerId") - @Parameter(description = "Numero de cliente IBS (VCUSCUN)", example = "200053197") + @Parameter(description = "Numero de cliente (VCUSCUN)", example = "200053197") String customerId, @QueryParam("customerReferenceFintechId") @@ -371,32 +367,50 @@ public class LegalCustomerProductDirectoryResource { @QueryParam("casheaIndicator") @Parameter(description = "Indicador cash (VCASHEA). 'SI'=En tabla cashea, 'NO'=No en tabla cashea", example = "SI") - String casheaIndicator - ) { - log.info("Iniciando consulta para cliente IBS: {}", customerId); + String casheaIndicator, - try { - return Response.ok(useCase.execute( - LegalCustomerProductDirectoryRequest.builder() - .customerId(Objects.toString(customerId, "")) - .customerReferenceFintechId(Objects.toString(customerReferenceFintechId, "")) - .appId(Objects.toString(appId, "")) - .bankNumber(Objects.toString(bankNumber, "")) - .currencyCode(Objects.toString(currencyCode, "")) - .accountStatus(Objects.toString(accountStatus, "")) - .productCvCode(Objects.toString(productCvCode, "")) - .productCode(Objects.toString(productCode, "")) - .channelCode(Objects.toString(channelCode, "")) - .serviceType(Objects.toString(serviceType, "")) - .affiliationStatus(Objects.toString(affiliationStatus, "")) - .limitType(Objects.toString(limitType, "")) - .casheaIndicator(Objects.toString(casheaIndicator, "")) - .build() - )).build(); - } catch (HttpStatusCodeException e) { - return messageHelper.handleException(e); - } catch (Exception e) { - return messageHelper.handleGenericException(e); - } + @QueryParam("deviceType") + @Parameter(description = "Tipo de dispositivo", example = "Mobile") + String deviceType, + + @QueryParam("deviceDescription") + @Parameter(description = "Descripcion del dispositivo", example = "Xiaomi Note 11 PRO") + String deviceDescription, + + @QueryParam("deviceIp") + @Parameter(description = "Direccion IP del dispositivo", example = "127.0.0.1") + String deviceIp, + + @QueryParam("deviceSessionReference") + @Parameter(description = "Referencia de la peticion del dispositivo", example = "12345678901304") + String deviceSessionReference + ) { + log.info("Iniciando consulta para cliente : {}", customerId); + + return useCase.execute( + LegalCustomerProductDirectoryRequest.builder() + .customerId(Objects.toString(customerId, "")) + .customerReferenceFintechId(Objects.toString(customerReferenceFintechId, "")) + .appId(Objects.toString(appId, "")) + .bankNumber(Objects.toString(bankNumber, "")) + .currencyCode(Objects.toString(currencyCode, "")) + .accountStatus(Objects.toString(accountStatus, "")) + .productCvCode(Objects.toString(productCvCode, "")) + .productCode(Objects.toString(productCode, "")) + .channelCode(Objects.toString(channelCode, "")) + .serviceType(Objects.toString(serviceType, "")) + .affiliationStatus(Objects.toString(affiliationStatus, "")) + .limitType(Objects.toString(limitType, "")) + .casheaIndicator(Objects.toString(casheaIndicator, "")) + .device( + Device.builder() + .deviceType(deviceType) + .deviceDescription(deviceDescription) + .deviceIp(deviceIp) + .deviceSessionReference(deviceSessionReference) + .build() + ) + .build() + ); } } \ No newline at end of file diff --git a/src/main/resources/application-dev.yml b/src/main/resources/application-dev.yml index 06f597a..2bf7a2f 100644 --- a/src/main/resources/application-dev.yml +++ b/src/main/resources/application-dev.yml @@ -23,7 +23,7 @@ api: dom-legal-customer-product-directory: messages: key: 'dom-legal-customer-product-directory' - content: '[{"backendCode":"200","httpCode":200,"statusCode":"200","description":"Operacion exitosa"},{"backendCode":"R404","httpCode":404,"statusCode":"404","description":"Datos de validacion no encontrado."},{"backendCode":"503","httpCode":503,"statusCode":"503","description":"Uso interno"},{"backendCode":"422","httpCode":422,"statusCode":"422","description":"Uso interno"},{"backendCode":"500","httpCode":500,"statusCode":"500","description":"Uso interno"},{"backendCode":"100","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-382505","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-380002","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"ERROR","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"400","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"401","httpCode":401,"statusCode":"401","description":"Uso interno"},{"backendCode":"403","httpCode":403,"statusCode":"403","description":"Uso interno"},{"backendCode":"404","httpCode":404,"statusCode":"404","description":"Uso interno"},{"backendCode":"default","httpCode":409,"statusCode":"409","description":"Conflicto"},{"backendCode":"424","httpCode":424,"statusCode":"424","description":"Error de dependencia"},{"backendCode":"VDE01","httpCode":400,"statusCode":"VDE01","description":"VDE01 - Error en dato de entrada obligatorio: %s"},{"backendCode":"VDE02","httpCode":400,"statusCode":"VDE02","description":"VDE02 - Error en valor permitido para campo: %s"},{"backend_code":"204","http_code":"200","status_code":"200","description":"Cliente sin productos","status":"ok"}]' + content: '[{"backendCode":"200","httpCode":200,"statusCode":"200","description":"Operacion exitosa"},{"backendCode":"R404","httpCode":404,"statusCode":"404","description":"Datos de validacion no encontrado."},{"backendCode":"503","httpCode":503,"statusCode":"503","description":"Uso interno"},{"backendCode":"422","httpCode":422,"statusCode":"422","description":"Uso interno"},{"backendCode":"500","httpCode":500,"statusCode":"500","description":"Uso interno"},{"backendCode":"100","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-382505","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-380002","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"ERROR","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"400","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"401","httpCode":401,"statusCode":"401","description":"Uso interno"},{"backendCode":"403","httpCode":403,"statusCode":"403","description":"Uso interno"},{"backendCode":"404","httpCode":404,"statusCode":"404","description":"Uso interno"},{"backendCode":"default","httpCode":409,"statusCode":"409","description":"Conflicto"},{"backendCode":"424","httpCode":424,"statusCode":"424","description":"Error de dependencia"},{"backendCode":"VDE01","httpCode":400,"statusCode":"VDE01","description":"VDE01 - Error en dato de entrada obligatorio: %s"},{"backendCode":"VDE02","httpCode":400,"statusCode":"VDE02","description":"VDE02 - Error en valor permitido para campo: %s"},{"backendCode":"VRN01","httpCode":"400","statusCode":"VRN01","description":"Campo Codigo de IBS Requerido"},{"backendCode":"VRN02","httpCode":"204","statusCode":"VRN02","description":"Cliente sin productos"}]' datasource: sp: diff --git a/src/main/resources/configmap.yaml b/src/main/resources/configmap.yaml index 38fb39b..9eebc2d 100644 --- a/src/main/resources/configmap.yaml +++ b/src/main/resources/configmap.yaml @@ -8,7 +8,7 @@ metadata: creationTimestamp: '2026-01-12T22:23:07Z' annotations: kubectl.kubernetes.io/last-applied-configuration: | - {"apiVersion":"v1","data":{"api.allowed.request-validation.account-status":"^(A|D|ACTBSUSD)$","api.allowed.request-validation.cachea-indicator":"^(SI|NO)$","api.allowed.request-validation.customer-ibs-number":"\\d+","api.allowed.request-validation.limit-type":"^(PAG|REC)$","api.allowed.request-validation.product-cv-code":"^(CV|CVFL)$","api.dom-legal-customer-product-directory.messages.content":"[{\"backendCode\":\"200\",\"httpCode\":200,\"statusCode\":\"200\",\"description\":\"Operacion exitosa\"},{\"backendCode\":\"R404\",\"httpCode\":404,\"statusCode\":\"404\",\"description\":\"Datos de validación no encontrado.\"},{\"backendCode\":\"503\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"Uso interno\"},{\"backendCode\":\"422\",\"httpCode\":422,\"statusCode\":\"422\",\"description\":\"Uso interno\"},{\"backendCode\":\"500\",\"httpCode\":500,\"statusCode\":\"500\",\"description\":\"Uso interno\"},{\"backendCode\":\"100\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"OSB-382505\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"OSB-380002\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"ERROR\",\"httpCode\":400,\"statusCode\":\"400\",\"description\":\"Uso interno\"},{\"backendCode\":\"400\",\"httpCode\":400,\"statusCode\":\"400\",\"description\":\"Uso interno\"},{\"backendCode\":\"401\",\"httpCode\":401,\"statusCode\":\"401\",\"description\":\"Uso interno\"},{\"backendCode\":\"403\",\"httpCode\":403,\"statusCode\":\"403\",\"description\":\"Uso interno\"},{\"backendCode\":\"404\",\"httpCode\":404,\"statusCode\":\"404\",\"description\":\"Uso interno\"},{\"backendCode\":\"default\",\"httpCode\":409,\"statusCode\":\"409\",\"description\":\"Conflicto\"},{\"backendCode\":\"424\",\"httpCode\":424,\"statusCode\":\"424\",\"description\":\"Error de dependencia\"},{\"backendCode\":\"VDE01\",\"httpCode\":400,\"statusCode\":\"VDE01\",\"description\":\"VDE01 - Error en dato de entrada obligatorio: %s\"},{\"backendCode\":\"VDE02\",\"httpCode\":400,\"statusCode\":\"VDE02\",\"description\":\"VDE02 - Error en valor permitido para campo: %s\"},{\"backend_code\":\"204\",\"http_code\":\"200\",\"status_code\":\"200\",\"description\":\"Cliente sin productos\",\"status\":\"ok\"}]","api.dom-legal-customer-product-directory.messages.key":"dom-legal-customer-product-directory","api.read-messages.from-props":"true","api.source-id":"DLCPD","datasource.sp.allowed.account-relationship-type.parent":"PADRE","datasource.sp.allowed.account-status.disable":"D","datasource.sp.allowed.account-status.enable":"A","datasource.sp.allowed.account-type.current":"DDA,MMK","datasource.sp.allowed.account-type.interest-arrangement":"MMK","datasource.sp.allowed.account-type.saving":"SAV","datasource.sp.allowed.currency.base":"BS","datasource.sp.errors.ibs":"DEBE ESPECIFICAR EL NRO DE CLIENTE","datasource.sp.name":"BANCYFIL2.CONCTABOLE","quarkus.application.name":"dom-legal-customer-product-directory","quarkus.application.version":"1.0.0","quarkus.datasource.db-kind":"db2 ","quarkus.datasource.health.enabled":"false","quarkus.datasource.jdbc.acquisition-timeout":"20","quarkus.datasource.jdbc.additional-jdbc-properties.currentSchema":"BANCYFIL2","quarkus.datasource.jdbc.additional-jdbc-properties.retrieveMessagesFromServerOnGetMessage":"true","quarkus.datasource.jdbc.additional-jdbc-properties.useJDBC4ColumnNameAndLabelSemantics":"2","quarkus.datasource.jdbc.background-validation-interval":"120000","quarkus.datasource.jdbc.driver":"com.ibm.db2.jcc.DB2Driver","quarkus.datasource.jdbc.idle-removal-interval":"300000","quarkus.datasource.jdbc.initial-size":"5","quarkus.datasource.jdbc.leak-detection-interval":"60000","quarkus.datasource.jdbc.max-lifetime":"900000","quarkus.datasource.jdbc.max-size":"30","quarkus.datasource.jdbc.min-size":"5","quarkus.datasource.jdbc.url":"jdbc:db2://10.137.0.138:446/S100906D","quarkus.datasource.jdbc.validation-query-sql":"SELECT 1 FROM SYSIBM.SYSDUMMY1","quarkus.datasource.password":"${DB2_PASSWORD}","quarkus.datasource.username":"${DB2_USERNAME}","quarkus.debug.print-startup-times":"true","quarkus.debug.reflection":"false","quarkus.http.idle-timeout":"30s","quarkus.http.non-application-root-path":"actuator","quarkus.http.port":"8080","quarkus.log.console.enable":"true","quarkus.log.console.format":"%d{HH:mm:ss.SSS} %-5p [%t] [%X{requestId}] %c{1} - %s%e%n","quarkus.log.level":"INFO","quarkus.profile":"dev","quarkus.smallrye-health.liveness-path":"/actuator/health/live","quarkus.smallrye-health.readiness-path":"/actuator/health/ready","quarkus.smallrye-health.root-path":"/actuator/health","quarkus.smallrye-health.ui.enable":"false","quarkus.smallrye-openapi.enable":"true","quarkus.smallrye-openapi.path":"/openapi","quarkus.swagger-ui.always-include":"true","quarkus.swagger-ui.path":"/swagger-ui","quarkus.thread-pool.core-threads":"1","quarkus.thread-pool.max-threads":"100"},"kind":"ConfigMap","metadata":{"annotations":{},"app":"dom-legal-customer-product-directory","labels":null,"name":"configmap-dom-legal-customer-product-directory","namespace":"proyecto-prueba-ja"}} + {"apiVersion":"v1","data":{"api.allowed.request-validation.account-status":"^(A|D|ACTBSUSD)$","api.allowed.request-validation.cachea-indicator":"^(SI|NO)$","api.allowed.request-validation.customer-ibs-number":"\\d+","api.allowed.request-validation.limit-type":"^(PAG|REC)$","api.allowed.request-validation.product-cv-code":"^(CV|CVFL)$","api.dom-legal-customer-product-directory.messages.content":"[{\"backendCode\":\"200\",\"httpCode\":200,\"statusCode\":\"200\",\"description\":\"Operacion exitosa\"},{\"backendCode\":\"R404\",\"httpCode\":404,\"statusCode\":\"404\",\"description\":\"Datos de validación no encontrado.\"},{\"backendCode\":\"503\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"Uso interno\"},{\"backendCode\":\"422\",\"httpCode\":422,\"statusCode\":\"422\",\"description\":\"Uso interno\"},{\"backendCode\":\"500\",\"httpCode\":500,\"statusCode\":\"500\",\"description\":\"Uso interno\"},{\"backendCode\":\"100\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"OSB-382505\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"OSB-380002\",\"httpCode\":503,\"statusCode\":\"503\",\"description\":\"VDR13 - OSB Disponible\"},{\"backendCode\":\"ERROR\",\"httpCode\":400,\"statusCode\":\"400\",\"description\":\"Uso interno\"},{\"backendCode\":\"400\",\"httpCode\":400,\"statusCode\":\"400\",\"description\":\"Uso interno\"},{\"backendCode\":\"401\",\"httpCode\":401,\"statusCode\":\"401\",\"description\":\"Uso interno\"},{\"backendCode\":\"403\",\"httpCode\":403,\"statusCode\":\"403\",\"description\":\"Uso interno\"},{\"backendCode\":\"404\",\"httpCode\":404,\"statusCode\":\"404\",\"description\":\"Uso interno\"},{\"backendCode\":\"default\",\"httpCode\":409,\"statusCode\":\"409\",\"description\":\"Conflicto\"},{\"backendCode\":\"424\",\"httpCode\":424,\"statusCode\":\"424\",\"description\":\"Error de dependencia\"},{\"backendCode\":\"VDE01\",\"httpCode\":400,\"statusCode\":\"VDE01\",\"description\":\"VDE01 - Error en dato de entrada obligatorio: %s\"},{\"backendCode\":\"VDE02\",\"httpCode\":400,\"statusCode\":\"VDE02\",\"description\":\"VDE02 - Error en valor permitido para campo: %s\"},{\"backendCode\":\"204\",\"httpCode\":\"200\",\"statusCode\":\"200\",\"description\":\"Cliente sin productos\",\"status\":\"ok\"}]","api.dom-legal-customer-product-directory.messages.key":"dom-legal-customer-product-directory","api.read-messages.from-props":"true","api.source-id":"DLCPD","datasource.sp.allowed.account-relationship-type.parent":"PADRE","datasource.sp.allowed.account-status.disable":"D","datasource.sp.allowed.account-status.enable":"A","datasource.sp.allowed.account-type.current":"DDA,MMK","datasource.sp.allowed.account-type.interest-arrangement":"MMK","datasource.sp.allowed.account-type.saving":"SAV","datasource.sp.allowed.currency.base":"BS","datasource.sp.errors.ibs":"DEBE ESPECIFICAR EL NRO DE CLIENTE","datasource.sp.name":"BANCYFIL2.CONCTABOLE","quarkus.application.name":"dom-legal-customer-product-directory","quarkus.application.version":"1.0.0","quarkus.datasource.db-kind":"db2 ","quarkus.datasource.health.enabled":"false","quarkus.datasource.jdbc.acquisition-timeout":"20","quarkus.datasource.jdbc.additional-jdbc-properties.currentSchema":"BANCYFIL2","quarkus.datasource.jdbc.additional-jdbc-properties.retrieveMessagesFromServerOnGetMessage":"true","quarkus.datasource.jdbc.additional-jdbc-properties.useJDBC4ColumnNameAndLabelSemantics":"2","quarkus.datasource.jdbc.background-validation-interval":"120000","quarkus.datasource.jdbc.driver":"com.ibm.db2.jcc.DB2Driver","quarkus.datasource.jdbc.idle-removal-interval":"300000","quarkus.datasource.jdbc.initial-size":"5","quarkus.datasource.jdbc.leak-detection-interval":"60000","quarkus.datasource.jdbc.max-lifetime":"900000","quarkus.datasource.jdbc.max-size":"30","quarkus.datasource.jdbc.min-size":"5","quarkus.datasource.jdbc.url":"jdbc:db2://10.137.0.138:446/S100906D","quarkus.datasource.jdbc.validation-query-sql":"SELECT 1 FROM SYSIBM.SYSDUMMY1","quarkus.datasource.password":"${DB2_PASSWORD}","quarkus.datasource.username":"${DB2_USERNAME}","quarkus.debug.print-startup-times":"true","quarkus.debug.reflection":"false","quarkus.http.idle-timeout":"30s","quarkus.http.non-application-root-path":"actuator","quarkus.http.port":"8080","quarkus.log.console.enable":"true","quarkus.log.console.format":"%d{HH:mm:ss.SSS} %-5p [%t] [%X{requestId}] %c{1} - %s%e%n","quarkus.log.level":"INFO","quarkus.profile":"dev","quarkus.smallrye-health.liveness-path":"/actuator/health/live","quarkus.smallrye-health.readiness-path":"/actuator/health/ready","quarkus.smallrye-health.root-path":"/actuator/health","quarkus.smallrye-health.ui.enable":"false","quarkus.smallrye-openapi.enable":"true","quarkus.smallrye-openapi.path":"/openapi","quarkus.swagger-ui.always-include":"true","quarkus.swagger-ui.path":"/swagger-ui","quarkus.thread-pool.core-threads":"1","quarkus.thread-pool.max-threads":"100"},"kind":"ConfigMap","metadata":{"annotations":{},"app":"dom-legal-customer-product-directory","labels":null,"name":"configmap-dom-legal-customer-product-directory","namespace":"proyecto-prueba-ja"}} managedFields: - manager: kubectl-client-side-apply operation: Update @@ -110,7 +110,7 @@ data: quarkus.datasource.jdbc.additional-jdbc-properties.currentSchema: BANCYFIL2 quarkus.datasource.jdbc.additional-jdbc-properties.retrieveMessagesFromServerOnGetMessage: 'true' datasource.sp.allowed.account-status.enable: A - api.dom-legal-customer-product-directory.messages.content: '[{"backendCode":"200","httpCode":200,"statusCode":"200","description":"Operacion exitosa"},{"backendCode":"R404","httpCode":404,"statusCode":"404","description":"Datos de validación no encontrado."},{"backendCode":"503","httpCode":503,"statusCode":"503","description":"Uso interno"},{"backendCode":"422","httpCode":422,"statusCode":"422","description":"Uso interno"},{"backendCode":"500","httpCode":500,"statusCode":"500","description":"Uso interno"},{"backendCode":"100","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-382505","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-380002","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"ERROR","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"400","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"401","httpCode":401,"statusCode":"401","description":"Uso interno"},{"backendCode":"403","httpCode":403,"statusCode":"403","description":"Uso interno"},{"backendCode":"404","httpCode":404,"statusCode":"404","description":"Uso interno"},{"backendCode":"default","httpCode":409,"statusCode":"409","description":"Conflicto"},{"backendCode":"424","httpCode":424,"statusCode":"424","description":"Error de dependencia"},{"backendCode":"VDE01","httpCode":400,"statusCode":"VDE01","description":"VDE01 - Error en dato de entrada obligatorio: %s"},{"backendCode":"VDE02","httpCode":400,"statusCode":"VDE02","description":"VDE02 - Error en valor permitido para campo: %s"},{"backend_code":"204","http_code":"200","status_code":"200","description":"Cliente sin productos","status":"ok"}]' + api.dom-legal-customer-product-directory.messages.content: '[{"backendCode":"200","httpCode":200,"statusCode":"200","description":"Operacion exitosa"},{"backendCode":"R404","httpCode":404,"statusCode":"404","description":"Datos de validación no encontrado."},{"backendCode":"503","httpCode":503,"statusCode":"503","description":"Uso interno"},{"backendCode":"422","httpCode":422,"statusCode":"422","description":"Uso interno"},{"backendCode":"500","httpCode":500,"statusCode":"500","description":"Uso interno"},{"backendCode":"100","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-382505","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"OSB-380002","httpCode":503,"statusCode":"503","description":"VDR13 - OSB Disponible"},{"backendCode":"ERROR","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"400","httpCode":400,"statusCode":"400","description":"Uso interno"},{"backendCode":"401","httpCode":401,"statusCode":"401","description":"Uso interno"},{"backendCode":"403","httpCode":403,"statusCode":"403","description":"Uso interno"},{"backendCode":"404","httpCode":404,"statusCode":"404","description":"Uso interno"},{"backendCode":"default","httpCode":409,"statusCode":"409","description":"Conflicto"},{"backendCode":"424","httpCode":424,"statusCode":"424","description":"Error de dependencia"},{"backendCode":"VDE01","httpCode":400,"statusCode":"VDE01","description":"VDE01 - Error en dato de entrada obligatorio: %s"},{"backendCode":"VDE02","httpCode":400,"statusCode":"VDE02","description":"VDE02 - Error en valor permitido para campo: %s"},{"backendCode":"VRN01","httpCode":"400","statusCode":"VRN01","description":"Campo Codigo de IBS Requerido"},{"backendCode":"VRN02","httpCode":"204","statusCode":"VRN02","description":"Cliente sin productos"}]' quarkus.log.console.format: '%d{HH:mm:ss.SSS} %-5p [%t] [%X{requestId}] %c{1} - %s%e%n' quarkus.datasource.jdbc.additional-jdbc-properties.useJDBC4ColumnNameAndLabelSemantics: '2' datasource.sp.name: BANCYFIL2.CONCTABOLE