public static bool ChargeSucceeded(StripeEvent se, string json) { try { var dc = new ManagementContext(); RDN.Library.DataModels.PaymentGateway.Stripe.StripeEventDb even = new RDN.Library.DataModels.PaymentGateway.Stripe.StripeEventDb(); even.CreatedStripeDate = se.Created.GetValueOrDefault(); even.StripeId = se.Id; even.LiveMode = se.LiveMode.GetValueOrDefault(); if (se.Data != null) { //StripeCharge inv = (StripeCharge)se.Data.Object; StripeCharge inv = Stripe.Mapper<StripeCharge>.MapFromJson(se.Data.Object.ToString()); StripeChargeDb nnv = new StripeChargeDb(); even.StripeEventTypeEnum = (byte)StripeEventTypeEnum.charge_succeeded; nnv.AmountInCents = inv.AmountInCents; nnv.AmountInCentsRefunded = inv.AmountInCentsRefunded; nnv.Currency = inv.Currency; nnv.Customer = dc.StripeCustomers.Where(x => x.Id == inv.CustomerId).FirstOrDefault(); nnv.Description = inv.Description; nnv.FailureMessage = inv.FailureMessage; foreach (var fee in inv.FeeDetails) { StripeFeeDb f = new StripeFeeDb(); f.AmountInCents = fee.AmountInCents; f.Application = fee.Application; f.Currency = fee.Currency; f.Description = fee.Description; f.type = fee.type; nnv.FeeDetails.Add(f); } nnv.FeeInCents = inv.FeeInCents; nnv.Id = inv.Id; nnv.Invoice = dc.StripeInvoices.Where(x => x.Id == inv.InvoiceId).FirstOrDefault(); nnv.LiveMode = inv.LiveMode; nnv.Paid = inv.Paid; nnv.Refunded = inv.Refunded; if (inv.StripeCard != null) { nnv.StripeCard = dc.StripeCards.Where(x => x.AddressLine1 == inv.StripeCard.AddressLine1).Where(x => x.Last4 == inv.StripeCard.Last4).FirstOrDefault(); if (nnv.StripeCard == null) { nnv.StripeCard = CreateStripeCard(inv.StripeCard, json); dc.StripeCards.Add(nnv.StripeCard); } } even.Charge = nnv; dc.StripeCharges.Add(nnv); var invoice = (from xx in dc.Invoices where xx.PaymentProviderCustomerId == inv.CustomerId where xx.InvoicePaid == false select xx).OrderByDescending(x => x.Created).FirstOrDefault(); if (invoice == null) EmailServer.EmailServer.SendEmail(ServerConfig.DEFAULT_EMAIL, ServerConfig.DEFAULT_EMAIL_FROM_NAME, ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN, "STRIPE: Invoice Not Found, Can't Be Confirmed", inv.CustomerId + " " + inv.ToString() + json); else { if (invoice.InvoiceStatus == (byte)InvoiceStatus.Subscription_Should_Be_Updated_On_Charge) { //update league subscription League.LeagueFactory.UpdateLeagueSubscriptionPeriod(invoice.Subscription.ValidUntil, true, invoice.Subscription.InternalObject); EmailServer.EmailServer.SendEmail(ServerConfig.DEFAULT_EMAIL, ServerConfig.DEFAULT_EMAIL_FROM_NAME, ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN, "STRIPE: Subscription Updated!!", invoice.InvoiceId + " Amount:" + inv.AmountInCents + ":" + inv.ToString() + json); } invoice.InvoicePaid = true; invoice.InvoiceStatus = (byte)InvoiceStatus.Payment_Successful; invoice.InvoiceStatusUpdated = DateTime.UtcNow; invoice.Merchant = invoice.Merchant; EmailServer.EmailServer.SendEmail(ServerConfig.DEFAULT_EMAIL, ServerConfig.DEFAULT_EMAIL_FROM_NAME, ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN, "STRIPE: New Payment Made!!", invoice.InvoiceId + " Amount:" + inv.AmountInCents + ":" + inv.ToString() + json); } } dc.StripeEvents.Add(even); dc.SaveChanges(); return true; } catch (Exception exception) { ErrorDatabaseManager.AddException(exception, exception.GetType(), additionalInformation: json); } return false; }
public static bool ChargeFailed(StripeEvent se, string json) { try { var dc = new ManagementContext(); RDN.Library.DataModels.PaymentGateway.Stripe.StripeEventDb even = new RDN.Library.DataModels.PaymentGateway.Stripe.StripeEventDb(); even.CreatedStripeDate = se.Created.GetValueOrDefault(); even.StripeId = se.Id; even.LiveMode = se.LiveMode.GetValueOrDefault(); if (se.Data != null) { //StripeCharge inv = (StripeCharge)se.Data.Object; StripeCharge inv = Stripe.Mapper<StripeCharge>.MapFromJson(se.Data.Object.ToString()); StripeChargeDb nnv = new StripeChargeDb(); even.StripeEventTypeEnum = (byte)StripeEventTypeEnum.charge_failed; nnv.AmountInCents = inv.AmountInCents; nnv.AmountInCentsRefunded = inv.AmountInCentsRefunded; nnv.Currency = inv.Currency; nnv.Customer = dc.StripeCustomers.Where(x => x.Id == inv.CustomerId).FirstOrDefault(); nnv.Description = inv.Description; nnv.FailureMessage = inv.FailureMessage; nnv.FeeInCents = inv.FeeInCents; nnv.Id = inv.Id; nnv.Invoice = dc.StripeInvoices.Where(x => x.Id == inv.InvoiceId).FirstOrDefault(); nnv.LiveMode = inv.LiveMode; nnv.Paid = inv.Paid; nnv.Refunded = inv.Refunded; if (inv.StripeCard != null) { nnv.StripeCard = dc.StripeCards.Where(x => x.AddressLine1 == inv.StripeCard.AddressLine1).Where(x => x.Last4 == inv.StripeCard.Last4).FirstOrDefault(); if (nnv.StripeCard == null) { nnv.StripeCard = CreateStripeCard(inv.StripeCard, json); dc.StripeCards.Add(nnv.StripeCard); } } even.Charge = nnv; dc.StripeCharges.Add(nnv); var invoice = (from xx in dc.Invoices where xx.PaymentProviderCustomerId == inv.CustomerId where xx.InvoicePaid == false select xx).OrderByDescending(x => x.Created).FirstOrDefault(); if (invoice == null) EmailServer.EmailServer.SendEmail(ServerConfig.DEFAULT_EMAIL, ServerConfig.DEFAULT_EMAIL_FROM_NAME, ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN, "STRIPE: Invoice Not Found, Can't Be Confirmed, CHARGE FAILED", inv.CustomerId + " " + inv.ToString() + json); else { if (invoice.InvoiceStatus == (byte)InvoiceStatus.Subscription_Should_Be_Updated_On_Charge) { //update league subscription //League.League.UpdateLeagueSubscriptionPeriod(invoice.Subscription.ValidUntil, true, invoice.Subscription.InternalObject); //EmailServer.EmailServer.SendEmail(ServerConfig.DEFAULT_EMAIL, ServerConfig.DEFAULT_EMAIL_FROM_NAME, ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN, "STRIPE: Subscription Updated!!", invoice.InvoiceId + " Amount:" + inv.AmountInCents + ":" + inv.ToString() + json); } invoice.InvoicePaid = false; if (nnv.FailureMessage == null) { invoice.InvoiceStatus = (byte)InvoiceStatus.Failed; nnv.FailureMessage = "Payment Declined, Please contact RDNation @ [email protected]."; } else if (nnv.FailureMessage.Contains("Your card number is incorrect")) invoice.InvoiceStatus = (byte)InvoiceStatus.Card_Was_Declined; else invoice.InvoiceStatus = (byte)InvoiceStatus.Failed; invoice.InvoiceStatusUpdated = DateTime.UtcNow; invoice.Merchant = invoice.Merchant; var customerService = new StripeCustomerService(); StripeSubscription subscription = customerService.CancelSubscription(inv.CustomerId, true); EmailLeagueAboutCardDeclinedSubscription(invoice.Subscription.InternalObject, invoice.InvoiceId, nnv.FailureMessage, ServerConfig.LEAGUE_SUBSCRIPTION_UPDATESUBSUBSCRIBE + invoice.Subscription.InternalObject.ToString().Replace("-", ""), ServerConfig.DEFAULT_ADMIN_EMAIL_ADMIN); } } dc.StripeEvents.Add(even); dc.SaveChanges(); return true; } catch (Exception exception) { ErrorDatabaseManager.AddException(exception, exception.GetType(), additionalInformation: json); } return false; }