From 87dc4f9d11af4610f534d57d5e51fabca9bb328a Mon Sep 17 00:00:00 2001 From: jessib Date: Mon, 10 Jun 2013 10:25:37 -0700 Subject: Back to singular-customer controller, in hopes that would help some confusions. --- billing/app/controllers/customer_controller.rb | 57 ++++++++++++++++++++++++ billing/app/controllers/customers_controller.rb | 58 ------------------------- 2 files changed, 57 insertions(+), 58 deletions(-) create mode 100644 billing/app/controllers/customer_controller.rb delete mode 100644 billing/app/controllers/customers_controller.rb (limited to 'billing/app/controllers') diff --git a/billing/app/controllers/customer_controller.rb b/billing/app/controllers/customer_controller.rb new file mode 100644 index 0000000..505aa6e --- /dev/null +++ b/billing/app/controllers/customer_controller.rb @@ -0,0 +1,57 @@ +class CustomerController < BillingBaseController + before_filter :authorize + before_filter :fetch_customer_data, :only => [:show, :edit] #confirm??? + + def show + @active_subscription = @customer.subscriptions(@braintree_data) + end + + def new + if customer = Customer.find_by_user_id(current_user.id) + redirect_to edit_customer_path(customer.braintree_customer_id), :notice => 'Here is your saved customer data' + else + @tr_data = Braintree::TransparentRedirect. + # create_customer_data(:redirect_url => confirm_customer_url(-1)) # trial + create_customer_data(:redirect_url => confirm_customer_url) + end + end + + def edit + @tr_data = Braintree::TransparentRedirect. + update_customer_data(:redirect_url => confirm_customer_url, + :customer_id => params[:id]) + end + + def confirm + @result = Braintree::TransparentRedirect.confirm(request.query_string) + if @result.success? + # customer = Customer.new(:user_id => current_user.id, :braintree_customer_id => @result.customer.id) + customer = Customer.new(:braintree_customer_id => @result.customer.id) + customer.user = current_user + customer.save + #current_user.save! + #debugger + render :action => "confirm" + #elsif current_user.has_payment_info? + elsif (customer = Customer.find_by_user_id(current_user.id)) and customer.has_payment_info? + #customer.with_braintree_data! + render :action => "edit" + else + render :action => "new" + end + end + + private + + def fetch_customer_data + if ((@customer = Customer.find_by_user_id(current_user.id)) and + (params[:id] == @customer.braintree_customer_id)) + @braintree_data = Braintree::Customer.find(params[:id]) #used in editing form + @default_cc = @customer.default_credit_card(@braintree_data) + else + # TODO will want case for admins, presumably + access_denied + end + end + +end diff --git a/billing/app/controllers/customers_controller.rb b/billing/app/controllers/customers_controller.rb deleted file mode 100644 index 2532334..0000000 --- a/billing/app/controllers/customers_controller.rb +++ /dev/null @@ -1,58 +0,0 @@ -class CustomersController < BillingBaseController - before_filter :authorize - before_filter :fetch_customer_data, :only => [:show, :edit] - - - def show - @active_subscription = @customer.subscriptions(@braintree_data) - end - - def new - if customer = Customer.find_by_user_id(current_user.id) - redirect_to edit_customer_path(customer.braintree_customer_id), :notice => 'Here is your saved customer data' - else - @tr_data = Braintree::TransparentRedirect. - create_customer_data(:redirect_url => confirm_customer_url) - end - end - - def edit - @tr_data = Braintree::TransparentRedirect. - update_customer_data(:redirect_url => confirm_customer_url, - :customer_id => params[:id]) - end - - def confirm - @result = Braintree::TransparentRedirect.confirm(request.query_string) - - if @result.success? - # customer = Customer.new(:user_id => current_user.id, :braintree_customer_id => @result.customer.id) - customer = Customer.new(:braintree_customer_id => @result.customer.id) - customer.user = current_user - customer.save - #current_user.save! - render :action => "confirm" - #elsif current_user.has_payment_info? - elsif (customer = Customer.find_by_user_id(current_user.id)) and customer.has_payment_info? - #customer.with_braintree_data! - render :action => "edit" - else - render :action => "new" - end - end - - private - - def fetch_customer_data - if ((@customer = Customer.find_by_user_id(current_user.id)) and - (params[:id] == @customer.braintree_customer_id)) - #current_customer.with_braintree_data! - @braintree_data = Braintree::Customer.find(params[:id]) #used in editing form - @default_cc = @customer.default_credit_card(@braintree_data) - else - # TODO will want case for admins, presumably - access_denied - end - end - -end -- cgit v1.2.3