summaryrefslogtreecommitdiff
path: root/billing/app/controllers/customer_controller.rb
blob: 887dbfd555a809483486306afcfbe8db6ddd0951 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
class CustomerController < BillingBaseController
  before_filter :authorize
  def show
    @active_subscription = customer.subscriptions
  end

  def new
    if customer.has_payment_info?
      redirect_to edit_customer_path(customer), :notice => 'Here is your saved customer data'
    else
      fetch_new_transparent_redirect_data
    end
  end

  def edit
    fetch_edit_transparent_redirect_data
  end

  def confirm
    @result = Braintree::TransparentRedirect.confirm(request.query_string)

    if @result.success?
      customer.braintree_customer =  @result.customer
      customer.save
      render :action => "confirm"
    elsif customer.has_payment_info?
      fetch_edit_transparent_redirect_data
      render :action => "edit"
    else
      fetch_new_transparent_redirect_data
      render :action => "new"
    end
  end

  protected

  def fetch_new_transparent_redirect_data
    @tr_data = Braintree::TransparentRedirect.
      create_customer_data(:redirect_url => confirm_customer_url)
  end

  def fetch_edit_transparent_redirect_data
    customer.with_braintree_data!
    @default_cc = customer.default_credit_card
    @tr_data = Braintree::TransparentRedirect.
      update_customer_data(:redirect_url => confirm_customer_url,
                           :customer_id => customer.braintree_customer_id) ##??
  end

  def customer
    @customer ||= Customer.find(params[:id]) if params[:id]  # edit, show
    @customer ||= Customer.find_by_user_id(current_user.id)  # confirm
    @customer ||= Customer.new(user: current_user)
    # TODO will want case for admins, presumably
    access_denied unless @customer.user == current_user
    return @customer
  end
end