summaryrefslogtreecommitdiff
path: root/billing/app/controllers/customer_controller.rb
blob: f38f77e5e1f090b347e6def3495a0d72d27789b0 (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
59
60
61
62
63
64
65
class CustomerController < BillingBaseController
  before_filter :authorize

  def show
    if customer = fetch_customer
      customer.with_braintree_data!
      @default_cc = customer.default_credit_card #TODO not actually right way
      @active_subscription = customer.subscriptions
      @transactions = customer.braintree_customer.transactions
    end
  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 fetch_customer
    @customer = Customer.find_by_user_id(@user.id)
    if @user == current_user
      @customer ||= Customer.new(user: @user)
    end
    # TODO will want case for admins, presumably
    access_denied unless (@customer and (@customer.user == current_user)) or admin?
    return @customer
  end
end