diff --git a/includes/api/api.php b/includes/api/api.php index 5901531a..782e87cb 100644 --- a/includes/api/api.php +++ b/includes/api/api.php @@ -179,7 +179,7 @@ function initCartCommon() } -add_action('setup_extra_setting_fields', 'addMagicCheckoutSettingFields'); +add_action('setup_extra_setting_fields_1cc', 'addMagicCheckoutSettingFields'); function addMagicCheckoutSettingFields(&$defaultFormFields) { diff --git a/includes/api/cart.php b/includes/api/cart.php index 421d8cba..3e54e54d 100644 --- a/includes/api/cart.php +++ b/includes/api/cart.php @@ -250,6 +250,22 @@ function cartResponse($couponCode){ $prefillData = getPrefillCartData($couponCode); $response['prefill'] = $prefillData; + $response['config'] = $razorpay->getDisplayConfig(); + + // Every hour post installation check + $getPostInstallationFlag = get_option('rzp_post_installation_update_at'); + if (empty($getPostInstallationFlag) == false) + { + if ($getPostInstallationFlag + 3600 < time()) + { + $razorpay->autoPostInstallationCheck(); + } + } + else + { + $razorpay->autoPostInstallationCheck(); + } + $response['enable_ga_analytics'] = get_option('woocommerce_razorpay_settings')['enable_1cc_ga_analytics'] === 'yes' ? true : false; $response['enable_fb_analytics'] = get_option('woocommerce_razorpay_settings')['enable_1cc_fb_analytics'] === 'yes' ? true : false; diff --git a/includes/plugin-instrumentation.php b/includes/plugin-instrumentation.php index 2f36f3f5..7b60f75b 100644 --- a/includes/plugin-instrumentation.php +++ b/includes/plugin-instrumentation.php @@ -275,7 +275,11 @@ public function getDefaultProperties($timestamp = true) } $paymentSettings = get_option('woocommerce_razorpay_settings'); -if ($paymentSettings !== false) +if (($paymentSettings !== false) and + (isset($paymentSettings['key_id']) === true) and + (empty($paymentSettings['key_id']) === false) and + (isset($paymentSettings['key_secret']) === true) and + (empty($paymentSettings['key_secret']) === false)) { $api = new Api($paymentSettings['key_id'], $paymentSettings['key_secret']); diff --git a/includes/razorpay-affordability-widget.php b/includes/razorpay-affordability-widget.php index 2f8cbd94..bca72007 100644 --- a/includes/razorpay-affordability-widget.php +++ b/includes/razorpay-affordability-widget.php @@ -526,37 +526,41 @@ function updateAffordabilityWidgetSettings() woocommerce_update_options(getAffordabilityWidgetSettings()); try { - if (isset($_POST['woocommerce_razorpay_key_id']) and - empty($_POST['woocommerce_razorpay_key_id']) === false and - isset($_POST['woocommerce_razorpay_key_secret']) and - empty($_POST['woocommerce_razorpay_key_secret']) === false) - { - $api = new Api($_POST['woocommerce_razorpay_key_id'], $_POST['woocommerce_razorpay_key_secret']); - } - else + $checkout360status = (get_option('rzp_checkout360_status') === 'yes') ? true : false; + + if ($checkout360status === false) { - $api = new Api(get_option('woocommerce_razorpay_settings')['key_id'],get_option('woocommerce_razorpay_settings')['key_secret']); - } + if (isset($_POST['woocommerce_razorpay_key_id']) and + empty($_POST['woocommerce_razorpay_key_id']) === false and + isset($_POST['woocommerce_razorpay_key_secret']) and + empty($_POST['woocommerce_razorpay_key_secret']) === false) + { + $api = new Api($_POST['woocommerce_razorpay_key_id'], $_POST['woocommerce_razorpay_key_secret']); + } + else + { + $api = new Api(get_option('woocommerce_razorpay_settings')['key_id'],get_option('woocommerce_razorpay_settings')['key_secret']); + } - $merchantPreferences = $api->request->request('GET', 'accounts/me/features'); + $merchantPreferences = $api->request->request('GET', 'accounts/me/features'); - if (isset($merchantPreferences) === false or - isset($merchantPreferences['assigned_features']) === false) - { - throw new Exception("Error in Api call."); - } + if (isset($merchantPreferences) === false or + isset($merchantPreferences['assigned_features']) === false) + { + throw new Exception("Error in Api call."); + } - update_option('rzp_afd_enable', 'no'); - foreach ($merchantPreferences['assigned_features'] as $preference) - { - if ($preference['name'] === 'affordability_widget' or - $preference['name'] === 'affordability_widget_set') + update_option('rzp_afd_enable', 'no'); + foreach ($merchantPreferences['assigned_features'] as $preference) { - update_option('rzp_afd_enable', 'yes'); - break; + if ($preference['name'] === 'affordability_widget' or + $preference['name'] === 'affordability_widget_set') + { + update_option('rzp_afd_enable', 'yes'); + break; + } } } - } catch (\Exception $e) { diff --git a/includes/razorpay-webhook.php b/includes/razorpay-webhook.php index ce969c48..68a169d2 100644 --- a/includes/razorpay-webhook.php +++ b/includes/razorpay-webhook.php @@ -96,6 +96,13 @@ public function process() return; } + // Skip the webhook if not the valid data and event + if ($this->shouldConsumeWebhook($data) === false) { + + rzpLogDebug("Invalid webhook trigger: " . json_encode($data)); + return; + } + if (empty($data['event']) === false) { $orderId = $data['payload']['payment']['entity']['notes']['woocommerce_order_number']; @@ -107,13 +114,6 @@ public function process() $razorpayOrderId = ($data['event'] == self::SUBSCRIPTION_CHARGED) ? $razorpayOrderId : "No payment id in subscription event"; } - - // Skip the webhook if not the valid data and event - if ($this->shouldConsumeWebhook($data) === false) { - rzpLogInfo("Woocommerce orderId: $orderId webhook process exited in shouldConsumeWebhook function"); - - return; - } if (isset($_SERVER['HTTP_X_RAZORPAY_SIGNATURE']) === true) { $razorpayWebhookSecret = (empty($this->razorpay->getSetting('webhook_secret')) === false) ? $this->razorpay->getSetting('webhook_secret') : get_option('webhook_secret'); diff --git a/readme.txt b/readme.txt index 974a8327..26b2c4e0 100644 --- a/readme.txt +++ b/readme.txt @@ -3,7 +3,7 @@ Contributors: razorpay Tags: razorpay, payments, india, woocommerce, curlec, malaysia, ecommerce, international, cross border Requires at least: 3.9.2 Tested up to: 6.6 -Stable tag: 4.6.9 +Stable tag: 4.7.0 Requires PHP: 7.0 License: GPLv2 or later License URI: http://www.gnu.org/licenses/gpl-2.0.html @@ -69,6 +69,10 @@ Razorpay is available for Store Owners and Merchants in == Changelog == += 4.7.0 = +* Fixed validation for instrumentation. +* Added section restriction to API call. + = 4.6.9 = * Added checkout.js script to checkout page. diff --git a/woo-razorpay.php b/woo-razorpay.php index fe1e36db..e38ff544 100644 --- a/woo-razorpay.php +++ b/woo-razorpay.php @@ -3,8 +3,8 @@ * Plugin Name: 1 Razorpay: Signup for FREE PG * Plugin URI: https://razorpay.com * Description: Razorpay Payment Gateway Integration for WooCommerce.Razorpay Welcome Back Offer: New to Razorpay? Sign up to enjoy FREE payments* of INR 2 lakh till March 31st! Transact before January 10th to grab the offer. - * Version: 4.6.9 - * Stable tag: 4.6.9 + * Version: 4.7.0 + * Stable tag: 4.7.0 * Author: Team Razorpay * WC tested up to: 9.1.2 * Author URI: https://razorpay.com @@ -248,6 +248,193 @@ public function getCustomOrdercreationMessage($thank_you_title, $order) return $message; } + public function generate_multicheckbox_html($key, $data) + { + $c360FieldMapping = [ + 'enable_magic_checkout_cart_page' => 'enable_1cc', + 'enable_magic_checkout_test_mode' => 'enable_1cc_test_mode', + 'enable_magic_checkout_buy_now' => 'enable_1cc_pdp_checkout', + 'enable_magic_checkout_mini_cart' => 'enable_1cc_mini_cart_checkout', + 'enable_cod_intelligence' => 'rzp_cod_intelligence_enable', + 'enable_razorpay_trusted_business_widget' => 'rzp_rtb_enable', + 'enable_razorpay_affordability_widget' => 'rzp_afd_enable' + ]; + + $field = $this->get_field_key($key); + + $defaults = array( + 'title' => '', + 'type' => 'multicheckbox', + 'description' => '', + 'desc_tip' => false, + 'options' => array(), + ); + + $data = wp_parse_args( $data, $defaults ); + + ob_start(); + ?> + + + + + +
+ $optionLabelDesc) : ?> + plugin_id . $this->id . '_' . 'enable_magic_checkout_group') + { + $option_checked = $this->getSetting($c360FieldMapping[$optionKey]); + } + elseif (isset($c360FieldMapping[$optionKey])) + { + $option_checked = get_option($c360FieldMapping[$optionKey]); + } + ?> +
+

