2018-05-23 16:40:41 +00:00
# -*- coding: utf-8 -*-
# Copyright (c) 2018, Frappe Technologies Pvt. Ltd. and contributors
# For license information, please see license.txt
from __future__ import unicode_literals
2018-06-05 19:49:57 +00:00
import frappe
from frappe import _
from frappe . integrations . utils import create_request_log
import stripe
2018-05-23 16:40:41 +00:00
2018-06-05 19:49:57 +00:00
def create_stripe_subscription ( gateway_controller , data ) :
stripe_settings = frappe . get_doc ( " Stripe Settings " , gateway_controller )
stripe_settings . data = frappe . _dict ( data )
stripe . api_key = stripe_settings . get_password ( fieldname = " secret_key " , raise_exception = False )
stripe . default_http_client = stripe . http_client . RequestsClient ( )
try :
2018-06-27 08:27:21 +00:00
stripe_settings . integration_request = create_request_log ( stripe_settings . data , " Host " , " Stripe " )
stripe_settings . payment_plans = frappe . get_doc ( " Payment Request " , stripe_settings . data . reference_docname ) . subscription_plans
return create_subscription_on_stripe ( stripe_settings )
2018-06-05 19:49:57 +00:00
except Exception :
frappe . log_error ( frappe . get_traceback ( ) )
return {
" redirect_to " : frappe . redirect_to_message ( _ ( ' Server Error ' ) , _ ( " It seems that there is an issue with the server ' s stripe configuration. In case of failure, the amount will get refunded to your account. " ) ) ,
" status " : 401
}
def create_subscription_on_stripe ( stripe_settings ) :
2018-06-20 17:38:13 +00:00
items = [ ]
for payment_plan in stripe_settings . payment_plans :
plan = frappe . db . get_value ( " Subscription Plan " , payment_plan . plan , " payment_plan_id " )
items . append ( { " plan " : plan , " quantity " : payment_plan . qty } )
2018-06-05 19:49:57 +00:00
try :
customer = stripe . Customer . create ( description = stripe_settings . data . payer_name , email = stripe_settings . data . payer_email , source = stripe_settings . data . stripe_token_id )
subscription = stripe . Subscription . create ( customer = customer , items = items )
if subscription . status == " active " :
stripe_settings . integration_request . db_set ( ' status ' , ' Completed ' , update_modified = False )
stripe_settings . flags . status_changed_to = " Completed "
else :
stripe_settings . integration_request . db_set ( ' status ' , ' Failed ' , update_modified = False )
frappe . log_error ( ' Subscription N°: ' + subscription . id , ' Stripe Payment not completed ' )
except Exception :
stripe_settings . integration_request . db_set ( ' status ' , ' Failed ' , update_modified = False )
frappe . log_error ( frappe . get_traceback ( ) )
2021-08-19 13:41:10 +05:30
return stripe_settings . finalize_request ( )