stripe_request = $stripe_request; $this->company_key = $company_key; $this->company_gateway_id = $company_gateway_id; } public function handle() { nlog("payment intent failed"); MultiDB::findAndSetDbByCompanyKey($this->company_key); nlog($this->stripe_request); $company = Company::query()->where('company_key', $this->company_key)->first(); foreach ($this->stripe_request as $transaction) { nlog($transaction); $payment = Payment::query() ->where('company_id', $company->id) ->where(function ($query) use ($transaction) { if(isset($transaction['payment_intent'])) { $query->where('transaction_reference', $transaction['payment_intent']); } if(isset($transaction['payment_intent']) && isset($transaction['id'])) { $query->orWhere('transaction_reference', $transaction['id']); } if(!isset($transaction['payment_intent']) && isset($transaction['id'])) { $query->where('transaction_reference', $transaction['id']); } }) ->first(); if ($payment) { $client = $payment->client; if ($payment->status_id == Payment::STATUS_PENDING) { $payment->service()->deletePayment(); } $payment->status_id = Payment::STATUS_FAILED; $payment->save(); $payment_hash = PaymentHash::query()->where('payment_id', $payment->id)->first(); if ($payment_hash) { $error = ctrans('texts.client_payment_failure_body', [ 'invoice' => implode(',', $payment->invoices->pluck('number')->toArray()), 'amount' => array_sum(array_column($payment_hash->invoices(), 'amount')) + $payment_hash->fee_total, ]); } else { $error = 'Payment for '.$payment->client->present()->name()." for {$payment->amount} failed"; } if (array_key_exists('failure_message', $transaction)) { $error .= "\n\n".$transaction['failure_message']; } PaymentFailedMailer::dispatch( $payment_hash, $client->company, $client, $error ); } } } }