AuthorizeCreditCard::class, ]; const SYSTEM_LOG_TYPE = SystemLog::TYPE_AUTHORIZE; public function setPaymentMethod($payment_method_id) { $class = self::$methods[$payment_method_id]; $this->payment_method = new $class($this); return $this; } /** * Returns the gateway types. */ public function gatewayTypes() :array { $types = [ GatewayType::CREDIT_CARD, ]; return $types; } public function getClientRequiredFields(): array { return [ ['name' => 'client_name', 'label' => ctrans('texts.name'), 'type' => 'text', 'validation' => 'required|min:2'], ['name' => 'contact_email', 'label' => ctrans('texts.email'), 'type' => 'text', 'validation' => 'required|email:rfc'], ['name' => 'client_address_line_1', 'label' => ctrans('texts.address1'), 'type' => 'text', 'validation' => 'required'], ['name' => 'client_address_line_2', 'label' => ctrans('texts.address2'), 'type' => 'text', 'validation' => 'sometimes'], ['name' => 'client_city', 'label' => ctrans('texts.city'), 'type' => 'text', 'validation' => 'required'], ['name' => 'client_state', 'label' => ctrans('texts.state'), 'type' => 'text', 'validation' => 'required'], ['name' => 'client_postal_code', 'label' => ctrans('texts.postal_code'), 'type' => 'text', 'validation' => 'required'], ['name' => 'client_country_id', 'label' => ctrans('texts.country'), 'type' => 'select', 'validation' => 'required'], ]; } public function authorizeView($payment_method) { return (new AuthorizePaymentMethod($this))->authorizeView(); } public function authorizeResponse($request) { return (new AuthorizePaymentMethod($this))->authorizeResponseView($request); } public function processPaymentView($data) { return $this->payment_method->processPaymentView($data); } public function processPaymentResponse($request) { return $this->payment_method->processPaymentResponse($request); } public function refund(Payment $payment, $refund_amount, $return_client_response = false) { return (new RefundTransaction($this))->refundTransaction($payment, $refund_amount); } public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash) { $this->setPaymentMethod($cgt->gateway_type_id); return $this->payment_method->tokenBilling($cgt, $payment_hash); } public function init() { error_reporting(E_ALL & ~E_DEPRECATED); $this->merchant_authentication = new MerchantAuthenticationType(); $this->merchant_authentication->setName($this->company_gateway->getConfigField('apiLoginId')); $this->merchant_authentication->setTransactionKey($this->company_gateway->getConfigField('transactionKey')); return $this; } public function getPublicClientKey() { $request = new GetMerchantDetailsRequest(); $request->setMerchantAuthentication($this->merchant_authentication); $controller = new GetMerchantDetailsController($request); $response = $controller->executeWithApiResponse($this->mode()); return $response->getPublicClientKey(); } public function mode() { if ($this->company_gateway->getConfigField('testMode')) { return ANetEnvironment::SANDBOX; } return $env = ANetEnvironment::PRODUCTION; } public function findClientGatewayRecord() :?ClientGatewayToken { return ClientGatewayToken::where('client_id', $this->client->id) ->where('company_gateway_id', $this->company_gateway->id) ->first(); } /** * Detach payment method from Authorize.net. * * @param ClientGatewayToken $token * @return void */ public function detach(ClientGatewayToken $token) { return (new AuthorizePaymentMethod($this))->deletePaymentProfile($token->gateway_customer_reference, $token->token); } }