Current File : /home/quantums/theartoflevelingup.net/wp-content/plugins/pixelyoursite/includes/class-pys.php |
<?php
namespace PixelYourSite;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
/**
* PixelYourSite Core class.
*/
final class PYS extends Settings implements Plugin {
private static $_instance;
/** @var $eventsManager EventsManager */
private $eventsManager;
/** @var $registeredPixels array Registered pixels */
private $registeredPixels = array();
/** @var $registeredPlugins array Registered plugins (addons) */
private $registeredPlugins = array();
private $adminPagesSlugs = array();
/**
* @var PYS_Logger
*/
private $logger;
public static function instance() {
if ( is_null( self::$_instance ) ) {
self::$_instance = new self();
}
return self::$_instance;
}
public function getPluginName() {}
public function getPluginFile() {}
public function getPluginVersion() {
return PYS_FREE_VERSION;
}
public function __construct() {
// initialize settings
parent::__construct( 'core' );
add_action( 'admin_init', array( $this, 'updatePlugin' ), 0 );
add_action( 'admin_init', 'PixelYourSite\manageAdminPermissions' );
// Priority 9 used to keep things same as on PRO version
add_action( 'init', array( $this, 'init' ), 9 );
add_action( 'init', array( $this, 'afterInit' ), 11 );
add_action( 'admin_menu', array( $this, 'adminMenu' ) );
add_action( 'admin_enqueue_scripts', array( $this, 'adminEnqueueScripts' ) );
add_action( 'admin_notices', 'PixelYourSite\adminRenderNotices' );
add_action( 'admin_init', array( $this, 'adminProcessRequest' ), 11 );
// run Events Manager
add_action( 'template_redirect', array( $this, 'managePixels' ) );
// track user login event
add_action('wp_login', [$this,'userLogin'], 10, 2);
// track user registrations
add_action( 'user_register', array( $this, 'userRegisterHandler' ) );
// "admin_permission" option custom sanitization function
add_filter( 'pys_core_settings_sanitize_admin_permissions_field', function( $value ) {
// "administrator" always should be allowed
if ( ! is_array( $value ) || ! in_array( 'administrator', $value ) ) {
$value[] = 'administrator';
}
manageAdminPermissions();
return $this->sanitize_multi_select_field( $value );
} );
add_action( 'wp_ajax_pys_get_gdpr_filters_values', array( $this, 'ajaxGetGdprFiltersValues' ) );
add_action( 'wp_ajax_nopriv_pys_get_gdpr_filters_values', array( $this, 'ajaxGetGdprFiltersValues' ) );
/*
* Restore settings after COG plugin
* */
add_action( 'deactivate_pixel-cost-of-goods/pixel-cost-of-goods.php',array($this,"restoreSettingsAfterCog"));
$this->logger = new PYS_Logger();
}
public function init() {
register_post_type( 'pys_event', array(
'public' => false,
'supports' => array( 'title' )
) );
// initialize options
$this->locateOptions(
PYS_FREE_PATH . '/includes/options_fields.json',
PYS_FREE_PATH . '/includes/options_defaults.json'
);
// register pixels and plugins (add-ons)
do_action( 'pys_register_pixels', $this );
do_action( 'pys_register_plugins', $this );
// load dummy Pinterest plugin for admin UI
if ( ! array_key_exists( 'pinterest', $this->registeredPlugins ) ) {
/** @noinspection PhpIncludeInspection */
require_once PYS_FREE_PATH . '/modules/pinterest/pinterest.php';
}
// load dummy Bing plugin for admin UI
if ( ! array_key_exists( 'bing', $this->registeredPlugins ) ) {
/** @noinspection PhpIncludeInspection */
require_once PYS_FREE_PATH . '/modules/bing/bing.php';
}
// maybe disable Facebook for WooCommerce pixel output
if ( isWooCommerceActive()
&& array_key_exists( 'facebook', $this->registeredPixels ) && Facebook()->configured() ) {
add_filter( 'facebook_for_woocommerce_integration_pixel_enabled', '__return_false' );
}
$this->logger->init();
EnrichOrder()->init();
AjaxHookEventManager::instance()->addHooks();
}
public function utmTemplate() {
include 'views/html-utm-templates.php';
}
/**
* Extend options after post types are registered
*/
public function afterInit() {
// add available public custom post types to settings
foreach ( get_post_types( array( 'public' => true, '_builtin' => false ), 'objects' ) as $post_type ) {
// skip product post type when WC is active
if ( isWooCommerceActive() && $post_type->name == 'product' ) {
continue;
}
// skip download post type when EDD is active
if ( isEddActive() && $post_type->name == 'download' ) {
continue;
}
$this->addOption( 'general_event_on_' . $post_type->name . '_enabled', 'checkbox', false );
}
maybeMigrate();
}
/**
* @param Pixel|Settings $pixel
*/
public function registerPixel( &$pixel ) {
$this->registeredPixels[ $pixel->getSlug() ] = $pixel;
}
/**
* Hook
* @param String $user_login
* @param \WP_User $user
*/
function userLogin($user_login, $user) {
update_user_meta($user->ID,'pys_just_login',true);
}
public function userRegisterHandler( $user_id ) {
if ( PYS()->getOption( 'woo_complete_registration_enabled' )
|| PYS()->getOption( 'automatic_event_signup_enabled' )
) {
update_user_meta( $user_id, 'pys_complete_registration', true );
}
}
/**
* Return array of registered pixels
*
* @return array
*/
public function getRegisteredPixels() {
return $this->registeredPixels;
}
/**
* @param Pixel|Settings $plugin
*/
public function registerPlugin( &$plugin ) {
$this->registeredPlugins[ $plugin->getSlug() ] = $plugin;
}
/**
* Return array of registered plugins
*
* @return array
*/
public function getRegisteredPlugins() {
return $this->registeredPlugins;
}
/**
* Front-end entry point
*/
public function managePixels() {
if (defined('DOING_AJAX') && DOING_AJAX) {
return;
}
// disable Events Manager on Customizer and preview mode
if (is_admin() || is_customize_preview() || is_preview()) {
return;
}
// disable Events Manager on Elementor editor
if (did_action('elementor/preview/init')
|| did_action('elementor/editor/init')
|| (isset( $_GET['action'] ) && $_GET['action'] == 'piotnetforms') // skip preview for piotnet forms plugin
) {
return;
}
// disable Events Manager on Divi Builder
if (function_exists('et_core_is_fb_enabled') && et_core_is_fb_enabled()) {
return;
}
if(PYS()->getOption( 'block_robot_enabled') && $this->is_user_agent_bot())
{
return;
}
if(PYS()->getOption( 'block_ip_enabled') && in_array($this->get_user_ip(), PYS()->getOption('blocked_ips')))
{
return;
}
$theme = wp_get_theme(); // gets the current theme
if ( ('Bricks' == $theme->name || 'Bricks' == $theme->parent_theme) && $_GET['bricks']=='run') {
return;
}
// output debug info
add_action( 'wp_head', function() {
echo "<script type='application/javascript'>console.log('PixelYourSite Free version " . PYS_FREE_VERSION . "');</script>\r\n";
}, 1 );
if ( isDisabledForCurrentRole() ) {
return;
}
// setup events
$this->eventsManager = new EventsManager();
// at least one pixel should be configured
if ( ! Facebook()->configured() && ! GA()->configured() && ! Pinterest()->configured() && ! Bing()->configured() ) {
add_action( 'wp_head', function() {
echo "<script type='application/javascript'>console.warn('PixelYourSite: no pixel configured.');</script>\r\n";
} );
return;
}
}
function get_user_ip(){
if (!empty($_SERVER['HTTP_CLIENT_IP'])) {
$ip = $_SERVER['HTTP_CLIENT_IP'];
} elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} else {
$ip = $_SERVER['REMOTE_ADDR'];
}
return $ip;
}
function is_user_agent_bot(){
if (!empty($_SERVER['HTTP_USER_AGENT'])) {
$options = array(
'YandexBot', 'YandexAccessibilityBot', 'YandexMobileBot','YandexDirectDyn',
'YandexScreenshotBot', 'YandexImages', 'YandexVideo', 'YandexVideoParser',
'YandexMedia', 'YandexBlogs', 'YandexFavicons', 'YandexWebmaster',
'YandexPagechecker', 'YandexImageResizer','YandexAdNet', 'YandexDirect',
'YaDirectFetcher', 'YandexCalendar', 'YandexSitelinks', 'YandexMetrika',
'YandexNews', 'YandexNewslinks', 'YandexCatalog', 'YandexAntivirus',
'YandexMarket', 'YandexVertis', 'YandexForDomain', 'YandexSpravBot',
'YandexSearchShop', 'YandexMedianaBot', 'YandexOntoDB', 'YandexOntoDBAPI',
'Googlebot', 'Googlebot-Image', 'Googlebot-News', 'Googlebot-Video',
'Mediapartners-Google', 'AdsBot-Google', 'Chrome-Lighthouse', 'Lighthouse',
'Mail.RU_Bot', 'bingbot', 'Accoona', 'ia_archiver', 'Ask Jeeves',
'OmniExplorer_Bot', 'W3C_Validator', 'WebAlta', 'YahooFeedSeeker', 'Yahoo!',
'Ezooms', '', 'Tourlentabot', 'MJ12bot', 'AhrefsBot', 'SearchBot', 'SiteStatus',
'Nigma.ru', 'Baiduspider', 'Statsbot', 'SISTRIX', 'AcoonBot', 'findlinks',
'proximic', 'OpenindexSpider','statdom.ru', 'Exabot', 'Spider', 'SeznamBot',
'oBot', 'C-T bot', 'Updownerbot', 'Snoopy', 'heritrix', 'Yeti',
'DomainVader', 'DCPbot', 'PaperLiBot', 'APIs-Google', 'AdsBot-Google-Mobile',
'AdsBot-Google-Mobile', 'AdsBot-Google-Mobile-Apps', 'FeedFetcher-Google',
'Google-Read-Aloud', 'DuplexWeb-Google', 'Storebot-Google'
);
foreach($options as $row) {
if (stripos($_SERVER['HTTP_USER_AGENT'], $row) !== false) {
return true;
}
}
}
return false;
}
public function ajaxGetGdprFiltersValues() {
wp_send_json_success( array(
'all_disabled_by_api' => apply_filters( 'pys_disable_by_gdpr', false ),
'facebook_disabled_by_api' => apply_filters( 'pys_disable_facebook_by_gdpr', false ),
'analytics_disabled_by_api' => apply_filters( 'pys_disable_analytics_by_gdpr', false ),
'pinterest_disabled_by_api' => apply_filters( 'pys_disable_pinterest_by_gdpr', false ),
'bing_disabled_by_api' => apply_filters( 'pys_disable_bing_by_gdpr', false ),
) );
}
public function getEventsManager() {
return $this->eventsManager;
}
public function adminMenu() {
global $submenu;
add_menu_page( 'PixelYourSite', 'PixelYourSite', 'manage_pys', 'pixelyoursite',
array( $this, 'adminPageMain' ), PYS_FREE_URL . '/dist/images/favicon.png' );
$addons = $this->registeredPlugins;
if ( $addons['head_footer'] ) {
unset( $addons['head_footer'] );
}
// display Licenses menu item only when at lest one addon is active
if ( count( $addons ) ) {
add_submenu_page( 'pixelyoursite', 'Licenses', 'Licenses',
'manage_pys', 'pixelyoursite_licenses', array( $this, 'adminPageLicenses' ) );
}
if(isWooCommerceActive()) {
add_submenu_page( 'pixelyoursite', 'WooCommerce Reports', 'WooCommerce Reports',
'manage_pys', 'pixelyoursite_woo_reports', array( $this, 'wooReport' ) );
}
if(isEddActive()) {
add_submenu_page( 'pixelyoursite', 'EDD Reports', 'EDD Reports',
'manage_pys', 'pixelyoursite_edd_reports', array( $this, 'eddReport' ) ,9);
}
add_submenu_page( 'pixelyoursite', 'UTM Builder', 'UTM Builder',
'manage_pys', 'pixelyoursite_utm', array( $this, 'utmTemplate' ) );
add_submenu_page( 'pixelyoursite', 'System Report', 'System Report',
'manage_pys', 'pixelyoursite_report', array( $this, 'adminPageReport' ) );
// core admin pages
$this->adminPagesSlugs = array(
'pixelyoursite',
'pixelyoursite_licenses',
'pixelyoursite_report',
'pixelyoursite_woo_reports',
'pixelyoursite_edd_reports',
'pixelyoursite_utm',
);
// rename first submenu item
if ( isset( $submenu['pixelyoursite'] ) ) {
$submenu['pixelyoursite'][0][0] = 'Dashboard';
}
$this->adminSaveSettings();
}
public function adminEnqueueScripts() {
wp_enqueue_style( 'pys_notice', PYS_FREE_URL . '/dist/styles/notice.css', array(), PYS_FREE_VERSION );
if ( in_array( getCurrentAdminPage(), $this->adminPagesSlugs ) ) {
wp_register_style( 'select2_css', PYS_FREE_URL . '/dist/styles/select2.min.css' );
wp_enqueue_script( 'select2_js', PYS_FREE_URL . '/dist/scripts/select2.min.js',
array( 'jquery' ) );
wp_enqueue_script( 'popper', PYS_FREE_URL . '/dist/scripts/popper.min.js', 'jquery' );
wp_enqueue_script( 'bootstrap', PYS_FREE_URL . '/dist/scripts/bootstrap.min.js', 'jquery',
'popper' );
wp_enqueue_style( 'pys_css', PYS_FREE_URL . '/dist/styles/admin.css', array( 'select2_css' ), PYS_FREE_VERSION );
wp_enqueue_script( 'pys_js', PYS_FREE_URL . '/dist/scripts/admin.js', array( 'jquery', 'select2_js', 'popper',
'bootstrap' ), PYS_FREE_VERSION );
}
}
public function adminPageMain() {
$this->adminResetSettings();
include 'views/html-wrapper-main.php';
}
public function adminPageReport() {
include 'views/html-report.php';
}
public function wooReport() {
include 'views/html-report-woo.php';
}
public function eddReport() {
include 'views/html-report-edd.php';
}
public function adminPageLicenses() {
$this->adminUpdateLicense();
/** @var Plugin|Settings $plugin */
foreach ( $this->registeredPlugins as $plugin ) {
if ( $plugin->getSlug() !== 'head_footer' ) {
$plugin->adminUpdateLicense();
}
}
include 'views/html-licenses.php';
}
public function adminUpdateLicense() {}
public function updatePlugin() {
foreach ( $this->registeredPlugins as $slug => $plugin ) {
if ( $slug == 'head_footer' ) {
continue;
}
updatePlugin( $plugin );
}
}
public function adminSecurityCheck() {
// verify user access
if ( ! current_user_can( 'manage_pys' ) ) {
return false;
}
// nonce filed and PYS data are required request
if ( ! isset( $_REQUEST['_wpnonce'] ) || ! isset( $_REQUEST['pys'] ) ) {
return false;
}
return true;
}
public function adminProcessRequest() {
$this->adminUpdateCustomEvents();
$this->adminEnableGdprAjax();
}
private function adminUpdateCustomEvents() {
if ( ! $this->adminSecurityCheck() ) {
return;
}
/**
* Single Custom Event Actions
*/
if ( isset( $_REQUEST['pys']['event'] ) && isset( $_REQUEST['action'] ) ) {
$nonce = isset( $_REQUEST['_wpnonce'] ) ? $_REQUEST['_wpnonce'] : null;
$action = $_REQUEST['action'];
if(isset( $_REQUEST['pys']['event']['post_id'] )) {
$post_id = sanitize_key($_REQUEST['pys']['event']['post_id']) ;
} else {
$post_id = false;
}
if ( $action == 'update' && wp_verify_nonce( $nonce, 'pys_update_event' ) ) {
if ( $post_id ) {
$event = CustomEventFactory::getById( $post_id );
$event->update( $_REQUEST['pys']['event'] );
} else {
if(isset( $_REQUEST['pys']['event']) && is_array($_REQUEST['pys']['event'])) {
CustomEventFactory::create( $_REQUEST['pys']['event'] );
} else {
CustomEventFactory::create( [] );
}
}
} elseif ( $action == 'enable' && $post_id && wp_verify_nonce( $nonce, 'pys_enable_event' ) ) {
$event = CustomEventFactory::getById( $post_id );
$event->enable();
} elseif ( $action == 'disable' && $post_id && wp_verify_nonce( $nonce, 'pys_disable_event' ) ) {
$event = CustomEventFactory::getById( $post_id );
$event->disable();
} elseif ( $action == 'remove' && $post_id && wp_verify_nonce( $nonce, 'pys_remove_event' ) ) {
CustomEventFactory::remove( $post_id );
}
purgeCache();
// redirect to events tab
wp_safe_redirect( buildAdminUrl( 'pixelyoursite', 'events' ) );
exit;
}
/**
* Bulk Custom Events Actions
*/
if ( isset( $_REQUEST['pys']['bulk_event_action'], $_REQUEST['pys']['selected_events'] )
&& isset( $_REQUEST['pys']['bulk_event_action_nonce'] )
&& wp_verify_nonce( $_REQUEST['pys']['bulk_event_action_nonce'], 'bulk_event_action' )
&& is_array( $_REQUEST['pys']['selected_events'] ) ) {
foreach ( $_REQUEST['pys']['selected_events'] as $event_id ) {
$event_id = (int) $event_id;
switch ( $_REQUEST['pys']['bulk_event_action'] ) {
case 'enable':
$event = CustomEventFactory::getById( $event_id );
$event->enable();
break;
case 'disable':
$event = CustomEventFactory::getById( $event_id );
$event->disable();
break;
case 'clone':
CustomEventFactory::makeClone( $event_id );
break;
case 'delete':
CustomEventFactory::remove( $event_id );
break;
}
}
purgeCache();
// redirect to events tab
wp_safe_redirect( buildAdminUrl( 'pixelyoursite', 'events' ) );
exit;
}
}
private function adminSaveSettings() {
if ( ! $this->adminSecurityCheck() ) {
return;
}
if ( wp_verify_nonce( $_REQUEST['_wpnonce'], 'pys_save_settings' ) ) {
if(isset( $_POST['pys']['core'] ) && is_array($_POST['pys']['core'])) {
$core_options = $_POST['pys']['core'];
} else {
$core_options = array();
}
$gdpr_ajax_enabled = isset( $core_options['gdpr_ajax_enabled'] )
? $core_options['gdpr_ajax_enabled'] // value from form data
: $this->getOption( 'gdpr_ajax_enabled' ); // previous value
// allow 3rd party plugins to by-pass option value
$core_options['gdpr_ajax_enabled'] = apply_filters( 'pys_gdpr_ajax_enabled', $gdpr_ajax_enabled );
if (isPixelCogActive() ) {
if (isset($core_options['woo_purchase_value_option'])) {
$core_options = $this->updateDefaultNoCogOption($core_options,'woo_purchase_value_option','woo_purchase_value_cog');
}
if (isset($core_options['woo_view_content_value_option'])) {
$core_options = $this->updateDefaultNoCogOption($core_options,'woo_view_content_value_option','woo_content_value_cog');
}
if (isset($core_options['woo_add_to_cart_value_option'])) {
$core_options = $this->updateDefaultNoCogOption($core_options,'woo_add_to_cart_value_option','woo_add_to_cart_value_cog');
}
if (isset($core_options['woo_initiate_checkout_value_option'])) {
$core_options = $this->updateDefaultNoCogOption($core_options,'woo_initiate_checkout_value_option','woo_initiate_checkout_value_cog');
}
}
// update core options
$this->updateOptions( $core_options );
$objects = array_merge( $this->registeredPixels, $this->registeredPlugins );
// update plugins and pixels options
foreach ( $objects as $obj ) {
/** @var Plugin|Pixel|Settings $obj */
$obj->updateOptions();
}
purgeCache();
}
}
private function updateDefaultNoCogOption($core_options,$optionName,$defaultOptionName) {
$val = $core_options[$optionName];
$currentVal = $this->getOption($optionName);
if($val != 'cog') {
$core_options[$defaultOptionName] = $val;
} elseif ( $currentVal != 'cog' ) {
$core_options[$defaultOptionName] = $currentVal;
}
return $core_options;
}
private function adminResetSettings() {
if ( ! $this->adminSecurityCheck() ) {
return;
}
if ( wp_verify_nonce( $_REQUEST['_wpnonce'], 'pys_save_settings' ) && isset( $_REQUEST['pys']['reset_settings'] ) ) {
if ( isPinterestActive() ) {
$old_options = array(
'license_key' => Pinterest()->getOption( 'license_key' ),
'license_status' => Pinterest()->getOption( 'license_status' ),
'license_expires' => Pinterest()->getOption( 'license_expires' ),
'pixel_id' => Pinterest()->getOption( 'pixel_id' ),
);
Pinterest()->resetToDefaults();
Pinterest()->updateOptions( $old_options );
}
PYS()->resetToDefaults();
Facebook()->resetToDefaults();
GA()->resetToDefaults();
// do redirect
wp_safe_redirect( buildAdminUrl( 'pixelyoursite' ) );
exit;
}
}
private function adminEnableGdprAjax() {
if ( ! $this->adminSecurityCheck() ) {
return;
}
if ( isset( $_REQUEST['pys']['enable_gdpr_ajax'] ) ) {
$this->updateOptions( array(
'gdpr_ajax_enabled' => true,
'gdpr_cookie_law_info_integration_enabled' => true,
'consent_magic_integration_enabled' => true,
) );
add_action( 'admin_notices', 'PixelYourSite\adminGdprAjaxEnabledNotice' );
purgeCache();
}
}
function restoreSettingsAfterCog() {
$params = array();
$oldPurchase = $this->getOption("woo_purchase_value_cog");
$oldContent = $this->getOption("woo_content_value_cog");
$oldAddCart = $this->getOption("woo_add_to_cart_value_cog");
$oldInitCheckout = $this->getOption("woo_initiate_checkout_value_cog");
if($this->getOption('woo_purchase_value_option') == 'cog') {
if(!empty($oldPurchase)) $params['woo_purchase_value_option'] = $oldPurchase;
else $params['woo_purchase_value_option'] = "price";
}
if($this->getOption('woo_view_content_value_option') == 'cog') {
if(!empty($oldContent)) $params['woo_view_content_value_option'] = $oldContent;
else $params['woo_view_content_value_option'] = "price";
}
if($this->getOption('woo_add_to_cart_value_option') == 'cog') {
if(!empty($oldAddCart)) $params['woo_add_to_cart_value_option'] = $oldAddCart;
else $params['woo_add_to_cart_value_option'] = "price";
}
if($this->getOption('woo_initiate_checkout_value_option') == 'cog') {
if(!empty($oldInitCheckout)) $params['woo_initiate_checkout_value_option'] = $oldInitCheckout;
else $params['woo_initiate_checkout_value_option'] = "price";
}
$params['woo_purchase_value_cog'] = '';
$params['woo_content_value_cog'] = '';
$params['woo_add_to_cart_value_cog'] = '';
$params['woo_initiate_checkout_value_cog'] = '';
$this->updateOptions($params);
}
public function getLog() {
return $this->logger;
}
}
/**
* @return PYS
*/
function PYS() {
return PYS::instance();
}