update signature generation & add BOL response

This commit is contained in:
Ramon Ramirez 2026-01-15 17:44:09 -04:00
parent 39227f7cca
commit c16e2b468c
17 changed files with 400 additions and 104 deletions

View File

@ -22,9 +22,8 @@ public class RequestValidatorHelper {
public void validateRequired(
ServiceOrderPaymentSearchRequest request
) {
required(request.getId(), "partyReferenceId");
required(request.getPartyId(), "partyReferenceId");
required(request.getChannelCode(), "channelCode");
required(request.getSignatureIdentifier(), "signatureIdentifier");
required(request.getCustomerReferenceFintechId(), "customerReferenceFintechId");
required(request.getAppId(), "appId");
}
@ -32,7 +31,7 @@ public class RequestValidatorHelper {
public void validateFieldValues(
ServiceOrderPaymentSearchRequest request
) {
validate(request.getId(), config.recipientIdNumber(), "partyReferenceId");
validate(request.getPartyId(), config.recipientIdNumber(), "partyReferenceId");
validate(request.getChannelCode(), config.channelCode(), "channelCode");
}

View File

@ -2,11 +2,14 @@ package com.banesco.module.instruction.domain.model;
import com.banesco.common.domain.exception.HttpStatusCodeException;
import com.banesco.common.domain.model.Identifier;
import com.banesco.module.party.domain.model.Party;
import com.banesco.module.party.domain.model.PartyIdentification;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
import java.util.Arrays;
import java.util.List;
import java.util.Objects;
@Getter
@ -17,14 +20,16 @@ import java.util.Objects;
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class Instruction {
private InstructionIdentification instructionIdentifier; // Request JSON: "recipientId"
private String instructionDescription; // Request JSON: "signature"
private InstructionInvolvement instructionInvolvement; // Request JSON: "recipientId"
private List<InstructionDateTime> instructionDate; // Request JSON: "dateCreate"
private InstructionIdentification instructionIdentifier; // Request JSON: "id"
private InstructionPurposeType instructionPurposeType; // Request JSON: "channelOrigin" (BOLE)
public static Instruction fromResource(
String partyReferenceId,
String channelCode,
String signatureIdentifier
String initiatedDate,
String instructionRequestId,
String channelCode
) {
boolean isChannelCodeValid = (Arrays.stream(
InstructionPurposeType.values()
@ -35,18 +40,39 @@ public class Instruction {
}
return Instruction.builder()
.instructionInvolvement(
InstructionInvolvement.builder()
.partyReference(
Party.builder()
.partyIdentification(List.of(
PartyIdentification.builder()
.partyIdentification(
Identifier.builder()
.identifierValue(Objects.toString(partyReferenceId, ""))
.build()
)
.build()
))
.build()
)
.build()
)
.instructionIdentifier(
InstructionIdentification.builder()
.identification(
Identifier.builder()
.identifierValue(partyReferenceId)
.identifierValue(Objects.toString(instructionRequestId, ""))
.build()
)
.identificationType(InstructionIdentificationType.INSTRUCTION_NUMBER)
.build()
)
.instructionDate(List.of(
InstructionDateTime.builder()
.date(Objects.toString(initiatedDate, ""))
.build()
))
.instructionPurposeType(InstructionPurposeType.valueOf(channelCode))
.instructionDescription(signatureIdentifier)
.build();
}
}

View File

@ -0,0 +1,14 @@
package com.banesco.module.instruction.domain.model;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@Getter
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
public class InstructionDateTime {
private String date;
}

View File

@ -0,0 +1,15 @@
package com.banesco.module.instruction.domain.model;
import com.banesco.module.party.domain.model.Party;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@Getter
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
public class InstructionInvolvement {
private Party partyReference;
}

View File

@ -37,7 +37,7 @@ public class ServiceOrderPaymentSearchService implements ServiceOrderPaymentSear
public ApiResponse<ServiceOrderPaymentSearchResponse> execute(
ServiceOrderPaymentSearchRequest request
) {
log.info("Iniciando ejecucion para el transaccion: {}", request.getId());
log.info("Iniciando ejecucion para el transaccion: {}", request.getPartyId());
validate(request);

View File

@ -1,6 +1,7 @@
package com.banesco.module.service_order_payment_search.domain.dto.request;
import com.banesco.module.instruction.domain.model.Instruction;
import com.banesco.module.instruction.domain.model.InstructionPurposeType;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@ -23,22 +24,51 @@ public class ServiceOrderPaymentSearchRequest {
@NonNull
private Instruction procedureRequest;
public String getId() {
return getProcedureRequest().getInstructionIdentifier().getIdentification().getIdentifierValue();
public String getPartyId() {
return getProcedureRequest()
.getInstructionInvolvement()
.getPartyReference()
.getPartyIdentification()
.get(0)
.getPartyIdentification()
.getIdentifierValue();
}
public String getInitiatedDate() {
return getProcedureRequest()
.getInstructionDate()
.get(0)
.getDate();
}
public String getPaymentRequestId() {
return getProcedureRequest()
.getInstructionIdentifier()
.getIdentification()
.getIdentifierValue();
}
public String getChannelCode() {
return getProcedureRequest().getInstructionPurposeType().name();
}
public String getSignatureIdentifier() {
return getProcedureRequest().getInstructionDescription();
public boolean isBole() {
return getProcedureRequest().getInstructionPurposeType() == InstructionPurposeType.BOLE;
}
public Map<String, String> toParams() {
return Map.ofEntries(
entry("partyReferenceId", Objects.toString(getPartyId(), "")),
entry("channelCode", Objects.toString(getChannelCode(), ""))
);
}
public Map<String, String> toQueryString() {
return Map.ofEntries(
entry("appId", Objects.toString(getAppId(), "")),
entry("customerReferenceFintechId", Objects.toString(getCustomerReferenceFintechId(), ""))
entry("customerReferenceFintechId", Objects.toString(getCustomerReferenceFintechId(), "")),
entry("initiatedDate", Objects.toString(getInitiatedDate(), "")),
entry("paymentRequestId", Objects.toString(getPaymentRequestId(), ""))
);
}
}

View File

@ -2,6 +2,7 @@ package com.banesco.module.service_order_payment_search.domain.model;
import com.banesco.module.document.domain.model.Document;
import com.banesco.module.transaction.domain.model.Transaction;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@ -11,7 +12,10 @@ import lombok.*;
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class ServicingOrderProcedure {
private Document document; // fileName
private Transaction transaction; // status, accepted, rejected, expired
private Document document; // BOLE: fileName
// BOLE: nroRequest, status, accepted, rejected, expired, dispatchDate, quantity
// BOL: id, requestType, emitterReceptor, status, amount, currency, concept, dateCreate
private Transaction transaction;
}

View File

@ -13,8 +13,6 @@ import jakarta.enterprise.context.ApplicationScoped;
import jakarta.inject.Inject;
import lombok.extern.slf4j.Slf4j;
import java.util.Map;
@Slf4j
@ApplicationScoped
public class BusServiceOrderPaymentSearchClient implements BusinessUseCase {
@ -36,19 +34,13 @@ public class BusServiceOrderPaymentSearchClient implements BusinessUseCase {
ServiceOrderPaymentSearchRequest params,
Class<T> responseType
) {
String partyReferenceId = params.getId();
String channelCode = params.getChannelCode();
String signatureIdentifier = params.getSignatureIdentifier();
String partyReferenceId = params.getPartyId();
HttpRequest request = HttpRequest.forApiResponse(
businessConfig.getUrl(),
HttpRequest.HttpMethod.GET,
responseType
)
.withPathParams(Map.of(
"partyReferenceId", partyReferenceId,
"channelCode", channelCode,
"signatureIdentifier", signatureIdentifier
))
.withPathParams(params.toParams())
.withQueryParams(params.toQueryString())
.withTimeout(
businessConfig.getTimeout().getConnect(),

View File

@ -43,7 +43,7 @@ public class ServiceOrderPaymentSearchResource {
}
@GET
@Path("/retrieve/{partyReferenceId}/{channelCode}/{signatureIdentifier}")
@Path("/retrieve/{partyReferenceId}/{channelCode}")
@Operation(
summary = "Recuperar informacion de la transaccion",
description = "Consulta de una trasanccion de pago por id de archivo"
@ -67,73 +67,234 @@ public class ServiceOrderPaymentSearchResource {
)
}
),
examples = @ExampleObject(
name = "Ejemplo exitoso",
value = """
{
"data": {
"servicingOrderProcedure": [
{
"document": {
"documentName": "TESTING.CSV"
},
"transaction": {
"transactionIdentification": {
"identifierValue": "2"
examples = {
@ExampleObject(
name = "Ejemplo exitoso (BOLE)",
value = """
{
"data": {
"servicingOrderProcedure": [
{
"document": {
"documentName": "TESTING.CSV"
},
"transactionStatus": {
"statusType": "PENDING",
"statusName": "PENDIENTE",
"statusAccepted": 0,
"statusRejected": 0,
"statusExpired": 2
},
"transactionDate": [
{
"dateType": "EXECUTED_DATE",
"date": "2026-01-05 14:35:45.0372395"
"transaction": {
"transactionIdentification": {
"identifierValue": "2"
},
"transactionStatus": {
"statusType": "PENDING",
"statusName": "PENDIENTE",
"statusAccepted": 0,
"statusRejected": 0,
"statusExpired": 2
},
"transactionDate": [
{
"dateType": "EXECUTED_DATE",
"date": "2026-01-05 14:35:45.0372395"
}
],
"transactionDetails": {
"transactionQuantity": 1000
}
}
},
{
"document": {
"documentName": "TESTING.CSV"
},
"transaction": {
"transactionIdentification": {
"identifierValue": "3"
},
"transactionStatus": {
"statusType": "IN_PROGRESS",
"statusName": "EN CURSO",
"statusAccepted": 0,
"statusRejected": 0,
"statusExpired": 5
},
"transactionDate": [
{
"dateType": "EXECUTED_DATE",
"date": "2026-01-05 14:39:52.3840159"
}
],
"transactionDetails": {
"transactionQuantity": 1000
}
],
"transactionDetails": {
"transactionQuantity": 1000
}
}
},
{
"document": {
"documentName": "TESTING.CSV"
]
},
"statusResponse": {
"statusCode": "200",
"message": "Operacion exitosa"
}
}
"""
),
@ExampleObject(
name = "Ejemplo exitoso (BOL)",
value = """
{
"data": {
"servicingOrderProcedure": [
{
"transaction": {
"transactionIdentification": {
"identifierValue": "1"
},
"transactionStatus": {
"statusType": "APPROVED",
"statusName": "Aprobada"
},
"transactionDate": [
{
"dateType": "INITIATED_DATE",
"date": "2024-06-15T10:30:00Z"
}
],
"transactionInvolvement": [
{
"partyReference": {
"partyIdentification": [
{
"partyIdentification": {
"identifierValue": "V20132859"
}
}
]
}
}
],
"financialTransaction": {
"amount": 150.75,
"currencyCode": "VES"
},
"name": "Enviada",
"description": "cobro a pepito"
}
},
"transaction": {
"transactionIdentification": {
"identifierValue": "3"
},
"transactionStatus": {
"statusType": "IN_PROGRESS",
"statusName": "EN CURSO",
"statusAccepted": 0,
"statusRejected": 0,
"statusExpired": 5
},
"transactionDate": [
{
"dateType": "EXECUTED_DATE",
"date": "2026-01-05 14:39:52.3840159"
}
],
"transactionDetails": {
"transactionQuantity": 1000
{
"transaction": {
"transactionIdentification": {
"identifierValue": "2"
},
"transactionStatus": {
"statusType": "PENDING",
"statusName": "Pendiente"
},
"transactionDate": [
{
"dateType": "INITIATED_DATE",
"date": "2024-06-16T14:49:00Z"
}
],
"transactionInvolvement": [
{
"partyReference": {
"partyIdentification": [
{
"partyIdentification": {
"identifierValue": "V20132859"
}
}
]
}
}
],
"financialTransaction": {
"amount": 350.0,
"currencyCode": "VES"
},
"name": "Recibida",
"description": "pago a proveedor"
}
},
{
"transaction": {
"transactionIdentification": {
"identifierValue": "3"
},
"transactionStatus": {
"statusType": "REJECTED",
"statusName": "Rechazado"
},
"transactionDate": [
{
"dateType": "INITIATED_DATE",
"date": "2024-06-17T09:15:00Z"
}
],
"transactionInvolvement": [
{
"partyReference": {
"partyIdentification": [
{
"partyIdentification": {
"identifierValue": "V20132859"
}
}
]
}
}
],
"financialTransaction": {
"amount": 200.0,
"currencyCode": "VES"
},
"name": "Enviada",
"description": "cobro a cliente"
}
},
{
"transaction": {
"transactionIdentification": {
"identifierValue": "4"
},
"transactionStatus": {
"statusType": "APPROVED",
"statusName": "Aprobada"
},
"transactionDate": [
{
"dateType": "INITIATED_DATE",
"date": "2024-06-18T11:20:00Z"
}
],
"transactionInvolvement": [
{
"partyReference": {
"partyIdentification": [
{
"partyIdentification": {
"identifierValue": "V20132859"
}
}
]
}
}
],
"financialTransaction": {
"amount": 750.0,
"currencyCode": "VES"
},
"name": "Recibida",
"description": "pago a proveedor"
}
}
}
]
},
"statusResponse": {
"statusCode": "200",
"message": "Operacion exitosa"
}
}
"""
)
]
},
"statusResponse": {
"statusCode": "200",
"message": "Operacion exitosa"
}
}
"""
)
}
)
),
@APIResponse(
@ -280,9 +441,13 @@ public class ServiceOrderPaymentSearchResource {
@Parameter(description = "Codigo del canal (BOL, BOLE)", required = true, example = "BOLE")
String channelCode,
@PathParam("signatureIdentifier")
@Parameter(description = "Firma del archivo", required = true, example = "f8c226f844339c55bf898162c5d7de5d8116cee6028e1b357414dcc686b3ea85")
String signatureIdentifier
@QueryParam("initiatedDate")
@Parameter(description = "Fecha de creación", example = "2024-06-15T10:30:00Z")
String initiatedDate,
@QueryParam("instructionRequestId")
@Parameter(description = "ID de la peticion de pago", example = "1")
String instructionRequestId
) {
log.info("Iniciando consulta para instruccion de archivo id: {}", partyReferenceId);
@ -292,7 +457,10 @@ public class ServiceOrderPaymentSearchResource {
.customerReferenceFintechId(Objects.toString(customerReferenceFintechId, ""))
.appId(Objects.toString(appId, ""))
.procedureRequest(Instruction.fromResource(
partyReferenceId, channelCode, signatureIdentifier
partyReferenceId,
initiatedDate,
instructionRequestId,
channelCode
))
.build()
)).build();

View File

@ -0,0 +1,19 @@
package com.banesco.module.transaction.domain.model;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
import java.math.BigDecimal;
@Getter
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class FinancialTransaction {
private BigDecimal amount; // BOL: amount
private String currencyCode; // BOL: currency
}

View File

@ -1,6 +1,7 @@
package com.banesco.module.transaction.domain.model;
import com.banesco.common.domain.model.Identifier;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@ -12,9 +13,14 @@ import java.util.List;
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class Transaction {
private Identifier transactionIdentification; // nroRequest
private TransactionStatus transactionStatus; // status, accepted, rejected, expired
private List<TransactionDateTime> transactionDate; // dispatchDate
private TransactionDetails transactionDetails; // quantity
private Identifier transactionIdentification; // BOLE: nroRequest | BOL: id
private TransactionStatus transactionStatus; // BOLE: status, accepted, rejected, expired | BOL: status
private List<TransactionDateTime> transactionDate; // BOLE: dispatchDate | BOL: dateCreate
private TransactionDetails transactionDetails; // BOLE: quantity
private List<TransactionInvolvement> transactionInvolvement; // BOL: emitterReceptor
private FinancialTransaction financialTransaction; // BOL: amount, currency
private String name; // BOL: requestType
private String description; // BOL: concept
}

View File

@ -11,5 +11,5 @@ import lombok.*;
@RegisterForReflection
public class TransactionDateTime {
private TransactionDateTimeType dateType;
private String date;
private String date; // BOLE: dispatchDate | BOL: dateCreate
}

View File

@ -1,5 +1,6 @@
package com.banesco.module.transaction.domain.model;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@ -11,6 +12,7 @@ import java.math.BigDecimal;
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class TransactionDetails {
private BigDecimal transactionQuantity; // quantity
private BigDecimal transactionQuantity; // BOLE: quantity
}

View File

@ -0,0 +1,17 @@
package com.banesco.module.transaction.domain.model;
import com.banesco.module.party.domain.model.Party;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@Getter
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class TransactionInvolvement {
private Party partyReference; // BOL: emitterReceptor
}

View File

@ -1,5 +1,6 @@
package com.banesco.module.transaction.domain.model;
import com.fasterxml.jackson.annotation.JsonInclude;
import io.quarkus.runtime.annotations.RegisterForReflection;
import lombok.*;
@ -9,10 +10,11 @@ import lombok.*;
@NoArgsConstructor
@AllArgsConstructor
@RegisterForReflection
@JsonInclude(JsonInclude.Include.NON_NULL)
public class TransactionStatus {
private TransactionStatusType statusType; // status
private String statusName; // status
private Long statusAccepted; // accepted
private Long statusRejected; // rejected
private Long statusExpired; // expired
private TransactionStatusType statusType; // BOLE: status | BOL: status
private String statusName; // BOLE: status | BOL: status
private Long statusAccepted; // BOLE: accepted
private Long statusRejected; // BOLE: rejected
private Long statusExpired; // BOLE: expired
}

View File

@ -7,6 +7,7 @@ public enum TransactionStatusType {
EXECUTED,
CANCELLED,
CONFIRMED,
APPROVED,
SUSPENDED,
PENDING,
COMPLETED,
@ -15,4 +16,5 @@ public enum TransactionStatusType {
REJECTED,
EXPIRED,
SENT,
RECEIVED,
}

View File

@ -19,4 +19,4 @@ api:
key: 'rec-service-order-payment-search'
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":"VRN04","httpCode":"503","statusCode":"VRN04","description":"Servicio en horario de mantenimiento","status":"error"},{"backendCode":"204","httpCode":"200","statusCode":"200","description":"Cliente sin productos","status":"ok"}]'
rest-client:
bus-service-order-payment-search: '{"url":"http://localhost:8082/service-order-payment-search/retrieve/{partyReferenceId}/{channelCode}/{signatureIdentifier}","timeout":{"connect":15000,"response":15000},"config":{}}'
bus-service-order-payment-search: '{"url":"http://localhost:8082/service-order-payment-search/retrieve/{partyReferenceId}/{channelCode}","timeout":{"connect":15000,"response":15000},"config":{}}'