+ +
+ + + $widgetEnabled, + ]; + + $rtbEnable = $this->rzpPostInstallationCall('save', $data); + + // Experiment returned false + if (isset($rtbEnable['checkout360_status']) === true and + $rtbEnable['checkout360_status'] == false) + { + update_option('rzp_checkout360_status', 'no'); + return; + } + + if ((empty($rtbEnable) === false) and + (isset($rtbEnable['rtb_eligibility']) === true)) + { + if ($rtbEnable['rtb_eligibility'] === true) + { + $value = ($action === 'activate') ? 'yes' : 'no'; + update_option('rzp_rtb_enable', $value); + } + elseif ($rtbEnable['rtb_eligibility'] === false) + { + echo "
+

We are sorry you are not Eligible to opt RTB.

+
"; + } + } + } + + public function process_admin_options() + { + $data = parent::get_post_data(); + $saved = parent::process_admin_options(); + + if (get_option('rzp_checkout360_status') === 'yes') + { + $optionKey = parent::get_option_key(); + $savedData = get_option($optionKey); + + // For checkout360 magic settings + $magicC360Mapping = [ + 'enable_magic_checkout_cart_page' => 'enable_1cc', + 'enable_magic_checkout_test_mode' => 'enable_1cc_test_mode', + 'enable_magic_checkout_buy_now' => 'enable_1cc_pdp_checkout', + 'enable_magic_checkout_mini_cart' => 'enable_1cc_mini_cart_checkout' + ]; + + foreach ($magicC360Mapping as $c360Field => $oneCCField) + { + if (isset($data[$this->plugin_id . $this->id . '_' . $c360Field]) === true) + { + $savedData[$oneCCField] = "yes"; + } + elseif (isset($data[$this->plugin_id . $this->id . '_' . $oneCCField]) === false) + { + $savedData[$oneCCField] = "no"; + } + } + + // For other checkout360 settings + $checkout360Settings = [ + 'enable_cod_intelligence' => 'rzp_cod_intelligence_enable', + 'enable_razorpay_trusted_business_widget' => 'rzp_rtb_enable', + 'enable_razorpay_affordability_widget' => 'rzp_afd_enable' + ]; + + foreach ($checkout360Settings as $c360Field => $c360Flag) + { + if ($c360Field === 'enable_razorpay_trusted_business_widget') + { + if ((isset($data[$this->plugin_id . $this->id . '_' . $c360Field]) === true) and + ((empty(get_option('rzp_rtb_enable')) === true) or (get_option('rzp_rtb_enable') === 'no'))) + { + $this->toggleRtbWidget('activate' , true); + } + elseif ((isset($data[$this->plugin_id . $this->id . '_' . $c360Field]) === false) and + (get_option('rzp_rtb_enable') === 'yes')) + { + $this->toggleRtbWidget('deactivate' , false); + } + + } + elseif (isset($data[$this->plugin_id . $this->id . '_' . $c360Field]) === true) + { + update_option($c360Flag, "yes"); + } + elseif (isset($data[$this->plugin_id . $this->id . '_' . $c360Field]) === false) + { + update_option($c360Flag, "no"); + } + } + + return update_option($optionKey, apply_filters('woocommerce_settings_api_sanitized_fields_' . $this->id, $savedData), 'yes'); + } + + return $saved; + } + + public function rzpPostInstallationCall($event, $data = []) + { + try + { + $api = $this->getRazorpayApiInstance(); + $key_id = $this->getSetting('key_id'); + + $postInstallationPayload = [ + "event" => $event, + "mode" => (substr($key_id, 0, 8) === 'rzp_live') ? 'live' : 'test', + "data" => $data + ]; + + $result = $api->request->request('POST', 'app/woocommerce/api/post-installation-workflow', $postInstallationPayload); + + return $result; + } + catch (\Exception $e) + { + rzpLogError($e->getMessage()); + + return ['error' => $e->getMessage()]; + } + } + /** * @param boolean $hooks Whether or not to * setup the hooks on @@ -255,7 +442,6 @@ public function getCustomOrdercreationMessage($thank_you_title, $order) */ public function __construct($hooks = true) { - $this->isHposEnabled = false; // file added in woocommerce v7.1.0, maybe removed later @@ -270,8 +456,9 @@ public function __construct($hooks = true) $is1ccAvailable = false; $isAccCreationAvailable = false; $merchantPreferences = []; + $checkout360Available = get_option('rzp_checkout360_status', ""); - $merchantPreferences = get_transient(self::ONE_CC_MERCHANT_PREF); + $merchantPreferences = get_transient(self::ONE_CC_MERCHANT_PREF . "_" . $checkout360Available); // Load preference API call only for administrative interface + razorpay payment settings page. if (current_user_can('administrator') && @@ -287,7 +474,7 @@ public function __construct($hooks = true) $api = $this->getRazorpayApiInstance(); $merchantPreferences = $api->request->request('GET', 'merchant/1cc_preferences'); - set_transient( self::ONE_CC_MERCHANT_PREF, $merchantPreferences, 7200 ); + set_transient( self::ONE_CC_MERCHANT_PREF . "_" . $checkout360Available, $merchantPreferences, 7200 ); } catch (\Exception $e) { rzpLogError($e->getMessage()); @@ -298,11 +485,30 @@ public function __construct($hooks = true) if (!empty($merchantPreferences['features']['one_click_checkout'])) { $is1ccAvailable = true; } + else + { + $optionKey = parent::get_option_key(); + $razorpay_settings = get_option($optionKey); + + $razorpay_settings['enable_1cc'] = 'no'; + $razorpay_settings['enable_1cc_mini_cart_checkout'] = 'no'; + $razorpay_settings['enable_1cc_pdp_checkout'] = 'no'; + update_option($optionKey, apply_filters('woocommerce_settings_api_sanitized_fields_' . $this->id, $razorpay_settings), 'yes'); + } if (!empty($merchantPreferences['features']['one_cc_store_account'])) { $isAccCreationAvailable = true; } + if (empty($checkout360Available) === true) + { + $response = $this->rzpPostInstallationCall('install'); + if (isset($response['error']) === false) + { + $checkout360Available = ($response['checkout360_status'] === true) ? 'yes' : 'no'; + update_option('rzp_checkout360_status', $checkout360Available); + } + } if ($is1ccAvailable) { $this->visibleSettings = array_merge($this->visibleSettings, array( @@ -323,7 +529,32 @@ public function __construct($hooks = true) '1cc_account_creation', )); } + } + if ($checkout360Available === "yes") + { + //remove 1cc fields + $magicSettingsToRemove = [ + 'enable_1cc', + 'enable_1cc_test_mode', + 'enable_1cc_pdp_checkout', + 'enable_1cc_mini_cart_checkout', + '1cc_min_cart_amount', + '1cc_min_COD_slab_amount', + '1cc_max_COD_slab_amount', + ]; + $this->visibleSettings = array_diff($this->visibleSettings, $magicSettingsToRemove); + + //add checkout 360 fields + $checkout360VisibleFields = [ + 'checkout360_header', + 'checkout360_subheader', + 'configure_checkout360', + 'enable_magic_checkout_group', + 'enable_cod_configurations_group', + 'enhance_your_checkout_group', + ]; + $this->visibleSettings = array_merge($this->visibleSettings, $checkout360VisibleFields); } $this->init_form_fields(); @@ -431,8 +662,84 @@ public function init_form_fields() ), ); + $checkout360Settings = array( + 'checkout360_header' => array( + 'title' => __('Upgrade to Razorpay Checkout360'), + 'type' => 'title', + ), + 'checkout360_subheader' => array( + 'title' => '

