private bool AgregarPago(int idUsuario, Usuario_Tarjeta tarjeta, double total, string referencia, CarritoDeCompra carrito) { using (var _dbContext = new MercampoEntities()) { Startup.OpenDatabaseConnection(_dbContext); if (_dbContext.Database.Connection.State != ConnectionState.Open) { return(false); } Pago newPago = _dbContext.Pagoes.Add(new Pago { idUsuario = idUsuario, tipoTarjeta = tarjeta.tipoTarjeta, digitosTarjeta = tarjeta.digitosTarjeta, total = total, fecha = DateTime.Now, Referencia = referencia }); _dbContext.SaveChanges(); foreach (var paquete in carrito.Paquetes) { if (paquete.Beneficios.Count() < 1) { Pago_Concepto pagoConcepto = _dbContext.Pago_Concepto.Add(new Pago_Concepto { idPago = newPago.id, tipo = paquete.EsRenovacion(), nombrePaquete = paquete.Nombre, mesesPaquete = paquete.Meses, precioPaquete = paquete.Precio, descripcionPaquete = string.Empty }); continue; } foreach (var beneficio in paquete.Beneficios) { Pago_Concepto pagoConcepto = _dbContext.Pago_Concepto.Add(new Pago_Concepto { idPago = newPago.id, tipo = paquete.EsRenovacion(), nombrePaquete = paquete.Nombre, mesesPaquete = paquete.Meses, precioPaquete = paquete.Precio, descripcionPaquete = string.Empty, descripcionBeneficio = beneficio.Descripcion, precioBeneficio = beneficio.Precio, tipoBeneficio = beneficio.Tipo }); } } _dbContext.SaveChanges(); _dbContext.Database.Connection.Close(); return(true); } }
public bool RealizarCargoTarjeta(int id, string tarjetaToken, string sessionId, CarritoDeCompra carrito, out string resultadoJson) { if (carrito == null || carrito.TotalCarrito <= 0.0) { resultadoJson = new ResultadoCargo(false, ResultadoCargoTarjeta.ErrorInterno, mensaje: "El carrito de compras esta vacio").AsJson(); return(false); } HttpRequest request = HttpContext.Current.Request; var usuario = getUsuarioPortalActual(request); if (usuario.Id != id) { resultadoJson = new ResultadoCargo(false, ResultadoCargoTarjeta.ErrorInterno, mensaje: "Error favor de hacer login").AsJson(); return(false); } using (var _dbContext = new MercampoEntities()) { Startup.OpenDatabaseConnection(_dbContext); if (_dbContext.Database.Connection.State != ConnectionState.Open) { resultadoJson = new ResultadoCargo(false, ResultadoCargoTarjeta.ErrorInterno, mensaje: "Error en el servidor, vuelva a intentarlo de nuevo en unos minutos").AsJson(); return(false); } try { Customer cliente = Startup.OpenPayLib.CustomerService.Get(usuario.IdConekta); if (cliente == null) { resultadoJson = new ResultadoCargo(false, ResultadoCargoTarjeta.ErrorInterno, mensaje: "Error en el servidor, vuelva a intentarlo de nuevo en unos minutos").AsJson(); return(false); } ChargeRequest chargeRequest = new ChargeRequest(); chargeRequest.Method = "card"; chargeRequest.SourceId = tarjetaToken; chargeRequest.Amount = new decimal(carrito.TotalCarrito); chargeRequest.Currency = "MXN"; chargeRequest.Description = "Servicio de anuncios Mercampo.mx"; chargeRequest.OrderId = getToken(); chargeRequest.DeviceSessionId = sessionId; chargeRequest.SendEmail = true; Charge cargo = Startup.OpenPayLib.ChargeService.Create(usuario.IdConekta, chargeRequest); Usuario_Tarjeta tarjeta = _dbContext.Usuario_Tarjeta.Where(t => t.tokenTarjeta == tarjetaToken).FirstOrDefault(); try { AgregarAnuncios(carrito, usuario.Id); } catch (Exception) { Charge charge = Startup.OpenPayLib.ChargeService.Refund(cargo.CustomerId, cargo.Id, "Devolucion del cargo de Mercampo.mx", cargo.Amount); resultadoJson = new ResultadoCargo(false, ResultadoCargoTarjeta.ErrorInterno, mensaje: "Hubo un error interno, favor de volver a intentarlo").AsJson(); return(false); } AgregarPago(usuario.Id, tarjeta, (double)cargo.Amount, cargo.Authorization, carrito); ResultadoCargo resultado = new ResultadoCargo(true, ResultadoCargoTarjeta.Aprobado, cargo.OrderId, cargo.Authorization, "El cargo ha sido exitoso", (double)cargo.Amount); resultadoJson = resultado.AsJson(); return(true); } catch (OpenpayException e) { ResultadoCargoTarjeta res = ResultadoCargoTarjeta.ErrorInterno; if ((int)ResultadoCargoTarjeta.Rechazado == e.ErrorCode) { res = ResultadoCargoTarjeta.Rechazado; } resultadoJson = new ResultadoCargo(false, res, mensaje: TarjetaResultadoHelpers.ObtenerMensajeError((OpenPayErrorCodes)e.ErrorCode)).AsJson(); return(false); } } }