Handle error better
This commit is contained in:
parent
e7196af1f9
commit
c081f9e73a
1 changed files with 27 additions and 6 deletions
|
@ -30,20 +30,29 @@ def handle_invoice_webhook(request):
|
||||||
payload, sig_header, settings.INVOICE_WEBHOOK_SECRET
|
payload, sig_header, settings.INVOICE_WEBHOOK_SECRET
|
||||||
)
|
)
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
logger.error("Invalid payload details = " + str(e))
|
|
||||||
# Invalid payload
|
# Invalid payload
|
||||||
return HttpResponse(status=400)
|
err_msg = "FAILURE handle_invoice_webhook: Invalid payload details"
|
||||||
|
err_body = "Details %s" % str(e)
|
||||||
|
return handle_error(err_msg, err_body)
|
||||||
except stripe.error.SignatureVerificationError as e:
|
except stripe.error.SignatureVerificationError as e:
|
||||||
logger.error("SignatureVerificationError details = " + str(e))
|
|
||||||
# Invalid signature
|
# Invalid signature
|
||||||
return HttpResponse(status=400)
|
err_msg = "FAILURE handle_invoice_webhook: SignatureVerificationError"
|
||||||
|
err_body = "Details %s" % str(e)
|
||||||
|
return handle_error(err_msg, err_body)
|
||||||
|
|
||||||
# Do something with event
|
# Do something with event
|
||||||
logger.debug("Passed invoice signature verification")
|
logger.debug("Passed invoice signature verification")
|
||||||
|
|
||||||
# Get the user from the invoice
|
# Get the user from the invoice
|
||||||
invoice = event.data.object
|
invoice = event.data.object
|
||||||
|
logger.debug("Checking whether StripeCustomer %s exists" % invoice.customer)
|
||||||
|
try:
|
||||||
stripe_customer = StripeCustomer.objects.get(stripe_id=invoice.customer)
|
stripe_customer = StripeCustomer.objects.get(stripe_id=invoice.customer)
|
||||||
|
except StripeCustomer.DoesNotExist as dne:
|
||||||
|
# StripeCustomer does not exist
|
||||||
|
err_msg = "FAILURE handle_invoice_webhook: StripeCustomer %s doesn't exist" % invoice.customer
|
||||||
|
err_body = "Details %s" % str(dne)
|
||||||
|
return handle_error(err_msg, err_body)
|
||||||
|
|
||||||
if event.type == "invoice.payment_succeeded":
|
if event.type == "invoice.payment_succeeded":
|
||||||
logger.debug("Invoice payment succeeded")
|
logger.debug("Invoice payment succeeded")
|
||||||
|
@ -112,3 +121,15 @@ def handle_invoice_webhook(request):
|
||||||
logger.error("Unhandled event : " + event.type)
|
logger.error("Unhandled event : " + event.type)
|
||||||
|
|
||||||
return HttpResponse(status=200)
|
return HttpResponse(status=200)
|
||||||
|
|
||||||
|
|
||||||
|
def handle_error(error_msg, error_body):
|
||||||
|
logger.error("%s -- %s" % (error_msg, error_body))
|
||||||
|
email_to_admin_data = {
|
||||||
|
'subject': error_msg,
|
||||||
|
'from_email': settings.DCL_SUPPORT_FROM_ADDRESS,
|
||||||
|
'to': settings.WEBHOOK_EMAIL_TO.split(","),
|
||||||
|
'body': error_body,
|
||||||
|
}
|
||||||
|
send_plain_email_task.delay(email_to_admin_data)
|
||||||
|
return HttpResponse(status=400)
|
Loading…
Reference in a new issue