2010-11-21 13:41:06 +00:00
|
|
|
class PaypalExpressCallbacksController < Spree::BaseController
|
|
|
|
include ActiveMerchant::Billing::Integrations
|
|
|
|
skip_before_filter :verify_authenticity_token
|
|
|
|
|
|
|
|
def notify
|
2010-11-24 09:31:31 +00:00
|
|
|
retrieve_details #need to retreive details first to ensure ActiveMerchant gets configured correctly.
|
|
|
|
|
2010-11-21 13:41:06 +00:00
|
|
|
@notification = Paypal::Notification.new(request.raw_post)
|
|
|
|
|
|
|
|
# we only care about eChecks (for now?)
|
2011-01-11 13:13:58 +00:00
|
|
|
if @notification.params["payment_type"] == "echeck" && @notification.acknowledge && @payment && @order.total >= @payment.amount
|
2010-11-21 13:41:06 +00:00
|
|
|
case @notification.params["payment_status"]
|
|
|
|
when "Denied"
|
|
|
|
create_txn PaypalTxn::TxnType::DENIED
|
|
|
|
|
|
|
|
when "Completed"
|
|
|
|
create_txn PaypalTxn::TxnType::CAPTURE
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
render :nothing => true
|
2010-01-22 16:29:55 +00:00
|
|
|
end
|
2010-11-21 13:41:06 +00:00
|
|
|
|
|
|
|
private
|
|
|
|
def retrieve_details
|
2010-11-24 09:31:31 +00:00
|
|
|
@order = Order.find_by_number(params["invoice"])
|
|
|
|
|
|
|
|
if @order
|
|
|
|
@payment = @order.checkout.payments.find(:first,
|
2010-11-21 13:41:06 +00:00
|
|
|
:conditions => {"transactions.txn_type" => PaypalTxn::TxnType::AUTHORIZE,
|
2010-11-24 09:31:31 +00:00
|
|
|
"transactions.payment_type" => params["payment_type"]},
|
2010-11-21 13:41:06 +00:00
|
|
|
:joins => :transactions)
|
2010-11-24 09:31:31 +00:00
|
|
|
|
|
|
|
@payment.try(:payment_method).try(:provider) #configures ActiveMerchant
|
|
|
|
end
|
2010-11-21 13:41:06 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def create_txn(txn_type)
|
2010-11-24 09:31:31 +00:00
|
|
|
if txn_type == PaypalTxn::TxnType::CAPTURE
|
|
|
|
@payment.finalize! if @payment.can_finalize?
|
|
|
|
elsif txn_type == PaypalTxn::TxnType::DENIED
|
|
|
|
#maybe we should do something?
|
|
|
|
end
|
|
|
|
|
|
|
|
PaypalTxn.create(:payment => @payment,
|
2010-11-21 13:41:06 +00:00
|
|
|
:txn_type => txn_type,
|
|
|
|
:amount => @notification.params["payment_gross"].to_f,
|
|
|
|
:payment_status => @notification.params["payment_status"],
|
|
|
|
:transaction_id => @notification.params["txn_id"],
|
|
|
|
:transaction_type => @notification.params["txn_type"],
|
|
|
|
:payment_type => @notification.params["payment_type"])
|
|
|
|
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2010-01-22 16:29:55 +00:00
|
|
|
end
|