' . __('Advanced COD | Address Pre-Fills | Smart Coupons | COD Intelligence | Trust and Affordability').'

', + 'type' => 'title', + ), + 'configure_checkout360' => array( + 'title' => '' . __('Configure Checkout360 Settings').'', + 'type' => 'title', + ), + 'enable_magic_checkout_group' => array( + 'title' => __('Enable Magic Checkout'), + 'type' => 'multicheckbox', + 'label' => __('Enable Magic Checkout', $this->id), + 'options' => array( + 'enable_magic_checkout_cart_page' => array( + 'label' => __('Enable Magic Checkout', $this->id), + 'description' => __('Magic Checkout will launch when customer checkout with their cart', $this->id) + ), + 'enable_magic_checkout_buy_now' => array( + 'label' => __('Enable Magic Checkout On Buy Now Button', $this->id), + 'description' => __('Magic Checkout will launch when customer clicks on Buy Now on products page', $this->id) + ), + 'enable_magic_checkout_mini_cart' => array( + 'label' => __('Enable Magic Checkout On Mini Cart', $this->id), + 'description' => __('Magic Checkout will launch when checkout from mini cart', $this->id) + ), + 'enable_magic_checkout_test_mode' => array( + 'label' => __('Enable Magic Checkout On Test Mode', $this->id), + 'description' => __('Only logged in admin users will see Magic Checkout', $this->id) + ) + ) + ), + 'enable_cod_configurations_group' => array( + 'title' => __('Enable COD Intelligence'), + 'type' => 'multicheckbox', + 'options' => array( + 'enable_cod_intelligence' => array( + 'label' => __('Enable COD Intelligence', $this->id), + 'description' => __('Set up rules on Razorpay Dashboard to show/hide and charge for COD orders', $this->id) + ), + 'enable_cod_configuratiopn' => array( + 'label' => __('Set-up smart COD rules & RTO Prediction here', $this->id), + 'description' => __("Use Razorpay's RTO intelligence to block COD for high risk users", $this->id), + 'link' => 'http://dashboard.razorpay.com/app/magic' + ) + ) + ), + 'enhance_your_checkout_group' => array( + 'title' => __('Enhance Your Checkout'), + 'type' => 'multicheckbox', + 'options' => array( + 'enable_razorpay_trusted_business_widget' => array( + 'label' => __('Enable Razorpay Trusted Business Widget', $this->id), + 'description' => __('', $this->id) + ), + 'enable_razorpay_affordability_widget' => array( + 'label' => __('Enable Razorpay Affordability Widget', $this->id), + 'description' => __('', $this->id) + ), + 'enable_giftcards_coupons' => array( + 'label' => __('Set-up gift cards and coupons here', $this->id), + 'description' => __("", $this->id), + 'link' => 'https://dashboard.razorpay.com/app/magic/settings' + ) + ) + ) + ); + do_action_ref_array( 'setup_extra_setting_fields', array( &$defaultFormFields ) ); + $defaultFormFields = array_merge( $defaultFormFields, $checkout360Settings ); + + do_action_ref_array( 'setup_extra_setting_fields_1cc', array( &$defaultFormFields ) ); + foreach ($defaultFormFields as $key => $value) { if (in_array($key, $this->visibleSettings, true)) @@ -442,10 +749,16 @@ public function init_form_fields() } //Affordability Widget Code - if (is_admin()) + $currentSection = isset($_GET["section"]) ? sanitize_text_field($_GET["section"]) : ""; + + if (is_admin() and + (($currentSection === "razorpay") or + ($currentSection === "affordability-widget"))) { try { + $checkout360status = (get_option('rzp_checkout360_status') === 'yes') ? true : false; + if (isset($_POST['woocommerce_razorpay_key_id']) and empty($_POST['woocommerce_razorpay_key_id']) === false and isset($_POST['woocommerce_razorpay_key_secret']) and @@ -460,6 +773,11 @@ public function init_form_fields() $api = $this->getRazorpayApiInstance(); } + if (empty($key_id) === true) + { + return; + } + $merchantPreferences = $api->request->request('GET', 'accounts/me/features'); if (isset($merchantPreferences) === false or isset($merchantPreferences['assigned_features']) === false) @@ -467,8 +785,11 @@ public function init_form_fields() throw new Exception("Error in Api call."); } - update_option('rzp_afd_enable', 'no'); - update_option('rzp_rtb_enable', 'no'); + if ($checkout360status === false) + { + update_option('rzp_afd_enable', 'no'); + update_option('rzp_rtb_enable', 'no'); + } foreach ($merchantPreferences['assigned_features'] as $preference) { @@ -478,33 +799,39 @@ public function init_form_fields() add_action('woocommerce_sections_checkout', 'addSubSection'); add_action('woocommerce_settings_tabs_checkout', 'displayAffordabilityWidgetSettings'); add_action('woocommerce_update_options_checkout', 'updateAffordabilityWidgetSettings'); - update_option('rzp_afd_enable', 'yes'); + if ($checkout360status === false) + { + update_option('rzp_afd_enable', 'yes'); + } break; } } - $rtbActivationStatus = $api->request->request('GET', 'rtb?key_id=' . $key_id); - - if (isset($rtbActivationStatus['widget_enabled']) and - $rtbActivationStatus['widget_enabled'] === true) + if ($checkout360status === false) { - $this->form_fields['rtb_widget_title'] = array( - 'title' => '' . __('Razorpay Trusted Business'). '', - 'type' => 'title' - ); - - $this->form_fields['enable_rtb_widget'] = array( - 'title' => __('RTB Widget Enable/Disable'), - 'type' => 'checkbox', - 'desc' => __('Enable RTB Widget?'), - 'default' => 'no', - 'id' => 'rzp_rtb_enable' - ); - update_option('rzp_rtb_enable', 'yes'); - } + $rtbActivationStatus = $api->request->request('GET', 'rtb?key_id=' . $key_id); - update_option('rzp_afd_feature_checked', 'yes'); - update_option('rzp_rtb_feature_checked', 'yes'); + if (isset($rtbActivationStatus['widget_enabled']) and + $rtbActivationStatus['widget_enabled'] === true) + { + $this->form_fields['rtb_widget_title'] = array( + 'title' => '' . __('Razorpay Trusted Business'). '', + 'type' => 'title' + ); + + $this->form_fields['enable_rtb_widget'] = array( + 'title' => __('RTB Widget Enable/Disable'), + 'type' => 'checkbox', + 'desc' => __('Enable RTB Widget?'), + 'default' => 'no', + 'id' => 'rzp_rtb_enable' + ); + update_option('rzp_rtb_enable', 'yes'); + } + + update_option('rzp_afd_feature_checked', 'yes'); + update_option('rzp_rtb_feature_checked', 'yes'); + } } catch (\Exception $e) { @@ -535,6 +862,52 @@ protected function triggerValidationInstrumentation($data) $trackObject->rzpTrackDataLake('formfield.validation.error', $properties); } + public function autoPostInstallationCheck() + { + try + { + $response = $this->rzpPostInstallationCall('install'); + + $checkout360Available = ((isset($response['checkout360_status']) === true) and ($response['checkout360_status'] === true)) ? 'yes' : 'no'; + + update_option('rzp_checkout360_status', $checkout360Available); + update_option('rzp_post_installation_update_at', time()); + + // remove all checkout360 settings + if ((isset($response['merchant_status']) === true) and + ($response['merchant_status'] === 'existing_checkout360_merchant') and + ($checkout360Available === 'no')) + { + $checkout360Fields = [ + 'enable_1cc', + 'enable_1cc_test_mode', + 'enable_1cc_pdp_checkout', + 'enable_1cc_mini_cart_checkout', + 'rzp_cod_intelligence_enable' + ]; + $optionKey = parent::get_option_key(); + $savedData = get_option($optionKey); + + foreach ($checkout360Fields as $field) + { + if ($field === 'rzp_cod_intelligence_enable') + { + delete_option($field); + } + else + { + $savedData[$field] = 'no'; + } + } + update_option($optionKey, apply_filters('woocommerce_settings_api_sanitized_fields_' . $this->id, $savedData), 'yes'); + } + } + catch (\Exception $e) + { + rzpLogError($e->getMessage()); + } + } + public function autoEnableWebhook() { $webhookExist = false; @@ -718,7 +1091,7 @@ public function newTrackPluginInstrumentation($key, $secret) public function enqueue_checkout_js_script_on_checkout() { - if (is_checkout()) + if (is_checkout()) { wp_enqueue_script( 'razorpay-checkout-js', @@ -1131,6 +1504,32 @@ public function generate_razorpay_form($orderId) return $html; } + public function getDisplayConfig() + { + $config = [ + 'display' => [ + 'hide' => [ + [ + 'method' => 'cod' + ] + ] + ] + ]; + + $checkout360_status = get_option('rzp_checkout360_status'); + $rzp_cod_intelligence_enable = get_option('rzp_cod_intelligence_enable'); + + if ((isset($checkout360_status) === true) and + ($checkout360_status === 'yes') and + (empty($rzp_cod_intelligence_enable) === false) and + ($rzp_cod_intelligence_enable === 'yes')) + { + unset($config['display']['hide']); + } + + return $config; + } + /** * default parameters passed to checkout * @param WC_Order $order WC Order @@ -2935,11 +3334,13 @@ function razorpay_woo_plugin_links($links) function trigger_affordability_widget() { + $checkout360status = (get_option('rzp_checkout360_status') === 'yes') ? true : false; if (empty(get_option('rzp_afd_enable')) === false and get_option('rzp_afd_enable') === 'yes') { - if (empty(get_option('rzp_afd_feature_checked')) === true or - get_option('rzp_afd_feature_checked') === 'no') + if ((empty(get_option('rzp_afd_feature_checked')) === true or + get_option('rzp_afd_feature_checked') === 'no' ) and + $checkout360status === false) { try { @@ -2981,8 +3382,11 @@ function trigger_affordability_widget() function trigger_rtb_widget() { - if (empty(get_option('rzp_rtb_feature_checked')) === true or - get_option('rzp_rtb_feature_checked') === 'no') + $checkout360status = (get_option('rzp_checkout360_status') === 'yes') ? true : false; + + if ((empty(get_option('rzp_rtb_feature_checked')) === true or + get_option('rzp_rtb_feature_checked') === 'no') and + $checkout360status === false) { try { @@ -3007,11 +3411,15 @@ function trigger_rtb_widget() } } - if (empty(get_option('woocommerce_razorpay_settings')) === false and + if ((empty(get_option('woocommerce_razorpay_settings')) === false and isset(get_option('woocommerce_razorpay_settings')['enable_rtb_widget']) === true and get_option('woocommerce_razorpay_settings')['enable_rtb_widget'] === 'yes' and empty(get_option('rzp_rtb_enable')) === false and - get_option('rzp_rtb_enable') === 'yes') + get_option('rzp_rtb_enable') === 'yes') or + $checkout360status === true and + empty(get_option('rzp_rtb_enable')) === false and + get_option('rzp_rtb_enable') === 'yes' + ) { $key_id = get_option('woocommerce_razorpay_settings')['key_id']; echo '