| 
									
										
										
										
											2016-07-27 00:08:45 -05:00
										 |  |  | from django.core.management.base import BaseCommand | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from datetime import datetime | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from utils.stripe_utils import StripeUtils | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-04 01:07:41 -05:00
										 |  |  | from utils.mailer import BaseEmail | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  | from nosystemd.models import DonatorStatus, Donation | 
					
						
							|  |  |  | from nosystemd.forms import DonationForm | 
					
						
							| 
									
										
										
										
											2016-07-27 00:08:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-04 01:07:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 00:08:45 -05:00
										 |  |  | class Command(BaseCommand): | 
					
						
							|  |  |  |     help = 'Make the monthly stripe charge to all donators' | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  |     CURRENCY = 'usd' | 
					
						
							| 
									
										
										
										
											2016-07-27 00:08:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def handle(self, *args, **options): | 
					
						
							|  |  |  |         donators = DonatorStatus.objects.filter(status=DonatorStatus.ACTIVE) | 
					
						
							|  |  |  |         current_month = datetime.now().month | 
					
						
							|  |  |  |         current_year = datetime.now().year | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         print("--------- STARTING DONATIONS SCRIPT  ---------") | 
					
						
							|  |  |  |         print("Donations date: %s-%s" % (current_month, current_year)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for donator_status in donators: | 
					
						
							|  |  |  |             donator = donator_status.user.stripecustomer | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 Donation.objects.get(created_at__month=current_month, | 
					
						
							|  |  |  |                                      created_at__year=current_year, | 
					
						
							|  |  |  |                                      donator=donator) | 
					
						
							|  |  |  |             except Donation.DoesNotExist: | 
					
						
							|  |  |  |                 try: | 
					
						
							|  |  |  |                     # Get donator last donation amount | 
					
						
							|  |  |  |                     last_donation = Donation.objects.filter(donator=donator).last() | 
					
						
							|  |  |  |                     donation_amount = last_donation.donation | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     # Make stripe charge to a customer | 
					
						
							|  |  |  |                     stripe_utils = StripeUtils() | 
					
						
							|  |  |  |                     stripe_utils.CURRENCY = self.CURRENCY | 
					
						
							|  |  |  |                     charge_response = stripe_utils.make_charge(amount=donation_amount, | 
					
						
							|  |  |  |                                                                customer=donator.stripe_id) | 
					
						
							|  |  |  |                     charge = charge_response.get('response_object') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     # Check if the payment was approved | 
					
						
							|  |  |  |                     if not charge: | 
					
						
							|  |  |  |                         # There is an error trying to creating the stripe charge | 
					
						
							|  |  |  |                         context = { | 
					
						
							|  |  |  |                             'paymentError': charge_response.get('error'), | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         print("--------- STRIPE PAYMENT ERROR ---------") | 
					
						
							|  |  |  |                         print(context) | 
					
						
							|  |  |  |                         print("-------------------------") | 
					
						
							| 
									
										
										
										
											2016-08-04 01:07:41 -05:00
										 |  |  |                         continue | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  |                     # Create a donation | 
					
						
							|  |  |  |                     charge = charge_response.get('response_object') | 
					
						
							|  |  |  |                     donation_data = { | 
					
						
							|  |  |  |                         'cc_brand': charge.source.brand, | 
					
						
							|  |  |  |                         'stripe_charge_id': charge.id, | 
					
						
							|  |  |  |                         'last4': charge.source.last4, | 
					
						
							|  |  |  |                         'billing_address': last_donation.billing_address.id, | 
					
						
							|  |  |  |                         'donator': donator.id, | 
					
						
							|  |  |  |                         'donation': donation_amount | 
					
						
							| 
									
										
										
										
											2016-07-27 00:08:45 -05:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  |                     donation_form = DonationForm(donation_data) | 
					
						
							|  |  |  |                     if donation_form.is_valid(): | 
					
						
							|  |  |  |                         donation = donation_form.save() | 
					
						
							| 
									
										
										
										
											2016-08-04 01:07:41 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                         context = { | 
					
						
							|  |  |  |                             'donation': donation, | 
					
						
							|  |  |  |                             'base_url': "{0}://{1}".format('https', 'dynamicweb.ungleich.ch') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         email_data = { | 
					
						
							|  |  |  |                             'subject': 'Your donation have been charged', | 
					
						
							|  |  |  |                             'to': donation.donator.user.email, | 
					
						
							|  |  |  |                             'context': context, | 
					
						
							|  |  |  |                             'template_name': 'donation_charge', | 
					
						
							|  |  |  |                             'template_path': 'nosystemd/emails/' | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         email = BaseEmail(**email_data) | 
					
						
							|  |  |  |                         email.send() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 00:17:34 -05:00
										 |  |  |                         print("--------- PAYMENT DONATION SUCCESSFULL ---------") | 
					
						
							|  |  |  |                         print("Donator: %s" % donation.donator.user.email) | 
					
						
							|  |  |  |                         print("Amount: %s %s" % (donation.donation, self.CURRENCY)) | 
					
						
							|  |  |  |                         print("-----------------------------------------------") | 
					
						
							|  |  |  |                 except Exception as e: | 
					
						
							|  |  |  |                     print("--------- ERROR ---------") | 
					
						
							|  |  |  |                     print(e) | 
					
						
							|  |  |  |                     print("-------------------------") | 
					
						
							|  |  |  |                     continue |