Merge pull request #2303 from r888888888/stripe

Stripe integration
This commit is contained in:
Albert Yi
2014-11-07 14:17:50 -08:00
25 changed files with 960 additions and 31 deletions

View File

@@ -0,0 +1,50 @@
class UserUpgradesController < ApplicationController
before_filter :member_only
def create
if params[:desc] == "Upgrade to Gold"
level = User::Levels::GOLD
cost = 2000
elsif params[:desc] == "Upgrade to Platinum"
level = User::Levels::PLATINUM
cost = 4000
elsif params[:desc] == "Upgrade Gold to Platinum" && CurrentUser.user.level == User::Levels::GOLD
level = User::Levels::PLATINUM
cost = 2000
else
render :text => "invalid desc", :status => 422
return
end
@user = CurrentUser.user
stripe_token = params[:stripeToken]
begin
charge = Stripe::Charge.create(
:amount => cost,
:currency => "usd",
:card => params[:stripeToken],
:description => params[:desc]
)
@user.promote_to!(level, :skip_feedback => true)
UserMailer.upgrade(@user, params[:email]).deliver
flash[:success] = true
rescue Stripe::CardError => e
flash[:error] = e.message
end
redirect_to user_upgrade_path
end
def new
unless CurrentUser.user.is_anonymous?
TransactionLogItem.record_account_upgrade_view(CurrentUser.user, request.referer)
end
end
def show
end
end

View File

@@ -59,24 +59,6 @@ class UsersController < ApplicationController
respond_with(@user)
end
def upgrade_information
unless CurrentUser.user.is_anonymous?
TransactionLogItem.record_account_upgrade_view(CurrentUser.user, request.referer)
end
end
def upgrade
@user = User.find(params[:id])
if params[:email] =~ /paypal/
UserMailer.upgrade_fail(params[:email]).deliver
else
UserMailer.upgrade(@user, params[:email]).deliver
end
redirect_to user_path(@user), :notice => "Email was sent"
end
def cache
@user = User.find(params[:id])
@user.update_cache