Formatted utils/stripe_utils.py
This commit is contained in:
		
					parent
					
						
							
								a964f2fb5b
							
						
					
				
			
			
				commit
				
					
						b5e488e326
					
				
			
		
					 1 changed files with 52 additions and 29 deletions
				
			
		|  | @ -30,7 +30,8 @@ def handleStripeError(f): | ||||||
|             response.update({'error': err['message']}) |             response.update({'error': err['message']}) | ||||||
|             return response |             return response | ||||||
|         except stripe.error.RateLimitError as e: |         except stripe.error.RateLimitError as e: | ||||||
|             response.update({'error': "Too many requests made to the API too quickly"}) |             response.update( | ||||||
|  |                 {'error': "Too many requests made to the API too quickly"}) | ||||||
|             return response |             return response | ||||||
|         except stripe.error.InvalidRequestError as e: |         except stripe.error.InvalidRequestError as e: | ||||||
|             response.update({'error': "Invalid parameters"}) |             response.update({'error': "Invalid parameters"}) | ||||||
|  | @ -104,7 +105,8 @@ class StripeUtils(object): | ||||||
|                 customer = stripe.Customer.retrieve(id) |                 customer = stripe.Customer.retrieve(id) | ||||||
|             except stripe.InvalidRequestError: |             except stripe.InvalidRequestError: | ||||||
|                 customer = self.create_customer(token, user.email, user.name) |                 customer = self.create_customer(token, user.email, user.name) | ||||||
|                 user.stripecustomer.stripe_id = customer.get('response_object').get('id') |                 user.stripecustomer.stripe_id = customer.get( | ||||||
|  |                     'response_object').get('id') | ||||||
|                 user.stripecustomer.save() |                 user.stripecustomer.save() | ||||||
|         return customer |         return customer | ||||||
| 
 | 
 | ||||||
|  | @ -139,21 +141,26 @@ class StripeUtils(object): | ||||||
|     @handleStripeError |     @handleStripeError | ||||||
|     def get_or_create_stripe_plan(self, amount, name, stripe_plan_id): |     def get_or_create_stripe_plan(self, amount, name, stripe_plan_id): | ||||||
|         """ |         """ | ||||||
|         This function checks if a StripePlan with the given stripe_plan_id already exists. If it exists then the |         This function checks if a StripePlan with the given | ||||||
|         function returns this object otherwise it creates a new StripePlan and returns the new object. |         stripe_plan_id already exists. If it exists then the function | ||||||
|  |         returns this object otherwise it creates a new StripePlan and | ||||||
|  |         returns the new object. | ||||||
| 
 | 
 | ||||||
