public RespuestaSimpleQueryTxDTO SimpleQueryTx(RequerimientoSimpleQueryTxDTO dto) { //using (var service = new PaymentServicePlatform()) using (var service = NPSWSServiceWrapper.GetService(_UrlNPS)) { try { string secureHash = HashNPS.ObtenerHashSimpleQueryTx(dto); var response = service.SimpleQueryTx(new RequerimientoStruct_SimpleQueryTx { psp_Version = dto.Version, psp_MerchantId = dto.MerchantId, psp_QueryCriteria = dto.QueryCriteria, psp_QueryCriteriaId = dto.QueryCriteriaId, psp_PosDateTime = dto.PosDateTime.ToString("yyyy-MM-dd HH:mm:ss"), psp_SecureHash = secureHash }.AssignNullToEmptyStrings()); return(new DTOGenerador().ObtenerRespuestaSimpleQueryTxDTO(response)); } catch (Exception ex) { Tracker.WriteTrace(string.Format($"Error en metodo ServiciosNPS.SimpleQueryTx: {ex.Message}. Datos Enviados: {Tracker.SerializarObjeto(dto)}"), false, Tracker.TraceType.Error); var response = new DTOGenerador().ObtenerRespuestaSimpleQueryTxDTO(null); response.ErrorMessage = ex.Message + "\nInner Exception: " + (ex.InnerException != null ? ex.InnerException.Message : string.Empty); return(response); } } }
internal static string ObtenerHashSimpleQueryTx(RequerimientoSimpleQueryTxDTO dto) { string hash = string.Empty; try { hash = dto.MerchantId + dto.PosDateTime.ToString("yyyy-MM-dd HH:mm:ss") + dto.QueryCriteria + dto.QueryCriteriaId + dto.Version + dto.SecretKey; } catch (Exception) { throw; } return(CodificarHash(hash)); }
public string ActualizarEstadoPago(string idPagoNPS) { string respuesta = string.Empty; RequerimientoSimpleQueryTxDTO dtoRequest = new RequerimientoSimpleQueryTxDTO(); //datos generales------ string urlNps = NPSConfiguracion.Url; dtoRequest.Version = NPSConfiguracion.Version; dtoRequest.MerchantId = NPSConfiguracion.MerchantID; dtoRequest.SecretKey = NPSConfiguracion.NPSSecretKey; dtoRequest.QueryCriteria = NPSConfiguracion.QueryCriteriaMerchTxRef; dtoRequest.QueryCriteriaId = idPagoNPS; //idPago es el merchTxRef; dtoRequest.PosDateTime = DateTime.Now; //dtoLog.IdTransaccion = idTransaccion; //dtoLog.FechaSolicitud = DateTime.Now; //dtoLog.MensajeSolicitud = dtoRequest; //dtoLog.NombreServicio = "NPS-SimpleQueryTx"; //dtoLog.IdRequest = idRequest; RespuestaSimpleQueryTxDTO dtoResponse = new ServiciosNPS(urlNps).SimpleQueryTx(dtoRequest); //dtoLog.MensajeRespuesta = dtoResponse; //dtoLog.FechaRespuesta = DateTime.Now; //log.RegistrarLog(dtoLog); if (dtoResponse.ErrorMessage == null) { using (var Context = new WebServiceDataContext()) { //log.RegistrarLog(idPago, dtoResponse.Transaction); //using (var tx = new WebServiceDataContext().Connection.BeginTransaction()) //{ PAGO_NPS pagoNPS = Context.PAGO_NPS.First(c => c.IdPagoNPS == int.Parse(idPagoNPS)); //si la operación de consulta fue exitosa y encontró una transacción if (dtoResponse.ResponseCod.ToString() == RespuestaSimpleQueryTxNPS.Exitosa) { //pagoNPS.IdPago = idPago; pagoNPS.IdEstadoNPS = ObtenerIdEstadoNPS(dtoResponse.Transaction.ResponseCod); pagoNPS.MotivoEstado = dtoResponse.Transaction.ResponseMsg; pagoNPS.MotivoEstado += dtoResponse.Transaction.ResponseExtended != null?string.Format(" {0}", dtoResponse.Transaction.ResponseExtended) : ""; pagoNPS.IdTransaccionNPS = dtoResponse.Transaction.TransactionId; //pagoNPS.IdTransaccion = !string.IsNullOrEmpty(idTransaccion) ? new Guid(idTransaccion) : (Guid?)null; pagoNPS.ResponseCod = dtoResponse.ResponseCod; pagoNPS.ResponseMsg = dtoResponse.ResponseMsg; pagoNPS.ResponseExtended = dtoResponse.ResponseExtended; //hay que ver si el estado de la transacción no se cambia en otra parte //pagoNPS.Transaccion.EstadoPago = ObtenerIdEstadoTransaccion(pagoNPS.IdEstadoNPS); if (pagoNPS.IdEstadoNPS != (int)EstadoNPS.AprobadaAutorizada && pagoNPS.IdEstadoNPS != (int)EstadoNPS.PendienteEnComprador_CashPayment) { respuesta = pagoNPS.MotivoEstado; } } else { //falta definir en qué estado quedará si no se encuentra ninguna trx con SimpleQueryTx //actualmente queda en estado Iniciada respuesta = dtoResponse.ResponseMsg + " - " + dtoResponse.ResponseExtended; } Context.SubmitChanges(); //tx.Commit(); //} } } else { respuesta = dtoResponse.ErrorMessage; } return(respuesta); }