Server : Apache System : Linux cs317.bluehost.com 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64 User : andertr9 ( 1047) PHP Version : 8.2.18 Disable Function : NONE Directory : /home1/andertr9/public_html/wp-content/plugins/fooboxV2/includes/ |
Upload File : |
<?php /** * FooLicensing License Key Validation * * @author Brad Vincent * @version 1.6 */ if (!class_exists('foolic_validation_v1_6')) { class foolic_validation_v1_6 { protected $plugin_validation_url; protected $plugin_slug; protected $license_key; protected $license_valid; protected $license_expires; function __construct($plugin_validation_url, $plugin_slug) { $this->plugin_validation_url = $plugin_validation_url; $this->plugin_slug = $plugin_slug; if (is_admin()) { //output the needed css and js add_action('admin_enqueue_scripts', array(&$this, 'include_css') ); add_action('admin_footer', array(&$this, 'include_js') ); //wire up the ajax callbacks add_action('wp_ajax_foolic_validate_license-'.$this->plugin_slug, array($this, 'ajax_validate_license')); add_action('wp_ajax_foolic_license_set_validity-'.$this->plugin_slug, array($this, 'ajax_license_set_validity')); add_action('wp_ajax_foolic_license_store_error-'.$this->plugin_slug, array($this, 'ajax_license_store_error')); add_action('wp_ajax_foolic_clear_license-'.$this->plugin_slug, array($this, 'ajax_clear_license')); //output the validation HTML add_filter('foolic_get_validation_data-'.$this->plugin_slug, array($this, 'get_validation_data')); } } /** * Securely get the option, sanitize and return * * @param $key string The key of the option we want to get * * @return string The option value */ function get_option_secure($key) { $option = get_site_option($key); return htmlspecialchars($option); } function validate($license = false) { if ($license === false) { $license = apply_filters( $this->plugin_slug . '_foolic_licensekey', $this->get_option_secure( $this->plugin_slug . '_licensekey' ) ); } $valid = !empty($license) ? apply_filters( $this->plugin_slug . '_foolic_valid', $this->get_option_secure( $this->plugin_slug . '_valid') ) : false; $expires = apply_filters( $this->plugin_slug . '_foolic_expires', $this->get_option_secure( $this->plugin_slug . '_valid_expires') ); if (!empty($expires) && $expires !== 'never') { if (strtotime($expires) < strtotime(date("Y-m-d"))) { $valid = 'expired'; //it has expired! } } //if it is not valid AND we have a license to check, then try to validate from the server 1 last time if ( $valid !== true && !empty($license) ) { $check = get_transient( $this->plugin_slug . '_valid_check' ); if ( empty( $check ) ) { $response = $this->remote_validate( $license, true ); if ( !empty($response->response) ) { //only save the option if return good response from server update_site_option( $this->plugin_slug . '_licensekey', $license ); $valid = $response->response->valid; $expires = $response->expires; if (!empty($expires) && $expires !== 'never') { if (strtotime($expires) < strtotime(date("Y-m-d"))) { $valid = 'expired'; //it has expired! } } update_site_option($this->plugin_slug . '_valid', $valid); if (!empty($expires)) { update_site_option($this->plugin_slug . '_valid_expires', $expires); } set_transient( $this->plugin_slug . '_valid_check', true, 60 * 60 * 24 ); //dont check again for 1 day } else { set_transient( $this->plugin_slug . '_valid_check', true, 5 * 60 * 60 * 24 ); //dont check again for 5 days } } } $this->license_key = $license; $this->license_valid = $valid; $this->license_expires = $expires; return array( 'slug' => $this->plugin_slug, 'license' => $this->license_key, 'valid' => $this->license_valid, 'expires' => $this->license_expires ); } function get_validation_data() { $this->validate(); $input_id = $this->plugin_slug . '_licensekey'; $input_class = $this->license_valid === '1' ? ' foolic-valid' : ' foolic-invalid'; $input = '<input class="foolic-input foolic-input-' . $this->plugin_slug . '' . $input_class . '" type="password" id="' . $input_id . '" name="' . $this->plugin_slug . '[license]" value="' . $this->license_key . '" />'; $validate_button = '<input class="foolic-check foolic-check-' . $this->plugin_slug . '" type="button" name="foolic-check-' . $this->plugin_slug . '" value="' . __('Validate', $this->plugin_slug) . '" />'; $clear_button = '<input class="foolic-clear foolic-clear-' . $this->plugin_slug . '" type="button" name="foolic-clear-' . $this->plugin_slug . '" value="' . __('Clear', $this->plugin_slug) . '" />'; $nonce = '<span style="display:none" class="foolic-nonce-' . $this->plugin_slug . '">' . wp_create_nonce($this->plugin_slug . '_foolic-ajax-nonce') . '</span>'; if ($this->license_valid == 'expired') { $message = '<div class="foolic-error foolic-message-' . $this->plugin_slug . '">' . __('The license key has expired!', $this->plugin_slug) . '</div>'; } else { $message = '<div style="display:none" class="foolic-message foolic-message-' . $this->plugin_slug . '"></div>'; } return array( 'slug' => $this->plugin_slug, 'license' => $this->license_key, 'valid' => $this->license_valid, 'expires' => $this->license_expires, 'input' => $input, 'button' => $validate_button, 'clear_button' => $clear_button, 'nonce' => $nonce, 'message' => $message, 'html' => '<div class="foolic-validation-' . $this->plugin_slug . '">' . $input . $validate_button . $clear_button . $nonce . $message . '</div>' ); } function include_css($hook_suffix) { $screen = get_current_screen(); $include = apply_filters('foolic_validation_include_css-'.$this->plugin_slug, $screen); //if the filter was not overridden then add the css and js on the plugin settings page if ($include === $screen) $include = ($hook_suffix === $this->plugin_slug || $hook_suffix === 'settings_page_' . $this->plugin_slug); if (!$include) return; ?> <style type="text/css"> .foolic-check, .foolic-clear { cursor: pointer; } input.foolic-input.foolic-loading { background-image: url(); background-repeat: no-repeat; background-position: right center; } input.foolic-input.foolic-valid { background-image: url(); background-repeat: no-repeat; background-position: right center; padding-right: 3px; } input.foolic-input.foolic-invalid { background-image: url(); background-repeat: no-repeat; background-position: right center; padding-right: 3px; } .foolic-message { display: table-cell; background-color: lightYellow; border: solid 1px #E6DB55; padding: 3px 10px; } .foolic-error { display: table-cell; color: #c00; font-weight:bold; padding: 3px 10px; } </style> <?php } function include_js() { $screen = get_current_screen(); $include = apply_filters('foolic_validation_include_js-'.$this->plugin_slug, $screen); //if the filter was not overridden then add the js on the plugin settings page if ($include === $screen) $include = (array_key_exists('page', $_GET) && $_GET['page'] == $this->plugin_slug); if (!$include) return; $namespace = 'foolic_' . str_replace('-', '_', $this->plugin_slug); ?> <script type="text/javascript"> (function( <?php echo $namespace; ?>, $, undefined ) { <?php echo $namespace; ?>.init = function() { $('.foolic-validation-<?php echo $this->plugin_slug; ?> input.foolic-check').click(function (e) { e.preventDefault(); var $this = $(this); var $input = $this.siblings('.foolic-input-<?php echo $this->plugin_slug; ?>'); if ($input.val().length == 0) { alert('<?php echo __('Please enter a license key', $this->plugin_slug); ?>'); } else { <?php echo $namespace; ?>.send_request($input, 'foolic_validate_license'); } }); $('.foolic-validation-<?php echo $this->plugin_slug; ?> input.foolic-clear').click(function (e) { e.preventDefault(); var $this = $(this), $input = $this.siblings('.foolic-input-<?php echo $this->plugin_slug; ?>'); $input.val(''); <?php echo $namespace; ?>.send_request($input, 'foolic_clear_license', false); }); }; <?php echo $namespace; ?>.send_request = function($input, action, setValidity) { if (setValidity === undefined) setValidity = true; var $message = $input.siblings('.foolic-message-<?php echo $this->plugin_slug; ?>'); var nonce = $input.siblings('.foolic-nonce-<?php echo $this->plugin_slug; ?>').text(); $input.removeClass('foolic-valid foolic-invalid').addClass('foolic-loading'); $message.hide().removeClass('foolic-message foolic-error'); var data = { action: action + '-<?php echo $this->plugin_slug; ?>', license: $input.val(), nonce: nonce, input: $input.attr('name') }; $.ajax({ url: ajaxurl, cache: false, type: 'POST', data: data, dataType: "json", success: function (data) { $input.removeClass('foolic-loading'); var message = ''; if (data.license_message) { message = data.license_message; } message += '<strong style="color:' + data.response.color + '">' + data.response.message + '</strong>'; if (data.validation_message) message += '<div>' + data.validation_message + '</div>'; $message.html(message).show(); if ( setValidity ) { $input.addClass(data.response.valid ? 'foolic-valid' : 'foolic-invalid'); <?php echo $namespace; ?>. set_validity(data.response.valid, data.expires, nonce); if (data.response.valid) { $('.foolic-admin-notice-<?php echo $this->plugin_slug; ?>').remove(); } } }, error: function (a, b, c) { $message.html('Something went wrong when trying to validate your license. The error was : ' + a.responseText).show(); $input.removeClass('foolic-loading'); <?php echo $namespace; ?>.store_validation_error(a.responseText, nonce); } }); } <?php echo $namespace; ?>.store_validation_error = function(response, nonce) { if (response) { var data = { action: 'foolic_license_store_error-<?php echo $this->plugin_slug; ?>', response: response, nonce: nonce }; $.ajax({ url: ajaxurl, cache: false, type: 'POST', data: data }); } } <?php echo $namespace; ?>.set_validity = function(valid, expires, nonce) { var data = { action: 'foolic_license_set_validity-<?php echo $this->plugin_slug; ?>', valid: valid ? 'valid' : 'invalid', expires : expires, nonce: nonce }; $.ajax({ url: ajaxurl, cache: false, type: 'POST', data: data }); } }( window.<?php echo $namespace; ?> = window.<?php echo $namespace; ?> || {}, jQuery )); jQuery(function($) { <?php echo $namespace; ?>.init(); }); </script> <?php } function ajax_license_set_validity() { if (wp_verify_nonce($_REQUEST['nonce'], $this->plugin_slug . '_foolic-ajax-nonce')) { $valid = htmlspecialchars($_REQUEST['valid']); $expires = htmlspecialchars($_REQUEST['expires']); update_site_option($this->plugin_slug . '_valid', $valid); if (!empty($expires)) { update_site_option($this->plugin_slug . '_valid_expires', $expires); } } } function ajax_license_store_error() { if (wp_verify_nonce($_REQUEST['nonce'], $this->plugin_slug . '_foolic-ajax-nonce')) { $response = $_REQUEST['response']; update_site_option($this->plugin_slug . '_lasterror', $response); } } function ajax_clear_license() { if (wp_verify_nonce($_REQUEST['nonce'], $this->plugin_slug . '_foolic-ajax-nonce')) { delete_transient( $this->plugin_slug . '_valid_check' ); delete_site_option( $this->plugin_slug . '_licensekey' ); delete_site_option( $this->plugin_slug . '_valid' ); delete_site_option( $this->plugin_slug . '_valid_expires' ); delete_site_option( $this->plugin_slug . '_lasterror' ); //try to clear the setting if (array_key_exists('input', $_REQUEST)) { $setting_name = htmlspecialchars( $_REQUEST['input'] ); if (preg_match('/([^\]]*)\[([^\]]*)\]/', $setting_name, $match)) { $option_name = $match[1]; $option_key = $match[2]; $option = get_site_option($option_name); if ( is_array($option) ) { $option[$option_key] = ''; update_site_option($option_name, $option); } else { delete_site_option($option_name); add_site_option($option_name, array($option_key => '')); } } } $details = array( 'response' => array( 'valid' => false, 'message' => __( 'The license information has been cleared', $this->plugin_slug ), 'color' => '#000', 'error' => false ) ); header('Content-type: application/json'); echo json_encode($details); die; } else { $this->output_json_error(__('The clear request was invalid', $this->plugin_slug), __('The clear NONCE could not be validated!', $this->plugin_slug)); } } function ajax_validate_license() { if (wp_verify_nonce($_REQUEST['nonce'], $this->plugin_slug . '_foolic-ajax-nonce')) { delete_transient( $this->plugin_slug . '_valid_check' ); $license = htmlspecialchars( $_REQUEST['license'] ); $response = $this->remote_validate( $license ); if ( is_array( $response ) && array_key_exists( 'error', $response ) && $response['error'] === true ) { //something went down in chinatown! $this->output_json_error( $response['error_friendly_message'], $response['error_message'] ); die; } else { //all good! header('Content-type: application/json'); if ( !empty($response->response) ) { //only save the option if return good response from server update_site_option($this->plugin_slug . '_licensekey', $license); //try to save the setting if (array_key_exists('input', $_REQUEST)) { $setting_name = htmlspecialchars( $_REQUEST['input'] ); if (preg_match('/([^\]]*)\[([^\]]*)\]/', $setting_name, $match)) { $option_name = $match[1]; $option_key = $match[2]; $option = get_site_option($option_name); if (is_array($option)) { $option[$option_key] = $license; update_site_option($option_name, $option); } else { delete_site_option($option_name); add_site_option($option_name, array($option_key => $license)); } } } echo json_encode($response); } die; } } else { $this->output_json_error(__('The validation request was invalid', $this->plugin_slug), __('The validation NONCE could not be validated!', $this->plugin_slug)); } } function remote_validate( $license ) { try { $response_raw = wp_remote_post($this->plugin_validation_url, $this->prepare_validate_request($license)); if (is_wp_error($response_raw)) { $error = $response_raw->get_error_message(); return array( 'error' => true, 'error_friendly_message' => __('An error occurred while trying to validate your license key', $this->plugin_slug), 'error_message' => $error ); } else if (wp_remote_retrieve_response_code($response_raw) != 200) { return array( 'error' => true, 'error_friendly_message' => __('An error occurred while trying to validate your license key', $this->plugin_slug), 'error_message' => sprintf( __('The response code of [%s] was not expected', $this->plugin_slug), wp_remote_retrieve_response_code( $response_raw ) ) ); } else { $response = $response_raw['body']; $response_object = @json_decode( $response ); return $response_object; } } catch (Exception $e) { return array( 'error' => true, 'error_friendly_message' => __('An unexpected error occurred', $this->plugin_slug), 'error_message' => $e->getMessage() ); } } function output_json_error($error, $message) { $details = array( 'response' => array( 'valid' => false, 'message' => $error, 'color' => '#ff0000', 'error' => true ), 'validation_message' => $message ); header('Content-type: application/json'); echo json_encode($details); die; } function prepare_validate_request($license, $action = 'validate') { global $wp_version; return array( 'body' => array( 'action' => $action, 'license' => $license, 'site' => home_url() ), 'timeout' => 45, 'user-agent' => 'WordPress/' . $wp_version . '; FooLicensing' ); } } }