Files
danbooru/app/controllers/user_upgrades_controller.rb
2014-11-29 11:31:42 -08:00

51 lines
1.3 KiB
Ruby

class UserUpgradesController < ApplicationController
before_filter :member_only, :only => [:new, :show]
helper_method :encrypt_custom, :coinbase
force_ssl :if => :ssl_enabled?
skip_before_action :verify_authenticity_token, only: [:create]
def create
if params[:order][:status] == "completed"
user_id, level = decrypt_custom
user = User.find(user_id)
if user.level < User::Levels::PLATINUM && level >= User::Levels::GOLD && level <= User::Levels::PLATINUM
user.promote_to!(level, :skip_feedback => true)
end
end
render :nothing => true
end
def new
unless CurrentUser.user.is_anonymous?
TransactionLogItem.record_account_upgrade_view(CurrentUser.user, request.referer)
end
end
def show
end
def encrypt_custom(level)
crypt.encrypt_and_sign("#{CurrentUser.user.id},#{level}")
end
def coinbase
@coinbase_api ||= Coinbase::Client.new(Danbooru.config.coinbase_api_key, Danbooru.config.coinbase_api_secret)
end
private
def decrypt_custom
crypt.decrypt_and_verify(params[:order][:custom]).split(/,/).map(&:to_i)
end
def crypt
ActiveSupport::MessageEncryptor.new(Danbooru.config.coinbase_secret)
end
def ssl_enabled?
!Rails.env.development? && !Rails.env.test?
end
end