275 lines
7.8 KiB
Ruby
275 lines
7.8 KiB
Ruby
# -*- encoding : utf-8 -*-
|
|
|
|
class Public::RenewsController < ApplicationController
|
|
|
|
layout "public"
|
|
skip_before_filter :verify_authenticity_token, :only => [:ipn]
|
|
|
|
|
|
def select_sheet
|
|
raise
|
|
@renew = Renew.new(:sheet_number => params[:s])
|
|
end
|
|
|
|
def save_sheet
|
|
@renew = Renew.new(params.require(:renew).permit!)
|
|
|
|
|
|
if @renew.save
|
|
session[:renew_id] = @renew.id
|
|
redirect_to paid_by_paypal_public_renews_index_path
|
|
|
|
else
|
|
render action: "select_sheet"
|
|
|
|
end
|
|
end
|
|
|
|
|
|
|
|
|
|
def paid
|
|
@renew = Order.find_by_token(params[:id])
|
|
if @renew.paid
|
|
redirect_to public_order_path(@renew.token)
|
|
else
|
|
|
|
respond_to do |format|
|
|
format.html { redirect_to paid_by_paypal_public_order_path(@renew.token)}
|
|
|
|
end
|
|
|
|
|
|
end
|
|
end
|
|
|
|
def paid_by_paypal
|
|
@renew = Renew.where(:id => session[:renew_id]).first
|
|
|
|
if @renew and !@renew.ok
|
|
|
|
|
|
|
|
|
|
require 'paypal-sdk-merchant'
|
|
@api = PayPal::SDK::Merchant::API.new
|
|
|
|
|
|
@set_express_checkout = @api.build_set_express_checkout({
|
|
:SetExpressCheckoutRequestDetails => {
|
|
:custom => @renew.id,
|
|
:ReturnURL => do_paypal_payment_public_renews_index_url,
|
|
:CancelURL => select_sheet_public_renews_index_url(),
|
|
:NoShipping => 1,
|
|
:PaymentDetails => [{
|
|
:OrderTotal => {
|
|
:currencyID => "EUR",
|
|
:value =>@renew.price },
|
|
|
|
:NotifyURL => "http://lepicvert.org"+ipn_public_renews_index_path,
|
|
|
|
:PaymentDetailsItem => [{:Name => "Renouvellement adhésion",:Quantity => 1,:Amount => {:currencyID => "EUR",:value => @renew.price } }],
|
|
:PaymentAction => "Sale" }] } })
|
|
|
|
# Make API call & get response
|
|
@set_express_checkout_response = @api.set_express_checkout(@set_express_checkout)
|
|
|
|
# Access Response
|
|
if @set_express_checkout_response.success?
|
|
|
|
@get_express_checkout_details = @api.build_get_express_checkout_details({
|
|
:Token => @renew.id })
|
|
|
|
@get_express_checkout_details_response = @api.get_express_checkout_details(@get_express_checkout_details)
|
|
|
|
|
|
|
|
|
|
@payment_detail = @get_express_checkout_details_response.GetExpressCheckoutDetailsResponseDetails.PaymentDetails[0]
|
|
|
|
|
|
redirect_to @api.express_checkout_url(@set_express_checkout_response.Token)
|
|
else
|
|
@set_express_checkout_response.Errors
|
|
end
|
|
|
|
else
|
|
redirect_to select_sheet_public_renews_path()
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def do_paypal_payment
|
|
|
|
|
|
require 'paypal-sdk-merchant'
|
|
@api = PayPal::SDK::Merchant::API.new
|
|
|
|
|
|
@get_express_checkout_details = @api.build_get_express_checkout_details({:Token => params[:token] })
|
|
|
|
@get_express_checkout_details_response = @api.get_express_checkout_details(@get_express_checkout_details)
|
|
|
|
|
|
|
|
|
|
# Access Response
|
|
if @get_express_checkout_details_response.success?
|
|
|
|
@renew = Renew.find(@get_express_checkout_details_response.GetExpressCheckoutDetailsResponseDetails.Custom.to_s)
|
|
puts "AAA"
|
|
puts @get_express_checkout_details_response.GetExpressCheckoutDetailsResponseDetails.Custom.to_s
|
|
|
|
else
|
|
|
|
|
|
@get_express_checkout_details_response.Errors
|
|
end
|
|
|
|
# Build request object
|
|
@do_express_checkout_payment = @api.build_do_express_checkout_payment({
|
|
:DoExpressCheckoutPaymentRequestDetails => {
|
|
:PaymentAction => "Sale",
|
|
:Token => params[:token],
|
|
:PayerID => params[:PayerID],
|
|
:PaymentDetails => [{
|
|
:OrderTotal => {
|
|
:currencyID => "EUR",
|
|
:value => @renew.price },
|
|
:NotifyURL => "http://lepicvert.org"+ipn_public_renews_index_path }] } })
|
|
|
|
# Make API call & get response
|
|
@do_express_checkout_payment_response = @api.do_express_checkout_payment(@do_express_checkout_payment)
|
|
|
|
# Access Response
|
|
if @do_express_checkout_payment_response.success?
|
|
@payment_info = @do_express_checkout_payment_response.DoExpressCheckoutPaymentResponseDetails.PaymentInfo[0]
|
|
|
|
@do_express_checkout_payment_response.DoExpressCheckoutPaymentResponseDetails
|
|
@do_express_checkout_payment_response.FMFDetails
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if @payment_info.PaymentStatus.to_s == "Completed"
|
|
@renew.payment_type_id = 3
|
|
@renew.ok = true
|
|
@renew.save
|
|
@renew.done_return
|
|
|
|
redirect_to thanks_public_renews_index_url
|
|
|
|
else
|
|
render :file => 'public/500.html', :status => 500, :layout => false
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
render :file => 'public/500.html', :status => 500, :layout => false
|
|
end
|
|
|
|
|
|
|
|
|
|
end
|
|
|
|
def ipn
|
|
|
|
|
|
@api = PayPal::SDK::Merchant.new
|
|
if @api.ipn_valid?(request.raw_post) # return true or false
|
|
@renew = Renew.find_by_token(params[:custom].to_s)
|
|
if params[:payment_status] == "Completed"
|
|
|
|
|
|
@renew.payment_type_id = 3
|
|
@renew.ok = true
|
|
|
|
@renew.paypal_test_ipn= params[:test_ipn]
|
|
|
|
@renew.paypal_txn_type = params[:txn_type]
|
|
@renew.paypal_txn_id = params[:txn_id]
|
|
@renew.paypal_payment_date = params[:payment_date]
|
|
|
|
@renew.paypal_payment_status = params[:payment_status]
|
|
@renew.paypal_reason_code = params[:reason_code]
|
|
@renew.paypal_payment_type = params[:payment_type]
|
|
|
|
@renew.paypal_mc_currency = params[:mc_currency]
|
|
@renew.paypal_mc_fee = params[:mc_fee]
|
|
@renew.paypal_mc_gross = params[:mc_gross]
|
|
|
|
@renew.paypal_residence_country = params[:residence_country]
|
|
@renew.paypal_last_name = params[:last_name]
|
|
@renew.paypal_first_name = params[:first_name]
|
|
@renew.paypal_payer_email = params[:payer_email]
|
|
@renew.paypal_payer_id = params[:payer_id]
|
|
@renew.paypal_payer_status = params[:payer_status]
|
|
|
|
@renew.paypal_receiver_id = params[:receiver_id]
|
|
@renew.paypal_receiver_email = params[:receiver_email]
|
|
|
|
@renew.paypal_protection_eligibility = params[:protection_eligibility]
|
|
@renew.paypal_ipn_track_id = params[:ipn_track_id]
|
|
|
|
@renew.save
|
|
puts "le paiement de la commande #{@renew.id} par paypal est validé"
|
|
|
|
else
|
|
@renew.paypal_test_ipn= params[:test_ipn]
|
|
|
|
@renew.paypal_txn_type = params[:txn_type]
|
|
@renew.paypal_txn_id = params[:txn_id]
|
|
@renew.paypal_payment_date = params[:payment_date]
|
|
|
|
@renew.paypal_payment_status = params[:payment_status]
|
|
@renew.paypal_reason_code = params[:reason_code]
|
|
@renew.paypal_payment_type = params[:payment_type]
|
|
|
|
@renew.paypal_mc_currency = params[:mc_currency]
|
|
@renew.paypal_mc_fee = params[:mc_fee]
|
|
@renew.paypal_mc_gross = params[:mc_gross]
|
|
|
|
@renew.paypal_residence_country = params[:residence_country]
|
|
@renew.paypal_last_name = params[:last_name]
|
|
@renew.paypal_first_name = params[:first_name]
|
|
@renew.paypal_payer_email = params[:payer_email]
|
|
@renew.paypal_payer_id = params[:payer_id]
|
|
@renew.paypal_payer_status = params[:payer_status]
|
|
|
|
@renew.paypal_receiver_id = params[:receiver_id]
|
|
@renew.paypal_receiver_email = params[:receiver_email]
|
|
|
|
@renew.paypal_protection_eligibility = params[:protection_eligibility]
|
|
@renew.paypal_ipn_track_id = params[:ipn_track_id]
|
|
@renew.ok = false
|
|
|
|
@renew.save
|
|
|
|
@renew.done_return
|
|
|
|
end
|
|
|
|
else
|
|
|
|
end
|
|
render :inline => "test"
|
|
end
|
|
|
|
|
|
|
|
|
|
end
|