authorize = $authorize; } public function chargeCustomerProfile($profile_id, $payment_profile_id, $amount) { $this->authorize->init(); // Set the transaction's refId $refId = 'ref'.time(); $profileToCharge = new CustomerProfilePaymentType(); $profileToCharge->setCustomerProfileId($profile_id); $paymentProfile = new PaymentProfileType(); $paymentProfile->setPaymentProfileId($payment_profile_id); $profileToCharge->setPaymentProfile($paymentProfile); $invoice_numbers = ''; if($this->authorize->payment_hash->data) $invoice_numbers = collect($this->authorize->payment_hash->data->invoices)->pluck('invoice_number')->implode(','); $description = "Invoices: {$invoice_numbers} for {$amount} for client {$this->authorize->client->present()->name()}"; $order = new OrderType(); $order->setInvoiceNumber($invoice_numbers); $order->setDescription($description); $transactionRequestType = new TransactionRequestType(); $transactionRequestType->setTransactionType('authCaptureTransaction'); $transactionRequestType->setAmount($amount); $transactionRequestType->setOrder($order); $transactionRequestType->setProfile($profileToCharge); $transactionRequestType->setCurrencyCode($this->authorize->client->currency()->code); $request = new CreateTransactionRequest(); $request->setMerchantAuthentication($this->authorize->merchant_authentication); $request->setRefId($refId); $request->setTransactionRequest($transactionRequestType); $controller = new CreateTransactionController($request); $response = $controller->executeWithApiResponse($this->authorize->mode()); if ($response != null && $response->getMessages()->getResultCode() == 'Ok') { $tresponse = $response->getTransactionResponse(); if ($tresponse != null && $tresponse->getMessages() != null) { nlog(' Transaction Response code : '.$tresponse->getResponseCode()); nlog('Charge Customer Profile APPROVED :'); nlog(' Charge Customer Profile AUTH CODE : '.$tresponse->getAuthCode()); nlog(' Charge Customer Profile TRANS ID : '.$tresponse->getTransId()); nlog(' Code : '.$tresponse->getMessages()[0]->getCode()); nlog(' Description : '.$tresponse->getMessages()[0]->getDescription()); //nlog(" Charge Customer Profile TRANS STATUS : " . $tresponse->getTransactionStatus() ); //nlog(" Charge Customer Profile Amount : " . $tresponse->getAuthAmount()); nlog(' Code : '.$tresponse->getMessages()[0]->getCode()); nlog(' Description : '.$tresponse->getMessages()[0]->getDescription()); nlog(print_r($tresponse->getMessages()[0], 1)); } else { nlog('Transaction Failed '); if ($tresponse->getErrors() != null) { nlog(' Error code : '.$tresponse->getErrors()[0]->getErrorCode()); nlog(' Error message : '.$tresponse->getErrors()[0]->getErrorText()); nlog(print_r($tresponse->getErrors()[0], 1)); } } } else { nlog('Transaction Failed '); $tresponse = $response->getTransactionResponse(); if ($tresponse != null && $tresponse->getErrors() != null) { nlog(' Error code : '.$tresponse->getErrors()[0]->getErrorCode()); nlog(' Error message : '.$tresponse->getErrors()[0]->getErrorText()); nlog(print_r($tresponse->getErrors()[0], 1)); } else { nlog(' Error code : '.$response->getMessages()->getMessage()[0]->getCode()); nlog(' Error message : '.$response->getMessages()->getMessage()[0]->getText()); } } return [ 'response' => $tresponse, 'amount' => $amount, 'profile_id' => $profile_id, 'payment_profile_id' => $payment_profile_id, ]; } }