|         :param amount: The amount in CHF |         :param amount: The amount in CHF | ||||||
|         :param name: The name of the Stripe plan to be created. |         :param name: The name of the Stripe plan to be created. | ||||||
|         :param stripe_plan_id: The id of the Stripe plan to be created. Use get_stripe_plan_id_string function to obtain |         :param stripe_plan_id: The id of the Stripe plan to be | ||||||
|                                the name of the plan to be created |                created. Use get_stripe_plan_id_string function to | ||||||
|         :return: The StripePlan object if it exists else creates a Plan object in Stripe and a local StripePlan and |                obtain the name of the plan to be created | ||||||
|                 returns it. Returns None in case of Stripe error |         :return: The StripePlan object if it exists else creates a | ||||||
|  |                Plan object in Stripe and a local StripePlan and | ||||||
|  |                returns it. Returns None in case of Stripe error | ||||||
|         """ |         """ | ||||||
|         _amount = float(amount) |         _amount = float(amount) | ||||||
|         amount = int(_amount * 100)  # stripe amount unit, in cents |         amount = int(_amount * 100)  # stripe amount unit, in cents | ||||||
|         stripe_plan_db_obj = None |         stripe_plan_db_obj = None | ||||||
|         try: |         try: | ||||||
|             stripe_plan_db_obj = StripePlan.objects.get(stripe_plan_id=stripe_plan_id) |             stripe_plan_db_obj = StripePlan.objects.get( | ||||||
|  |                 stripe_plan_id=stripe_plan_id) | ||||||
|         except StripePlan.DoesNotExist: |         except StripePlan.DoesNotExist: | ||||||
|             try: |             try: | ||||||
|                 self.stripe.Plan.create( |                 self.stripe.Plan.create( | ||||||
|  | @ -162,30 +169,38 @@ class StripeUtils(object): | ||||||
|                     name=name, |                     name=name, | ||||||
|                     currency=self.CURRENCY, |                     currency=self.CURRENCY, | ||||||
|                     id=stripe_plan_id) |                     id=stripe_plan_id) | ||||||
|                 stripe_plan_db_obj = StripePlan.objects.create(stripe_plan_id=stripe_plan_id) |                 stripe_plan_db_obj = StripePlan.objects.create( | ||||||
|  |                     stripe_plan_id=stripe_plan_id) | ||||||
|             except stripe.error.InvalidRequestError as e: |             except stripe.error.InvalidRequestError as e: | ||||||
|                 if self.STRIPE_PLAN_ALREADY_EXISTS in str(e): |                 if self.STRIPE_PLAN_ALREADY_EXISTS in str(e): | ||||||
|                     logger.debug(self.PLAN_EXISTS_ERROR_MSG.format(stripe_plan_id)) |                     logger.debug( | ||||||
|                     stripe_plan_db_obj = StripePlan.objects.create(stripe_plan_id=stripe_plan_id) |                         self.PLAN_EXISTS_ERROR_MSG.format(stripe_plan_id)) | ||||||
|  |                     stripe_plan_db_obj = StripePlan.objects.create( | ||||||
|  |                         stripe_plan_id=stripe_plan_id) | ||||||
|         return stripe_plan_db_obj |         return stripe_plan_db_obj | ||||||
| 
 | 
 | ||||||
|     @handleStripeError |     @handleStripeError | ||||||
|     def delete_stripe_plan(self, stripe_plan_id): |     def delete_stripe_plan(self, stripe_plan_id): | ||||||
|         """ |         """ | ||||||
|         Deletes the Plan in Stripe and also deletes the local db copy of the plan if it exists |         Deletes the Plan in Stripe and also deletes the local db copy | ||||||
|  |         of the plan if it exists | ||||||
| 
 | 
 | ||||||
|         :param stripe_plan_id: The stripe plan id that needs to be deleted |         :param stripe_plan_id: The stripe plan id that needs to be | ||||||
|         :return: True if the plan was deleted successfully from Stripe, False otherwise. |                deleted | ||||||
|  |         :return: True if the plan was deleted successfully from | ||||||
|  |                Stripe, False otherwise. | ||||||
|         """ |         """ | ||||||
|         return_value = False |         return_value = False | ||||||
|         try: |         try: | ||||||
|             plan = self.stripe.Plan.retrieve(stripe_plan_id) |             plan = self.stripe.Plan.retrieve(stripe_plan_id) | ||||||
|             plan.delete() |             plan.delete() | ||||||
|             return_value = True |             return_value = True | ||||||
|             StripePlan.objects.filter(stripe_plan_id=stripe_plan_id).all().delete() |             StripePlan.objects.filter( | ||||||
|  |                 stripe_plan_id=stripe_plan_id).all().delete() | ||||||
|         except stripe.error.InvalidRequestError as e: |         except stripe.error.InvalidRequestError as e: | ||||||
|             if self.STRIPE_NO_SUCH_PLAN in str(e): |             if self.STRIPE_NO_SUCH_PLAN in str(e): | ||||||
|                 logger.debug(self.PLAN_DOES_NOT_EXIST_ERROR_MSG.format(stripe_plan_id)) |                 logger.debug( | ||||||
|  |                     self.PLAN_DOES_NOT_EXIST_ERROR_MSG.format(stripe_plan_id)) | ||||||
|         return return_value |         return return_value | ||||||
| 
 | 
 | ||||||
