Class: Spree::PaymentSessions::Razorpay

Inherits:
Spree::PaymentSession
  • Object
show all
Defined in:
app/models/spree/payment_sessions/razorpay.rb

Instance Method Summary collapse

Instance Method Details

#client_keyObject



5
6
7
# File 'app/models/spree/payment_sessions/razorpay.rb', line 5

def client_key
  external_data['client_key']
end

#find_or_create_payment!(metadata = {}) ⇒ Object

Required for Headless API V3 to properly create the source and prevent double-charges



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
# File 'app/models/spree/payment_sessions/razorpay.rb', line 14

def find_or_create_payment!( = {})
  return unless persisted?
  return payment if payment.present?

  # 1. Lock the order to prevent race conditions from Webhooks
  order.with_lock do
    rzp_payment_id = external_data['razorpay_payment_id']
    
    # 2. Check if the webhook already created this payment
    existing_payment = order.payments.where(
      payment_method: payment_method,
      response_code: rzp_payment_id || external_id
    ).first

    return existing_payment if existing_payment.present?

    # 3. Create your custom RazorpayCheckout source record for Headless!
    source = ::Spree::RazorpayCheckout.create!(
      order_id: order.id,
      razorpay_payment_id: rzp_payment_id,
      razorpay_order_id: external_id,
      razorpay_signature: external_data['razorpay_signature'],
      status: 'captured',
      payment_method: payment_method.name
    )

    # 4. Create the actual Spree::Payment
    order.payments.create!(
      payment_method: payment_method,
      amount: amount,
      response_code: rzp_payment_id || external_id,
      source: source,
      skip_source_requirement: true
    )
  end
end

#razorpay_order_idObject



9
10
11
# File 'app/models/spree/payment_sessions/razorpay.rb', line 9

def razorpay_order_id
  external_id
end