Fixing stripe controller webhook

This commit is contained in:
Matt Young 2026-01-29 23:15:22 -06:00
parent fcac34908e
commit 9d6c12ac5f
1 changed files with 16 additions and 2 deletions

View File

@ -48,6 +48,8 @@ class StripeController extends Controller
public function webhook(Request $request) public function webhook(Request $request)
{ {
\Log::info('Stripe webhook received');
$payload = $request->getContent(); $payload = $request->getContent();
$signature = $request->header('Stripe-Signature'); $signature = $request->header('Stripe-Signature');
@ -58,12 +60,20 @@ class StripeController extends Controller
config('services.stripe.webhook_secret') config('services.stripe.webhook_secret')
); );
} catch (\Exception $e) { } catch (\Exception $e) {
\Log::error('Stripe webhook signature verification failed', ['error' => $e->getMessage()]);
return response('Invalid signature', 400); return response('Invalid signature', 400);
} }
\Log::info('Stripe webhook event', ['type' => $event->type]);
if ($event->type === 'checkout.session.completed') { if ($event->type === 'checkout.session.completed') {
$session = $event->data->object; $session = $event->data->object;
\Log::info('Processing checkout.session.completed', [
'invoice_id' => $session->metadata->invoice_id ?? 'not set',
'payment_intent' => $session->payment_intent,
]);
$invoice = Invoice::find($session->metadata->invoice_id); $invoice = Invoice::find($session->metadata->invoice_id);
if ($invoice) { if ($invoice) {
@ -75,9 +85,9 @@ class StripeController extends Controller
'expand' => ['latest_charge.balance_transaction'], 'expand' => ['latest_charge.balance_transaction'],
]); ]);
$feeAmount = $paymentIntent->latest_charge->balance_transaction->fee; $feeAmount = $paymentIntent->latest_charge?->balance_transaction?->fee ?? 0;
Payment::create([ $payment = Payment::create([
'invoice_id' => $invoice->id, 'invoice_id' => $invoice->id,
'payment_date' => now(), 'payment_date' => now(),
'status' => PaymentStatus::COMPLETED, 'status' => PaymentStatus::COMPLETED,
@ -87,6 +97,10 @@ class StripeController extends Controller
'amount' => $session->amount_total / 100, 'amount' => $session->amount_total / 100,
'fee_amount' => $feeAmount / 100, 'fee_amount' => $feeAmount / 100,
]); ]);
\Log::info('Payment created', ['payment_id' => $payment->id, 'fee_amount' => $feeAmount]);
} else {
\Log::warning('Invoice not found for Stripe webhook', ['invoice_id' => $session->metadata->invoice_id]);
} }
} }