|     @handleStripeError |     @handleStripeError | ||||||
|  | @ -194,13 +209,14 @@ class StripeUtils(object): | ||||||
|         Subscribes the given customer to the list of given plans |         Subscribes the given customer to the list of given plans | ||||||
| 
 | 
 | ||||||
|         :param customer: The stripe customer identifier |         :param customer: The stripe customer identifier | ||||||
|         :param plans: A list of stripe plans. Ref: https://stripe.com/docs/api/python#create_subscription-items |         :param plans: A list of stripe plans. | ||||||
|                       e.g. |         Ref: https://stripe.com/docs/api/python#create_subscription-items | ||||||
|                             plans = [ |               e.g. | ||||||
|                                         { |                     plans = [ | ||||||
|                                           "plan": "dcl-v1-cpu-2-ram-5gb-ssd-10gb", |                                 { | ||||||
|                                         }, |                                   "plan": "dcl-v1-cpu-2-ram-5gb-ssd-10gb", | ||||||
|                                     ] |                                 }, | ||||||
|  |                             ] | ||||||
|         :return: The subscription StripeObject |         :return: The subscription StripeObject | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
|  | @ -222,18 +238,25 @@ class StripeUtils(object): | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def get_stripe_plan_id(cpu, ram, ssd, version, app='dcl', hdd=None): |     def get_stripe_plan_id(cpu, ram, ssd, version, app='dcl', hdd=None): | ||||||
|         """ |         """ | ||||||
|         Returns the stripe plan id string of the form `dcl-v1-cpu-2-ram-5gb-ssd-10gb` based on the input parameters |         Returns the stripe plan id string of the form | ||||||
|  |         `dcl-v1-cpu-2-ram-5gb-ssd-10gb` based on the input parameters | ||||||
| 
 | 
 | ||||||
|         :param cpu: The number of cores |         :param cpu: The number of cores | ||||||
|         :param ram: The size of the RAM in GB |         :param ram: The size of the RAM in GB | ||||||
|         :param ssd: The size of ssd storage in GB |         :param ssd: The size of ssd storage in GB | ||||||
|         :param hdd: The size of hdd storage in GB |         :param hdd: The size of hdd storage in GB | ||||||
|         :param version: The version of the Stripe plans |         :param version: The version of the Stripe plans | ||||||
|         :param app: The application to which the stripe plan belongs to. By default it is 'dcl' |         :param app: The application to which the stripe plan belongs | ||||||
|  |         to. By default it is 'dcl' | ||||||
|         :return: A string of the form `dcl-v1-cpu-2-ram-5gb-ssd-10gb` |         :return: A string of the form `dcl-v1-cpu-2-ram-5gb-ssd-10gb` | ||||||
|         """ |         """ | ||||||
|         dcl_plan_string = 'cpu-{cpu}-ram-{ram}gb-ssd-{ssd}gb'.format(cpu=cpu, ram=ram, ssd=ssd) |         dcl_plan_string = 'cpu-{cpu}-ram-{ram}gb-ssd-{ssd}gb'.format(cpu=cpu, | ||||||
|  |                                                                      ram=ram, | ||||||
|  |                                                                      ssd=ssd) | ||||||
|         if hdd is not None: |         if hdd is not None: | ||||||
|             dcl_plan_string = '{dcl_plan_string}-hdd-{hdd}gb'.format(dcl_plan_string=dcl_plan_string, hdd=hdd) |             dcl_plan_string = '{dcl_plan_string}-hdd-{hdd}gb'.format( | ||||||
|         stripe_plan_id_string = '{app}-v{version}-{plan}'.format(app=app, version=version, plan=dcl_plan_string) |                 dcl_plan_string=dcl_plan_string, hdd=hdd) | ||||||
|  |         stripe_plan_id_string = '{app}-v{version}-{plan}'.format(app=app, | ||||||
|  |                                                                  version=version, | ||||||
|  |                                                                  plan=dcl_plan_string) | ||||||
|         return stripe_plan_id_string |         return stripe_plan_id_string | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue