| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | import datetime | 
					
						
							|  |  |  | import logging | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  | import json | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | import stripe | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | # Create your views here. | 
					
						
							|  |  |  | from django.conf import settings | 
					
						
							|  |  |  | from django.http import HttpResponse | 
					
						
							|  |  |  | from django.views.decorators.csrf import csrf_exempt | 
					
						
							|  |  |  | from django.views.decorators.http import require_POST | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  | from datacenterlight.views import do_provisioning, do_provisioning_generic | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  | from membership.models import StripeCustomer | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  | from hosting.models import IncompleteSubscriptions, IncompletePaymentIntents | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | from utils.models import BillingAddress, UserBillingAddress | 
					
						
							|  |  |  | from utils.tasks import send_plain_email_task | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | logger = logging.getLogger(__name__) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-25 12:36:47 +05:30
										 |  |  | # Things to do for webhooks feature | 
					
						
							|  |  |  | # 1. Uninstall old version and install a more recent version of stripe | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | #    source venv/bin/activate | 
					
						
							|  |  |  | #    ./manage.py shell | 
					
						
							|  |  |  | #    pip uninstall stripe | 
					
						
							|  |  |  | #    pip install stripe==2.24.1 | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | # 2. Create tax id updated webhook | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | #    ./manage.py webhook --create \ | 
					
						
							|  |  |  | #    --webhook_endpoint https://datacenterlight.ch/en-us/webhooks/ \ | 
					
						
							|  |  |  | #    --events_csv customer.tax_id.updated | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # 3. From the secret obtained in 2, setup an environment variable | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | #    WEBHOOK_SECRET='whsec......' | 
					
						
							|  |  |  | #    ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | @require_POST | 
					
						
							|  |  |  | @csrf_exempt | 
					
						
							|  |  |  | def handle_webhook(request): | 
					
						
							|  |  |  |     payload = request.body | 
					
						
							|  |  |  |     event = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         if 'HTTP_STRIPE_SIGNATURE' in request.META: | 
					
						
							|  |  |  |             sig_header = request.META['HTTP_STRIPE_SIGNATURE'] | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             logger.error("No HTTP_STRIPE_SIGNATURE header") | 
					
						
							|  |  |  |             # Invalid payload | 
					
						
							|  |  |  |             return HttpResponse(status=400) | 
					
						
							|  |  |  |         event = stripe.Webhook.construct_event( | 
					
						
							|  |  |  |             payload, sig_header, settings.WEBHOOK_SECRET | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     except ValueError as e: | 
					
						
							|  |  |  |         # Invalid payload | 
					
						
							|  |  |  |         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: | 
					
						
							|  |  |  |         # Invalid signature | 
					
						
							|  |  |  |         err_msg = "FAILURE handle_invoice_webhook: SignatureVerificationError" | 
					
						
							|  |  |  |         err_body = "Details %s" % str(e) | 
					
						
							|  |  |  |         return handle_error(err_msg, err_body) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Do something with event | 
					
						
							|  |  |  |     logger.debug("Passed signature verification") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if event.type == "customer.tax_id.updated": | 
					
						
							|  |  |  |         logger.debug("Webhook Event: customer.tax_id.updated") | 
					
						
							|  |  |  |         tax_id_obj = event.data.object | 
					
						
							| 
									
										
										
										
											2019-12-26 08:06:27 +05:30
										 |  |  |         logger.debug("Tax_id %s is %s" % (tax_id_obj.id, | 
					
						
							|  |  |  |                      tax_id_obj.verification.status)) | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  |         stripe_customer = None | 
					
						
							|  |  |  |         try: | 
					
						
							| 
									
										
										
										
											2020-01-01 00:52:07 +05:30
										 |  |  |             stripe_customer = StripeCustomer.objects.get(stripe_id=tax_id_obj.customer) | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  |         except StripeCustomer.DoesNotExist as dne: | 
					
						
							|  |  |  |             logger.debug( | 
					
						
							|  |  |  |                 "StripeCustomer %s does not exist" % tax_id_obj.customer) | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |         if tax_id_obj.verification.status == "verified": | 
					
						
							| 
									
										
										
										
											2019-12-26 11:54:54 +05:30
										 |  |  |             b_addresses = BillingAddress.objects.filter(stripe_tax_id=tax_id_obj.id) | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |             for b_address in b_addresses: | 
					
						
							| 
									
										
										
										
											2019-12-26 19:35:50 +05:30
										 |  |  |                 b_address.vat_validation_status = tax_id_obj.verification.status | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |                 b_address.vat_number_validated_on = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2019-12-26 11:54:54 +05:30
										 |  |  |                 b_address.save() | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 11:54:54 +05:30
										 |  |  |             ub_addresses = UserBillingAddress.objects.filter(stripe_tax_id=tax_id_obj.id) | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |             for ub_address in ub_addresses: | 
					
						
							| 
									
										
										
										
											2019-12-26 19:35:50 +05:30
										 |  |  |                 ub_address.vat_validation_status = tax_id_obj.verification.status | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |                 ub_address.vat_number_validated_on = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2019-12-26 11:54:54 +05:30
										 |  |  |                 ub_address.save() | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  |             email_data = { | 
					
						
							|  |  |  |                 'subject': "The VAT %s associated with %s was verified" % | 
					
						
							|  |  |  |                            (tax_id_obj.value,  stripe_customer.user.email if stripe_customer else "unknown"), | 
					
						
							|  |  |  |                 'from_email': settings.DCL_SUPPORT_FROM_ADDRESS, | 
					
						
							|  |  |  |                 'to': settings.DCL_ERROR_EMAILS_TO_LIST, | 
					
						
							| 
									
										
										
										
											2020-01-01 02:04:55 +05:30
										 |  |  |                 'body': "The following objects were modified:\n".join( | 
					
						
							|  |  |  |                     '\n'.join([str(b_address) for b_address in b_addresses]) | 
					
						
							|  |  |  |                 ).join( | 
					
						
							|  |  |  |                     '\n'.join([str(ub_address) for ub_address in ub_addresses]) | 
					
						
							|  |  |  |                 ), | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |         else: | 
					
						
							| 
									
										
										
										
											2019-12-26 08:06:27 +05:30
										 |  |  |             logger.debug("Tax_id %s is %s" % (tax_id_obj.id, | 
					
						
							|  |  |  |                          tax_id_obj.verification.status)) | 
					
						
							| 
									
										
										
										
											2020-01-01 00:01:44 +05:30
										 |  |  |             email_data = { | 
					
						
							|  |  |  |                 'subject': "The VAT %s associated with %s was %s" % | 
					
						
							|  |  |  |                            (tax_id_obj.value,  stripe_customer.user.email if stripe_customer else "unknown", tax_id_obj.verification.status), | 
					
						
							|  |  |  |                 'from_email': settings.DCL_SUPPORT_FROM_ADDRESS, | 
					
						
							|  |  |  |                 'to': settings.DCL_ERROR_EMAILS_TO_LIST, | 
					
						
							|  |  |  |                 'body': "Response = %s" % str(tax_id_obj), | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         send_plain_email_task.delay(email_data) | 
					
						
							| 
									
										
										
										
											2020-12-18 17:34:40 +05:30
										 |  |  |     elif event.type == 'invoice.paid': | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  |         #More info:  https://stripe.com/docs/billing/migration/strong-customer-authentication#scenario-1-handling-fulfillment | 
					
						
							| 
									
										
										
										
											2020-12-18 17:34:40 +05:30
										 |  |  |         invoice_obj = event.data.object | 
					
						
							|  |  |  |         logger.debug("Webhook Event: invoice.paid") | 
					
						
							|  |  |  |         logger.debug("invoice_obj %s " % str(invoice_obj)) | 
					
						
							| 
									
										
										
										
											2020-12-20 02:41:30 +05:30
										 |  |  |         logger.debug("invoice_obj.paid = %s %s" % (invoice_obj.paid, type(invoice_obj.paid))) | 
					
						
							|  |  |  |         logger.debug("invoice_obj.billing_reason = %s %s" % (invoice_obj.billing_reason, type(invoice_obj.billing_reason))) | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  |         # We should check for billing_reason == "subscription_create" but we | 
					
						
							|  |  |  |         # check for "subscription_update" | 
					
						
							|  |  |  |         # because we are using older api. | 
					
						
							|  |  |  |         # See https://stripe.com/docs/upgrades?since=2015-07-13 | 
					
						
							| 
									
										
										
										
											2020-12-20 02:41:30 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |         # The billing_reason attribute of the invoice object now can take the | 
					
						
							|  |  |  |         # value of subscription_create, indicating that it is the first | 
					
						
							|  |  |  |         # invoice of a subscription. For older API versions, | 
					
						
							|  |  |  |         # billing_reason=subscription_create is represented as | 
					
						
							|  |  |  |         # subscription_update. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  |         if (invoice_obj.paid and | 
					
						
							|  |  |  |                 invoice_obj.billing_reason == "subscription_update"): | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             logger.debug("""invoice_obj.paid and
 | 
					
						
							|  |  |  |                 invoice_obj.billing_reason == subscription_update""")
 | 
					
						
							| 
									
										
										
										
											2020-12-18 17:34:40 +05:30
										 |  |  |             logger.debug("Start provisioning") | 
					
						
							| 
									
										
										
										
											2020-12-20 02:41:30 +05:30
										 |  |  |             try: | 
					
						
							| 
									
										
										
										
											2020-12-23 14:12:30 +05:30
										 |  |  |                 stripe_subscription_obj = stripe.Subscription.retrieve( | 
					
						
							|  |  |  |                     invoice_obj.subscription) | 
					
						
							|  |  |  |                 try: | 
					
						
							|  |  |  |                     incomplete_sub = IncompleteSubscriptions.objects.get( | 
					
						
							|  |  |  |                         subscription_id=invoice_obj.subscription) | 
					
						
							|  |  |  |                     request = "" | 
					
						
							|  |  |  |                     soc = "" | 
					
						
							|  |  |  |                     card_details_response = "" | 
					
						
							|  |  |  |                     gp_details = "" | 
					
						
							|  |  |  |                     template = "" | 
					
						
							|  |  |  |                     specs = "" | 
					
						
							|  |  |  |                     billing_address_data = "" | 
					
						
							|  |  |  |                     if incomplete_sub.request: | 
					
						
							|  |  |  |                         request = json.loads(incomplete_sub.request) | 
					
						
							|  |  |  |                     if incomplete_sub.specs: | 
					
						
							|  |  |  |                         specs = json.loads(incomplete_sub.specs) | 
					
						
							|  |  |  |                     if incomplete_sub.stripe_onetime_charge: | 
					
						
							|  |  |  |                         soc = json.loads(incomplete_sub.stripe_onetime_charge) | 
					
						
							|  |  |  |                     if incomplete_sub.gp_details: | 
					
						
							|  |  |  |                         gp_details = json.loads(incomplete_sub.gp_details) | 
					
						
							|  |  |  |                     if incomplete_sub.card_details_response: | 
					
						
							|  |  |  |                         card_details_response = json.loads( | 
					
						
							|  |  |  |                             incomplete_sub.card_details_response) | 
					
						
							|  |  |  |                     if incomplete_sub.template: | 
					
						
							|  |  |  |                         template = json.loads( | 
					
						
							|  |  |  |                             incomplete_sub.template) | 
					
						
							|  |  |  |                     if incomplete_sub.billing_address_data: | 
					
						
							|  |  |  |                         billing_address_data = json.loads( | 
					
						
							|  |  |  |                             incomplete_sub.billing_address_data) | 
					
						
							|  |  |  |                     logger.debug("*******") | 
					
						
							|  |  |  |                     logger.debug(str(incomplete_sub)) | 
					
						
							|  |  |  |                     logger.debug("*******") | 
					
						
							|  |  |  |                     logger.debug("1*******") | 
					
						
							|  |  |  |                     logger.debug(request) | 
					
						
							|  |  |  |                     logger.debug("2*******") | 
					
						
							|  |  |  |                     logger.debug(card_details_response) | 
					
						
							|  |  |  |                     logger.debug("3*******") | 
					
						
							|  |  |  |                     logger.debug(soc) | 
					
						
							|  |  |  |                     logger.debug("4*******") | 
					
						
							|  |  |  |                     logger.debug(gp_details) | 
					
						
							|  |  |  |                     logger.debug("5*******") | 
					
						
							|  |  |  |                     logger.debug(template) | 
					
						
							|  |  |  |                     logger.debug("6*******") | 
					
						
							| 
									
										
										
										
											2020-12-23 17:09:27 +05:30
										 |  |  |                     do_provisioning( | 
					
						
							| 
									
										
										
										
											2020-12-23 14:12:30 +05:30
										 |  |  |                         request=request, | 
					
						
							|  |  |  |                         stripe_api_cus_id=incomplete_sub.stripe_api_cus_id, | 
					
						
							|  |  |  |                         card_details_response=card_details_response, | 
					
						
							|  |  |  |                         stripe_subscription_obj=stripe_subscription_obj, | 
					
						
							|  |  |  |                         stripe_onetime_charge=soc, | 
					
						
							|  |  |  |                         gp_details=gp_details, | 
					
						
							|  |  |  |                         specs=specs, | 
					
						
							|  |  |  |                         vm_template_id=incomplete_sub.vm_template_id, | 
					
						
							|  |  |  |                         template=template, | 
					
						
							| 
									
										
										
										
											2020-12-23 17:09:27 +05:30
										 |  |  |                         billing_address_data=billing_address_data, | 
					
						
							|  |  |  |                         real_request=None | 
					
						
							| 
									
										
										
										
											2020-12-23 14:12:30 +05:30
										 |  |  |                     ) | 
					
						
							|  |  |  |                 except (IncompleteSubscriptions.DoesNotExist, | 
					
						
							|  |  |  |                         IncompleteSubscriptions.MultipleObjectsReturned) as ex: | 
					
						
							|  |  |  |                     logger.error(str(ex)) | 
					
						
							|  |  |  |                     email_data = { | 
					
						
							|  |  |  |                         'subject': "IncompleteSubscriptions error", | 
					
						
							|  |  |  |                         'from_email': settings.DCL_SUPPORT_FROM_ADDRESS, | 
					
						
							|  |  |  |                         'to': settings.DCL_ERROR_EMAILS_TO_LIST, | 
					
						
							|  |  |  |                         'body': "Response = %s" % str(ex), | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     send_plain_email_task.delay(email_data) | 
					
						
							|  |  |  |             except Exception as ex: | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  |                 logger.error(str(ex)) | 
					
						
							|  |  |  |                 email_data = { | 
					
						
							| 
									
										
										
										
											2020-12-23 14:12:30 +05:30
										 |  |  |                     'subject': "invoice.paid Webhook error", | 
					
						
							| 
									
										
										
										
											2020-12-23 10:59:21 +05:30
										 |  |  |                     'from_email': settings.DCL_SUPPORT_FROM_ADDRESS, | 
					
						
							|  |  |  |                     'to': settings.DCL_ERROR_EMAILS_TO_LIST, | 
					
						
							|  |  |  |                     'body': "Response = %s" % str(ex), | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 send_plain_email_task.delay(email_data) | 
					
						
							| 
									
										
										
										
											2020-12-23 17:10:23 +05:30
										 |  |  |     elif event.type == 'invoice.payment_failed': | 
					
						
							|  |  |  |         invoice_obj = event.data.object | 
					
						
							|  |  |  |         logger.debug("Webhook Event: invoice.payment_failed") | 
					
						
							|  |  |  |         logger.debug("invoice_obj %s " % str(invoice_obj)) | 
					
						
							|  |  |  |         if (invoice_obj.payment_failed and | 
					
						
							|  |  |  |                 invoice_obj.billing_reason == "subscription_update"): | 
					
						
							|  |  |  |             logger.debug("Payment failed, inform the users") | 
					
						
							| 
									
										
										
										
											2020-12-24 19:34:06 +05:30
										 |  |  |     elif event.type == 'payment_intent.succeeded': | 
					
						
							|  |  |  |         payment_intent_obj = event.data.object | 
					
						
							|  |  |  |         logger.debug("Webhook Event: payment_intent.succeeded") | 
					
						
							|  |  |  |         logger.debug("payment_intent_obj %s " % str(payment_intent_obj)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |         try: | 
					
						
							| 
									
										
										
										
											2020-12-31 16:47:45 +05:30
										 |  |  |             logger.debug("Looking for IncompletePaymentIntents %s " % | 
					
						
							|  |  |  |                          payment_intent_obj.id) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             incomplete_pm = IncompletePaymentIntents.objects.get( | 
					
						
							| 
									
										
										
										
											2020-12-31 16:23:44 +05:30
										 |  |  |                 payment_intent_id=payment_intent_obj.id) | 
					
						
							| 
									
										
										
										
											2020-12-31 17:05:01 +05:30
										 |  |  |             logger.debug("incomplete_pm = %s" % str(incomplete_pm.__dict__)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             request = "" | 
					
						
							|  |  |  |             soc = "" | 
					
						
							|  |  |  |             card_details_response = "" | 
					
						
							|  |  |  |             gp_details = "" | 
					
						
							|  |  |  |             template = "" | 
					
						
							|  |  |  |             billing_address_data = "" | 
					
						
							|  |  |  |             if incomplete_pm.request: | 
					
						
							|  |  |  |                 request = json.loads(incomplete_pm.request) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:55:05 +05:30
										 |  |  |             logger.debug("request = %s" % str(request)) | 
					
						
							| 
									
										
										
										
											2020-12-31 17:07:51 +05:30
										 |  |  |             if incomplete_pm.stripe_charge_id: | 
					
						
							|  |  |  |                 soc = incomplete_pm.stripe_charge_id | 
					
						
							| 
									
										
										
										
											2020-12-31 16:55:05 +05:30
										 |  |  |             logger.debug("stripe_onetime_charge = %s" % str(soc)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             if incomplete_pm.gp_details: | 
					
						
							|  |  |  |                 gp_details = json.loads(incomplete_pm.gp_details) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:55:05 +05:30
										 |  |  |             logger.debug("gp_details = %s" % str(gp_details)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             if incomplete_pm.card_details_response: | 
					
						
							|  |  |  |                 card_details_response = json.loads( | 
					
						
							|  |  |  |                     incomplete_pm.card_details_response) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:55:05 +05:30
										 |  |  |             logger.debug("card_details_response = %s" % str(card_details_response)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             if incomplete_pm.billing_address_data: | 
					
						
							|  |  |  |                 billing_address_data = json.loads( | 
					
						
							|  |  |  |                     incomplete_pm.billing_address_data) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:55:05 +05:30
										 |  |  |             logger.debug("billing_address_data = %s" % str(billing_address_data)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             logger.debug("1*******") | 
					
						
							|  |  |  |             logger.debug(request) | 
					
						
							|  |  |  |             logger.debug("2*******") | 
					
						
							|  |  |  |             logger.debug(card_details_response) | 
					
						
							|  |  |  |             logger.debug("3*******") | 
					
						
							|  |  |  |             logger.debug(soc) | 
					
						
							|  |  |  |             logger.debug("4*******") | 
					
						
							|  |  |  |             logger.debug(gp_details) | 
					
						
							|  |  |  |             logger.debug("5*******") | 
					
						
							|  |  |  |             logger.debug(template) | 
					
						
							|  |  |  |             logger.debug("6*******") | 
					
						
							|  |  |  |             logger.debug(billing_address_data) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:29:18 +05:30
										 |  |  |             incomplete_pm.completed_at = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2020-12-31 16:37:25 +05:30
										 |  |  |             charges = "" | 
					
						
							|  |  |  |             if len(payment_intent_obj.charges.data) > 0: | 
					
						
							|  |  |  |                 for d in payment_intent_obj.charges.data: | 
					
						
							|  |  |  |                     if charges == "": | 
					
						
							|  |  |  |                         charges = "%s" % d.id | 
					
						
							|  |  |  |                     else: | 
					
						
							|  |  |  |                         charges = "%s,%s" % (charges, d.id) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:39:25 +05:30
										 |  |  |             logger.debug("Charge ids = %s" % charges) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:37:25 +05:30
										 |  |  |             incomplete_pm.stripe_charge_id=charges | 
					
						
							| 
									
										
										
										
											2020-12-31 16:39:25 +05:30
										 |  |  |             do_provisioning_generic( | 
					
						
							|  |  |  |                 request=request, | 
					
						
							|  |  |  |                 stripe_api_cus_id=incomplete_pm.stripe_api_cus_id, | 
					
						
							|  |  |  |                 card_details_response=card_details_response, | 
					
						
							|  |  |  |                 stripe_subscription_id=None, | 
					
						
							|  |  |  |                 stripe_charge_id=charges, | 
					
						
							|  |  |  |                 gp_details=gp_details, | 
					
						
							|  |  |  |                 billing_address_data=billing_address_data | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:37:25 +05:30
										 |  |  |             incomplete_pm.save() | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |         except (IncompletePaymentIntents.DoesNotExist, | 
					
						
							| 
									
										
										
										
											2020-12-31 17:02:03 +05:30
										 |  |  |                 IncompletePaymentIntents.MultipleObjectsReturned, | 
					
						
							|  |  |  |                 Exception) as ex: | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             logger.error(str(ex)) | 
					
						
							| 
									
										
										
										
											2020-12-31 16:47:45 +05:30
										 |  |  |             logger.debug(str(ex)) | 
					
						
							| 
									
										
										
										
											2020-12-31 15:41:43 +05:30
										 |  |  |             email_data = { | 
					
						
							|  |  |  |                 'subject': "IncompletePaymentIntents error", | 
					
						
							|  |  |  |                 'from_email': settings.DCL_SUPPORT_FROM_ADDRESS, | 
					
						
							|  |  |  |                 'to': settings.DCL_ERROR_EMAILS_TO_LIST, | 
					
						
							|  |  |  |                 'body': "Response = %s" % str(ex), | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             send_plain_email_task.delay(email_data) | 
					
						
							| 
									
										
										
										
											2019-12-25 12:07:42 +05:30
										 |  |  |     else: | 
					
						
							|  |  |  |         logger.error("Unhandled event : " + event.type) | 
					
						
							|  |  |  |     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.ADMIN_EMAIL], | 
					
						
							|  |  |  |         'body': error_body, | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     send_plain_email_task.delay(email_to_admin_data) | 
					
						
							|  |  |  |     return HttpResponse(status=400) |