KGRKJGETMRETU895U-589TY5MIGM5JGB5SDFESFREWTGR54TY
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 :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home1/andertr9/public_html/wp-content/plugins/fooboxV2/includes/foolic_validation.php
<?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'
			);
		}

	}
}

Anon7 - 2021