forte = $forte; $this->forte_base_uri = "https://sandbox.forte.net/api/v3/"; if($this->forte->company_gateway->getConfigField('testMode') == false){ $this->forte_base_uri = "https://api.forte.net/v3/"; } $this->forte_api_access_id = $this->forte->company_gateway->getConfigField('apiAccessId'); $this->forte_secure_key = $this->forte->company_gateway->getConfigField('secureKey'); $this->forte_auth_organization_id = $this->forte->company_gateway->getConfigField('authOrganizationId'); $this->forte_organization_id = $this->forte->company_gateway->getConfigField('organizationId'); $this->forte_location_id = $this->forte->company_gateway->getConfigField('locationId'); } public function authorizeView(array $data) { return render('gateways.forte.credit_card.authorize', $data); } public function authorizeResponse($request) { $customer_token = null; $request->validate([ 'card_number'=>'required', 'card_holders_name'=>'required|string', 'expiry_month'=>'required', 'expiry_year'=>'required', 'cvc'=>'required', ]); if ($this->forte->client->gateway_tokens->count() == 0) { try { $curl = curl_init(); curl_setopt_array($curl, array( CURLOPT_URL => $this->forte_base_uri.'organizations/'.$this->forte_organization_id.'/locations/'.$this->forte_location_id.'/customers/', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "first_name": "'.$this->forte->client->present()->name().'", "last_name": "'.$this->forte->client->present()->name().'", "company_name": "'.$this->forte->client->present()->name().'", "customer_id": "'.$this->forte->client->number.'" }', CURLOPT_HTTPHEADER => array( 'X-Forte-Auth-Organization-Id: '.$this->forte_organization_id, 'Content-Type: application/json', 'Authorization: Basic '.base64_encode($this->forte_api_access_id.':'.$this->forte_secure_key), 'Cookie: visid_incap_621087=QJCccwHeTHinK5DnAeQIuXPk5mAAAAAAQUIPAAAAAAATABmm7IZkHhUi85sN+UaS; nlbi_621087=eeFJXPvhGXW3XVl0R1efXgAAAAC5hY2Arn4aSDDQA+R2vZZu; incap_ses_713_621087=IuVrdOb1HwK0pTS8ExblCT8B6GAAAAAAWyswWx7wzWve4j23+Nsp4w==' ), )); $response = curl_exec($curl); $httpcode = curl_getinfo($curl, CURLINFO_HTTP_CODE); curl_close($curl); $response=json_decode($response); if ($httpcode>299) { $error = Validator::make([], []); $error->getMessageBag()->add('gateway_error', $response->response->response_desc); return redirect()->back()->withErrors($error); } $customer_token=$response->customer_token; } catch (\Throwable $th) { throw $th; } }else{ $customer_token = $this->forte->client->gateway_tokens[0]->gateway_customer_reference; } $curl = curl_init(); curl_setopt_array($curl, array( CURLOPT_URL => $this->forte_base_uri.'organizations/'.$this->forte_organization_id.'/locations/'.$this->forte_location_id.'/customers/'.$customer_token.'/paymethods', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "notes":"'.$request->card_holders_name.' Card", "card": { "name_on_card":"'.$request->card_holders_name.'", "card_type":"'.$request->card_type.'", "account_number":"'.str_replace(' ', '', $request->card_number).'", "expire_month":'.$request->expiry_month.', "expire_year":20'.$request->expiry_year.', "card_verification_value": "'.$request->cvc.'" } }', CURLOPT_HTTPHEADER => array( 'X-Forte-Auth-Organization-Id: '.$this->forte_organization_id, 'Content-Type: application/json', 'Authorization: Basic '.base64_encode($this->forte_api_access_id.':'.$this->forte_secure_key), 'Cookie: visid_incap_621087=QJCccwHeTHinK5DnAeQIuXPk5mAAAAAAQUIPAAAAAAATABmm7IZkHhUi85sN+UaS' ), )); $response = curl_exec($curl); $httpcode = curl_getinfo($curl, CURLINFO_HTTP_CODE); curl_close($curl); $response=json_decode($response); if ($httpcode>299) { $error = Validator::make([], []); $error->getMessageBag()->add('gateway_error', $response->response->response_desc); return redirect()->back()->withErrors($error); } $payment_meta = new \stdClass; $payment_meta->exp_month = (string) $response->card->expire_month; $payment_meta->exp_year = (string) $response->card->expire_year; $payment_meta->brand = (string) $response->card->card_type; $payment_meta->last4 = (string) $response->card->last_4_account_number; $payment_meta->type = GatewayType::CREDIT_CARD; $data = [ 'payment_meta' => $payment_meta, 'token' => $response->paymethod_token, 'payment_method_id' => $request->payment_method_id, ]; $this->forte->storeGatewayToken($data, ['gateway_customer_reference' => $customer_token]); return redirect()->route('client.payment_methods.index')->withSuccess('Payment Method added.'); } public function paymentView(array $data) { $this->forte->payment_hash->data = array_merge((array) $this->forte->payment_hash->data, $data); $this->forte->payment_hash->save(); $data['gateway'] = $this; return render('gateways.forte.credit_card.pay', $data); } public function paymentResponse(PaymentResponseRequest $request) { $payment_hash = PaymentHash::whereRaw('BINARY `hash`= ?', [$request->input('payment_hash')])->firstOrFail(); try { $curl = curl_init(); curl_setopt_array($curl, array( CURLOPT_URL => $this->forte_base_uri.'organizations/'.$this->forte_organization_id.'/locations/'.$this->forte_location_id.'/transactions', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "action":"sale", "authorization_amount": '.$payment_hash->data->total->amount_with_fee.', "service_fee_amount": '.$payment_hash->data->total->fee_total.', "paymethod_token": "'.$request->payment_token.'", "billing_address":{ "first_name": "'.auth()->user()->client->name.'", "last_name": "'.auth()->user()->client->name.'" } }', CURLOPT_HTTPHEADER => array( 'X-Forte-Auth-Organization-Id: '.$this->forte_organization_id, 'Content-Type: application/json', 'Authorization: Basic '.base64_encode($this->forte_api_access_id.':'.$this->forte_secure_key), 'Cookie: visid_incap_621087=u18+3REYR/iISgzZxOF5s2ODW2IAAAAAQUIPAAAAAADuGqKgECQLS81FcSDrmhGe; nlbi_621087=YHngadhJ2VU+yr7/R1efXgAAAAD3mQyhqmnLls8PRu4iN58G; incap_ses_1136_621087=CVdrXUdhIlm9WJNDieLDD4QVXGIAAAAAvBwvkUcwhM0+OwvdPm2stg==' ), )); $response = curl_exec($curl); $httpcode = curl_getinfo($curl, CURLINFO_HTTP_CODE); curl_close($curl); $response=json_decode($response); } catch (\Throwable $th) { throw $th; } if ($httpcode>299) { $error = Validator::make([], []); $error->getMessageBag()->add('gateway_error', $response->response->response_desc); return redirect('client/invoices')->withErrors($error); } $data = [ 'payment_method' => $request->payment_method_id, 'payment_type' => PaymentType::parseCardType(strtolower($request->card_brand)) ?: PaymentType::CREDIT_CARD_OTHER, 'amount' => $payment_hash->data->amount_with_fee, 'transaction_reference' => $response->transaction_id, 'gateway_type_id' => GatewayType::CREDIT_CARD, ]; $payment=$this->forte->createPayment($data, Payment::STATUS_COMPLETED); return redirect('client/invoices')->withSuccess('Invoice paid.'); } }