diff --git a/.DS_Store b/.DS_Store index fc6e0e1..d56cb8c 100644 Binary files a/.DS_Store and b/.DS_Store differ diff --git a/iyzico/.DS_Store b/iyzico/.DS_Store new file mode 100644 index 0000000..1d69b16 Binary files /dev/null and b/iyzico/.DS_Store differ diff --git a/iyzico/admin/controller/payment/iyzico.php b/iyzico/admin/controller/payment/iyzico.php index 7d4ec0b..731c3c4 100644 --- a/iyzico/admin/controller/payment/iyzico.php +++ b/iyzico/admin/controller/payment/iyzico.php @@ -6,7 +6,7 @@ class iyzico extends \Opencart\System\Engine\Controller { private $error = array(); private $iyzico; private $module_version = VERSION; - private $module_product_name = '1.6'; + private $module_product_name = '2.0'; private $fields = array( @@ -148,7 +148,7 @@ public function index(): void $data['footer'] = $this->load->controller('common/footer'); $data['locale'] = $this->language->get('code'); $data['iyzico_webhook_url_key'] = $this->config->get('webhook_iyzico_webhook_url_key'); - $data['iyzico_webhook_url'] = HTTP_CATALOG.'index.php?route=extension/iyzico/payment/iyzico|webhook&key=' .$this->config->get('webhook_iyzico_webhook_url_key'); + $data['iyzico_webhook_url'] = HTTP_CATALOG.'index.php?route=extension/iyzico/payment/iyzico%7Cwebhook&key=' .$this->config->get('webhook_iyzico_webhook_url_key'); $data['module_version'] = $this->module_product_name; $data['iyzico_webhook_button'] = $this->config->get('payment_iyzico_webhook_active_button'); diff --git a/iyzico/catalog/controller/payment/iyzico.php b/iyzico/catalog/controller/payment/iyzico.php index 879a5f4..91e3cb5 100644 --- a/iyzico/catalog/controller/payment/iyzico.php +++ b/iyzico/catalog/controller/payment/iyzico.php @@ -4,7 +4,7 @@ class iyzico extends \Opencart\System\Engine\Controller { private $module_version = VERSION; - private $module_product_name = '1.6'; + private $module_product_name = '2.0'; private $paymentConversationId; private $webhookToken; @@ -16,18 +16,15 @@ public function index() { $this->load->language('extension/iyzico/payment/iyzico'); - $data['form_class'] = $this->config->get('payment_iyzico_design'); - $data['form_type'] = $this->config->get('payment_iyzico_design'); - $data['config_theme'] = $this->config->get('config_theme'); - $data['onepage_desc'] = $this->language->get('iyzico_onepage_desc'); - - if($data['form_type'] == 'onepage') - $data['form_class'] = 'responsive'; + if (isset($this->session->data['order_id'])) { + //$this->cart->clear(); - $data['user_login_check'] = $this->customer->isLogged(); + unset($this->session->data['payment_method']); + unset($this->session->data['payment_methods']); + } - return $this->load->view('extension/iyzico/payment/iyzico_form',$data); + return $this->getCheckoutFormToken(); } @@ -85,7 +82,7 @@ public function getCheckoutFormToken() { $api_key = $this->config->get('payment_iyzico_api_key'); $secret_key = $this->config->get('payment_iyzico_secret_key'); - $payment_source = "OPENCART-4x-".$this->module_version."|".$this->module_product_name."|".$this->config->get('payment_iyzico_design'); + $payment_source = "OPENCART-4x-".$this->module_version."|".$this->module_product_name; $user_create_date = $this->model_extension_iyzico_payment_iyzico->getUserCreateDate($user_id); @@ -110,7 +107,7 @@ public function getCheckoutFormToken() { $iyzico->basketId = $order_id; $iyzico->paymentGroup = "PRODUCT"; $iyzico->forceThreeDS = "0"; - $iyzico->callbackUrl = $this->url->link('extension/iyzico/payment/iyzico|getCallBack', '', true); + $iyzico->callbackUrl = $this->url->link('extension/iyzico/payment/iyzico%7CgetCallBack', '', true); $iyzico->cardUserKey = $this->model_extension_iyzico_payment_iyzico->findUserCardKey($customer_id,$api_key); $iyzico->paymentSource = $payment_source; @@ -189,18 +186,16 @@ public function getCheckoutFormToken() { $form_response = $this->model_extension_iyzico_payment_iyzico->createFormInitializeRequest($iyzico_json,$authorization_data); - $this->response->addHeader('Content-Type: application/json'); - $this->response->setOutput(json_encode($form_response)); + + $data['iyzico_redirect'] = $form_response->paymentPageUrl; + return $this->load->view('extension/iyzico/payment/iyzico_form',$data); + } public function getCallBack($webhook = null, $webhookPaymentConversationId = null ,$webhookToken = null) { - if(!isset($webhook) or !isset($webhookPaymentConversationId) or !isset($webhookToken)) - { - exit; - } try { @@ -254,6 +249,7 @@ public function getCallBack($webhook = null, $webhookPaymentConversationId = nul $request_response = $this->model_extension_iyzico_payment_iyzico->createFormInitializeDetailRequest($iyzico_json,$authorization_data); + if ($webhook == "webhook" && $webhookIyziEventType != 'CREDIT_PAYMENT_AUTH' && $request_response->status == 'failure'){ return $this->webhookHttpResponse("errorCode: ".$request_response->errorCode ." - " . $request_response->errorMessage, 404); } @@ -319,7 +315,7 @@ public function getCallBack($webhook = null, $webhookPaymentConversationId = nul $orderMessage = 'iyzico Banka Havale/EFT ödemesi bekleniyor.'; $this->setWebhookText(0); $this->model_checkout_order->addHistory($iyzico_local_order->order_id, $this->config->get('payment_iyzico_order_status'), $orderMessage); - return $this->response->redirect($this->url->link('extension/iyzico/payment/iyzico|successpage')); + return $this->response->redirect($this->url->link('extension/iyzico/payment/iyzico%7Csuccesspage')); } if($webhook != 'webhook' && $request_response->paymentStatus == 'PENDING_CREDIT' && $request_response->status == 'success') @@ -327,15 +323,13 @@ public function getCallBack($webhook = null, $webhookPaymentConversationId = nul $orderMessage = 'Alışveriş kredisi işlemi başlatıldı.'; $this->setWebhookText(1); $this->model_checkout_order->addHistory($iyzico_local_order->order_id, 1,$orderMessage); - return $this->response->redirect($this->url->link('extension/iyzico/payment/iyzico|successpage')); + return $this->response->redirect($this->url->link('extension/iyzico/payment/iyzico%7Csuccesspage')); } $this->setWebhookText(0); if($request_response->paymentStatus != 'SUCCESS' || $request_response->status != 'success' || $order_id != $request_response->basketId ) { - - /* Redirect Error */ - $errorMessage = isset($request_response->errorMessage) ? $request_response->errorMessage : $this->language->get('payment_failed'); - throw new \Exception($errorMessage); + echo '
iyzico
- {% if form_type == 'onepage' %} -{{ onepage_desc }}
- {% endif %} - -