Overview

Packages

  • ACF
  • Automation
    • Actions
    • Activation
    • LeadProfile
    • Menus
    • Queries
    • Rules
    • Triggers
  • CTA
    • Activation
    • AJAXListeners
    • Cloning
    • Core
    • Display
    • EditPage
    • Enqueues
    • GPLSettings
    • LeadsProfile
    • Loading
    • Menus
    • Notices
    • PlacementMetabox
    • PostType
    • Templates
    • Tracking
    • Variations
    • YOAST
  • InboundPro
    • Activation
    • AdminAJAX
    • AutoLoading
    • Cron
    • DataInterface
    • FieldMapping
    • Funnels
    • InboundNowAPI
    • Installer
    • LeadStatuses
    • Menus
    • Notifications
    • Ouath
    • Reports
    • Settings
    • Tracking
    • Translations
    • Updates
  • LandingPages
    • Activation
    • DataInterfaces
    • Management
    • Menus
    • NeedsAttention
    • Notices
    • Sidebars
    • Templates
    • Tracking
    • Variations
    • WelcomeScreen
    • Widgets
  • Leads
    • Activation
    • Akismet
    • BranchControl
    • BulkActions
    • Dashboard
    • Management
    • Notifications
    • Settings
    • Tracking
    • UserProfile
    • WPLogin
  • Mailer
    • Activation
    • Admin
    • ClickTracking
    • DataInterface
    • InboundForms
    • Leads
    • Management
    • Notifications
    • Scheduling
    • Sending
    • Settings
    • ShortcodesAndTokens
    • SparkPost
    • Templates
    • Unsubscribes
    • Variations
    • YoastSEO
  • None
  • Shared
    • APIs
    • CPT
    • DatabaseRoutines
    • DebugTricks
    • DoubleOptin
    • EventManagement
    • FieldMapping
    • InboundForms
    • LeadSorage
    • MarketingButton
    • Menus
    • Notifications
    • Shortcodes
    • ShortcodesAndTokens
    • StandAloneLicensing
    • Tracking
    • VisualEditor
  • xDepreciated

Classes

  • CTA_Activation
  • CTA_Activation_Update_Routines
  • CTA_Admin_Notices
  • CTA_Ajax_Listeners
  • CTA_Clone_Post
  • CTA_Conversion_Tracking
  • CTA_Dynamic_Widget
  • CTA_Enqueues
  • CTA_Load_Extensions
  • CTA_Menus
  • CTA_Metaboxes
  • CTA_Metaboxes_Global
  • CTA_Post_Type
  • CTA_Render
  • CTA_Settings
  • CTA_Static_Widget
  • CTA_Template_Manager
  • CTA_Template_Manager_List
  • CTA_Variations
  • CTA_WordPress_Leads
  • CTA_WordPress_SEO
  • Inbound_Ajax
  • Inbound_Akismet
  • Inbound_Analytics
  • Inbound_API
  • Inbound_API_Keys_Generation
  • Inbound_API_Keys_Table
  • Inbound_API_Wrapper
  • Inbound_Asset_Loader
  • Inbound_Automation_Action_Add_Remove_List
  • Inbound_Automation_Action_Add_Remove_Tag
  • Inbound_Automation_Action_Create_Lead
  • Inbound_Automation_Action_Create_User
  • Inbound_Automation_Action_Kill_Tasks
  • Inbound_Automation_Action_Relay_Data
  • Inbound_Automation_Action_Send_Email
  • Inbound_Automation_Action_Wait
  • Inbound_Automation_Activation
  • Inbound_Automation_Activation_Update_Routines
  • Inbound_Automation_Adminbar
  • Inbound_Automation_Lead_Profile
  • Inbound_Automation_Loader
  • Inbound_Automation_Plugin
  • Inbound_Automation_Post_Type
  • Inbound_Automation_Processing
  • Inbound_Automation_Query_Lead
  • Inbound_Automation_Query_User
  • Inbound_Automation_Trigger_inbound_double_optin_confirm
  • Inbound_Automation_Trigger_inbound_store_lead_post
  • Inbound_Automation_Trigger_inbound_track_link
  • Inbound_Automation_Trigger_Publish_Post
  • Inbound_Automation_Trigger_Save_Post_Deactivated
  • Inbound_Automation_Trigger_Set_Object_Terms
  • Inbound_Automation_Trigger_Update_Lead
  • Inbound_Automation_Trigger_User_Register
  • Inbound_Calls_To_Action_Plugin
  • Inbound_Confirm_Double_Optin
  • Inbound_Cron
  • Inbound_CTA_Quick_View
  • Inbound_Customizer
  • Inbound_Debug_Scripts
  • Inbound_Email_Meta
  • Inbound_Email_Preview
  • Inbound_Email_Template_Shortcodes
  • Inbound_Event_Report
  • Inbound_Events
  • Inbound_Events_Report
  • Inbound_Extension_Loads
  • Inbound_Forms
  • Inbound_Funnel_Reporting
  • Inbound_Impressions_Report
  • Inbound_Landing_Pages_Plugin
  • Inbound_Lead_Statuses
  • Inbound_Leads
  • Inbound_Leads_Custom_fields
  • Inbound_Leads_Plugin
  • Inbound_License
  • Inbound_List_Double_Optin
  • Inbound_Load_Shared
  • Inbound_Logging_Automation
  • Inbound_Login
  • Inbound_Mail_Daemon
  • Inbound_Mailer_ACF
  • Inbound_Mailer_Activation
  • Inbound_Mailer_Activation_Update_Routines
  • Inbound_Mailer_Ajax_Listeners
  • Inbound_Mailer_Clone_Post
  • Inbound_Mailer_Common_Settings
  • Inbound_Mailer_Customizer
  • Inbound_Mailer_Direct_Email_Leads
  • Inbound_Mailer_Enqueues
  • Inbound_Mailer_Forms_Integration
  • Inbound_Mailer_Load_Templates
  • Inbound_Mailer_Menus
  • Inbound_Mailer_Metaboxes
  • Inbound_Mailer_Notifications
  • Inbound_Mailer_Plugin
  • Inbound_Mailer_Post_Type
  • Inbound_Mailer_Scheduling
  • Inbound_Mailer_Settings
  • Inbound_Mailer_SparkPost
  • Inbound_Mailer_Stats_Report
  • Inbound_Mailer_Template_Manager
  • Inbound_Mailer_Template_Manager_List
  • Inbound_Mailer_Tokens
  • Inbound_Mailer_Tracking
  • Inbound_Mailer_Unsubscribe
  • Inbound_Mailer_Variations
  • Inbound_Mailer_WordPress_SEO
  • Inbound_Maintenance_Lists
  • Inbound_Marketing_Button
  • Inbound_Menus_Admin
  • Inbound_Menus_Adminbar
  • Inbound_Metaboxes_Automation
  • Inbound_Metaboxes_Leads
  • Inbound_Notifications
  • Inbound_Now_Store
  • Inbound_Options_API
  • Inbound_Pro_Activation
  • Inbound_Pro_Admin_Ajax_Listeners
  • Inbound_Pro_Automatic_Updates
  • Inbound_Pro_Downloads
  • Inbound_Pro_Notifications
  • Inbound_Pro_Oauth_Engine
  • Inbound_Pro_Plugin
  • Inbound_Pro_Settings
  • Inbound_Quick_View
  • Inbound_Reporting_Templates
  • Inbound_Search_And_Comment_Report
  • Inbound_Shared_ACF_BootStrap
  • Inbound_Shortcodes
  • Inbound_Shortcodes_Cookies
  • Inbound_Shortcodes_Fields
  • Inbound_SparkPost
  • Inbound_SparkPost_Stats
  • Inbound_Template_Utils
  • Inbound_Templating_Engine
  • Inbound_Tracking
  • Inbound_Translation_Updater
  • Inbound_Updater
  • Inbound_Upgrade_For_More_Reports
  • Inbound_Upgrade_Routines
  • Inbound_Visitor_Event_Report
  • Inbound_Visitor_Impressions_Report
  • Inbound_Visitors_Report
  • INBOUNDNOW_EXTEND
  • Landing_Pages_ACF
  • Landing_Pages_Activation
  • Landing_Pages_Activation_Update_Routines
  • Landing_Pages_Admin_Menus
  • Landing_Pages_Admin_Notices
  • Landing_Pages_Install
  • Landing_Pages_Load_Extensions
  • Landing_Pages_Meta
  • Landing_Pages_Metaboxes
  • Landing_Pages_Post_Type
  • Landing_Pages_Row_Actions
  • Landing_Pages_Settings
  • Landing_Pages_Sidebars
  • Landing_Pages_Split_Testing_Stats
  • Landing_Pages_Template_Management
  • Landing_Pages_Template_Switcher
  • Landing_Pages_Templates_List_Table
  • Landing_Pages_Variations
  • LandingPages_Welcome
  • Leads_Activation
  • Leads_Activation_Update_Routines
  • Leads_Admin_Notices
  • Leads_Batch_Processor
  • Leads_Branching
  • Leads_Dashboard
  • Leads_Field_Map
  • Leads_Manager
  • Leads_Post_Type
  • Leads_Settings
  • Leads_Tracking
  • Leads_User_Profile
  • LeadStorage
  • LP_EXTENSION_LICENSENING
  • LP_EXTENSION_UPDATER
  • LP_Variation_Rotation
  • LP_Widget_Conversion_Area

Functions

  • cta_check_active
  • cta_example_template_function
  • cta_load_dynamic_widget
  • CTA_Load_Extensions
  • cta_load_static_widget
  • CTA_Render
  • inbound_add_conversion_to_lead
  • inbound_automation_check_active
  • inbound_automation_load_definitions
  • inbound_automation_metaboxes
  • inbound_automation_processing
  • inbound_color
  • inbound_color_scheme
  • inbound_confirm_email_service_provider
  • inbound_email_kill_ie8
  • inbound_email_load_templates
  • inbound_form_add_lead_list
  • inbound_form_auto_publish
  • inbound_form_delete_transient
  • inbound_form_get_data
  • inbound_form_save
  • inbound_forms_change_columns
  • inbound_forms_cpt
  • inbound_forms_custom_columns
  • inbound_forms_default_content
  • inbound_get_form_names
  • inbound_get_parent_directory
  • inbound_Hex_2_RGB
  • inbound_inbound_email_example_template_function
  • inbound_load_lead_manager
  • inbound_load_token_engine
  • inbound_mailer_acf_integration
  • Inbound_Mailer_Common_Settings
  • Inbound_Mailer_Load_Templates
  • inbound_qtrans_disable
  • inbound_record_log
  • inbound_register_form_role_capabilities
  • inbound_shortcode_alert
  • inbound_shortcode_callout
  • inbound_shortcode_columns
  • inbound_shortcode_content_box
  • inbound_shortcode_divider
  • inbound_shortcode_empty_paragraph_fix
  • inbound_shortcode_four_fifth_columns
  • inbound_shortcode_full_columns
  • inbound_shortcode_gmap
  • inbound_shortcode_icon
  • inbound_shortcode_intro
  • inbound_shortcode_landing_pages
  • inbound_shortcode_leadp
  • inbound_shortcode_list_icons
  • inbound_shortcode_one_fifth_columns
  • inbound_shortcode_one_fourth_columns
  • inbound_shortcode_one_half_columns
  • inbound_shortcode_one_third_columns
  • inbound_shortcode_portfolio
  • inbound_shortcode_pricing
  • inbound_shortcode_profile
  • inbound_shortcode_social_links
  • inbound_shortcode_tabs
  • inbound_shortcode_teaser
  • inbound_shortcode_testimonial
  • inbound_shortcode_three_fifth_columns
  • inbound_shortcode_three_fourth_columns
  • inbound_shortcode_two_fifth_columns
  • inbound_shortcode_two_third_columns
  • inbound_shortcode_video
  • inbound_store_lead
  • inbound_template_brightness
  • inbound_template_color
  • Inbound_Templating_Engine
  • inbound_travis_check
  • inboundnow_add_master_license
  • json_encode_fallback
  • landingpage_fix_known_wp_title_isses
  • landingpages_is_active
  • load_CTA_Settings
  • load_CTA_Template_Manager
  • load_Inbound_API_Keys_Generation
  • load_Inbound_Lead_Statuses
  • load_Inbound_Leads_Custom_fields
  • load_inbound_mail_daemon
  • load_Inbound_Mailer_Settings
  • load_Inbound_Mailer_Template_Manager
  • load_Inbound_Pro_Downloads
  • lp_ab_testing_get_current_variation_id
  • lp_add_option
  • lp_body_class
  • lp_check_active
  • lp_content_area
  • lp_conversion_area
  • lp_discover_important_wrappers
  • lp_footer
  • lp_generate_drowndown
  • lp_get_parent_directory
  • lp_get_value
  • lp_global_config
  • lp_head
  • lp_in_admin_header
  • lp_init
  • lp_list_feature
  • lp_load_widgets
  • lp_main_headline
  • lp_manage_templates
  • lp_move_template_files
  • lp_rebuild_attributes
  • lp_templates_upload
  • mailer_check_active
  • wp_cta_check_active
  • wp_cta_kill_ie8
  • wp_cta_load_calls_to_action
  • wp_leads_get_page_final_id
  • wpl_url_to_postid
  • wpleads_add_lead_to_list
  • wpleads_check_active
  • wpleads_get_lead_lists_as_array
  • Overview
  • Package
  • Class
  1:   2:   3:   4:   5:   6:   7:   8:   9:  10:  11:  12:  13:  14:  15:  16:  17:  18:  19:  20:  21:  22:  23:  24:  25:  26:  27:  28:  29:  30:  31:  32:  33:  34:  35:  36:  37:  38:  39:  40:  41:  42:  43:  44:  45:  46:  47:  48:  49:  50:  51:  52:  53:  54:  55:  56:  57:  58:  59:  60:  61:  62:  63:  64:  65:  66:  67:  68:  69:  70:  71:  72:  73:  74:  75:  76:  77:  78:  79:  80:  81:  82:  83:  84:  85:  86:  87:  88:  89:  90:  91:  92:  93:  94:  95:  96:  97:  98:  99: 100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110: 111: 112: 113: 114: 115: 116: 117: 118: 119: 120: 121: 122: 123: 124: 125: 126: 127: 128: 129: 130: 131: 132: 133: 134: 135: 136: 137: 138: 139: 140: 141: 142: 143: 144: 145: 146: 147: 148: 149: 150: 151: 152: 153: 154: 155: 156: 157: 158: 159: 160: 161: 162: 163: 164: 165: 166: 167: 168: 169: 170: 171: 172: 173: 174: 175: 176: 177: 178: 179: 180: 181: 182: 183: 184: 185: 186: 187: 188: 189: 190: 191: 192: 193: 194: 195: 196: 197: 198: 199: 200: 201: 202: 203: 204: 205: 206: 207: 208: 209: 210: 211: 212: 213: 214: 215: 216: 217: 218: 219: 220: 221: 222: 223: 224: 225: 226: 227: 228: 229: 230: 231: 232: 233: 234: 235: 236: 237: 238: 239: 240: 241: 242: 243: 244: 245: 246: 247: 248: 249: 250: 251: 252: 253: 254: 255: 256: 257: 258: 259: 260: 261: 262: 263: 264: 265: 266: 267: 268: 269: 270: 271: 272: 273: 274: 275: 276: 277: 278: 279: 280: 281: 282: 283: 284: 285: 286: 287: 288: 289: 290: 291: 292: 293: 294: 295: 296: 297: 298: 299: 300: 301: 302: 303: 304: 305: 306: 307: 308: 309: 310: 311: 312: 313: 314: 315: 316: 317: 318: 319: 320: 321: 322: 323: 324: 325: 326: 327: 328: 329: 330: 331: 332: 333: 334: 335: 336: 337: 338: 339: 340: 341: 342: 343: 344: 345: 346: 347: 348: 349: 350: 351: 352: 353: 354: 355: 356: 357: 358: 359: 360: 361: 362: 363: 364: 365: 366: 367: 368: 369: 370: 371: 372: 373: 374: 375: 376: 377: 378: 379: 380: 381: 382: 383: 384: 385: 386: 387: 388: 389: 390: 391: 392: 393: 394: 395: 396: 397: 398: 399: 400: 401: 402: 403: 404: 405: 406: 407: 408: 409: 410: 411: 412: 413: 414: 415: 416: 417: 418: 419: 420: 421: 422: 423: 424: 425: 426: 427: 428: 429: 430: 
<?php

/**
 * Class provides search and comment tracking features
 *
 * @package Leads
 * @subpackage Tracking
 */


class Leads_Tracking {

    /**
     * Initiate class
     */
    public function __construct() {
        self::add_hooks();
    }


    /**
     * Load hooks and filters
     */
    public static function add_hooks() {
        /* listen for set cookie calls */
        add_action('wp_head', array(__CLASS__, 'set_cookies'));

        /* listens for comments approval status to change and either saves them to events or removes them */
        add_action('transition_comment_status', array(__CLASS__, 'track_comment_approval'), 10, 3);

        /* listens for comments that are auto approved, and saves them to events */
        add_action('wp_insert_comment', array(__CLASS__, 'track_comment_inserts'), 10, 2);

        /* saves user searches to events */
        add_action('wp_ajax_inbound_search_store', array(__CLASS__, 'ajax_inbound_search_store'), 10, 1);
        add_action('wp_ajax_nopriv_inbound_search_store', array(__CLASS__, 'ajax_inbound_search_store'), 10, 1);
    }

    /**
     * Listens for special frontend calls to set cookies
     */
    public static function set_cookies() {
        global $wpdb;

        if (isset($_GET['wpl_email'])) {
            $lead_id = $_GET['wpl_email'];

            $query = $wpdb->prepare(
                'SELECT ID FROM ' . $wpdb->posts . '
                WHERE post_title = %s
                AND post_type = \'wp-lead\'',
                $lead_id
            );

            $wpdb->query($query);

            if ($wpdb->num_rows) {
                $lead_ID = $wpdb->get_var($query);
                setcookie('wp_lead_id', $lead_ID, time() + (20 * 365 * 24 * 60 * 60), '/');
            }
        }
    }

    /**
     * Cookies visitor's browser with proper lead list given a lead id
     * @param  string $lead_id - lead CPT id
     * @return sets cookie of lists lead belongs to
     */
    public static function cookie_lead_lists($lead_id, $lists = null) {

        if (is_array($lists)) {
            $lead_lists = array('ids' => $lists);
        } else {
            $terms = get_the_terms($lead_id, 'wplead_list_category');

            $lists = array();
            if ($terms && !is_wp_error($terms)) {

                foreach ($terms as $term) {
                    $lists[] = $term->term_id;
                }
            }
        }

        $lead_lists = json_encode(array('ids' => $lists));

        setcookie('wp_lead_list', $lead_lists, (int) (time() + (20 * 365 * 24 * 60 * 60) ), '/');

    }

    /**
     * Cookies visitor's browser with proper lead list given a lead id
     * @param  string $lead_id - lead CPT id
     * @return sets cookie of lists lead belongs to
     */
    public static function cookie_lead_tags($lead_id, $tags = null) {
        $lead_tags = array();

        if (is_array($tags)) {
            $lead_tags = array('ids' => $tags);
        } else {
            $terms = get_the_terms($lead_id, 'lead-tags');
            $tags = array();

            if ($terms && !is_wp_error($terms)) {
                foreach ($terms as $term) {
                    $tags[] = $term->term_id;
                }
            }

            $lead_tags = array('ids' => $tags);
        }

        $tags_json = json_encode($lead_tags);
        setcookie('wp_lead_tags', $tags_json, time() + (20 * 365 * 24 * 60 * 60), '/');

    }

    /**
     * wp_leads_update_page_view_obj updates page_views meta for known leads
     * @param  ARRAY $lead_data array of data associated with page view event
     */

    public static function update_page_views_object($lead_data) {

        if (!$lead_data['page_id']) {
            return;
        }

        $current_page_view_count = get_post_meta($lead_data['lead_id'], 'wpleads_page_view_count', true);

        $increment_page_views = $current_page_view_count + 1;

        update_post_meta($lead_data['lead_id'], 'wpleads_page_view_count', $increment_page_views); // update count

        $time = current_time('timestamp', 0); // Current wordpress time from settings
        $wordpress_date_time = date("Y-m-d G:i:s T", $time);

        $page_view_data = get_post_meta($lead_data['lead_id'], 'page_views', TRUE);
        //echo $lead_data['page_id']; // for debug

        // If page_view meta exists do this
        if ($page_view_data) {
            $current_count = 0; // default
            $timeout = 30;  // 30 Timeout analytics tracking for same page timestamps
            $page_view_data = json_decode($page_view_data, true);

            // increment view count on page
            if (isset($page_view_data[$lead_data['page_id']])) {
                $current_count = count($page_view_data[$lead_data['page_id']]);
                $last_view = $page_view_data[$lead_data['page_id']][$current_count - 1];
                $timeout = abs(strtotime($last_view) - strtotime($wordpress_date_time));
            }

            // If page hasn't been viewed in past 30 seconds. Log it
            if ($timeout >= 30) {
                $page_view_data[$lead_data['page_id']][$current_count] = $wordpress_date_time;
                $page_view_data = json_encode($page_view_data);
                update_post_meta($lead_data['lead_id'], 'page_views', $page_view_data);
            }

        } else {
            // Create page_view meta if it doesn't exist
            $page_view_data = array();
            $page_view_data[$lead_data['page_id']][0] = $wordpress_date_time;
            $page_view_data = json_encode($page_view_data);
            update_post_meta($lead_data['lead_id'], 'page_views', $page_view_data);
        }

        /**
         * Runs hook that tells WordPress lead data has been updated
         * @package Leads
         * @subpackage Hooks
         */
        do_action('wplead_page_view', $lead_data);
    }

    /**
     * Tracks the change of comment statuses. Approved or Unapproved
     * @param $new_status
     * @param $old_status
     * @param $comment [the comment object]
     */
    public static function track_comment_approval($new_status, $old_status, $comment) {

        /* if comment tracking is turned off exit */
        if (!defined('INBOUND_PRO_CURRENT_VERSION')) {
            if (get_option('wpl-main-comment-tracking', '') == 0) {
                return;
            }
        } else {
            $settings = Inbound_Options_API::get_option('inbound-pro', 'settings', array());
            if ($settings['leads']['comment-tracking'] == 0) {
                return;
            }
        }

        /* if the comment has been approved, add it to the db */
        if ($comment->comment_approved == 1) {

            /* get the lead id */
            $lead_id = LeadStorage::lookup_lead_by_email($comment->comment_author_email);

            /*if the lead exists*/
            if ($lead_id) {

                /* if the comment isn't already stored */
                if (!Inbound_Events::comment_exists($comment->comment_ID)) {

                    /* exit if the comment came from a source we don't want to listen to */
                    $agents_to_ignore = array('WooCommerce');
                    if (in_array($comment->comment_agent, $agents_to_ignore)) {
                        return;
                    }

                    $datetime = date_i18n('Y-m-d G:i:s T', strtotime($comment->comment_date));

                    $args = array(
                        'page_id' => $comment->comment_post_ID,
                        'lead_id' => $lead_id,
                        'comment_id' => $comment->comment_ID,
                        'event_details' => json_encode(array(
                            'comment_id' => $comment->comment_ID,
                            'comment_content' => ($comment->comment_content) ? $comment->comment_content : '',
                            'comment_author' => ($comment->comment_author) ? $comment->comment_author : '',
                            'comment_author_email' => ($comment->comment_author_email) ? $comment->comment_author_email : '',
                            'comment_author_url' => ($comment->comment_author_url) ? $comment->comment_author_url : '',
                            'comment_agent' => ($comment->comment_agent) ? $comment->comment_agent : '',
                            'comment_type' => ($comment->comment_type) ? $comment->comment_type : '',
                            'comment_parent' => ($comment->comment_parent) ? $comment->comment_parent : '',
                            'user_id' => ($comment->user_id) ? $comment->user_id : '',
                            'page_id' => $comment->comment_post_ID,
                        )),
                        'datetime' => $datetime,
                    );
                    /* store the approved comment event */
                    Inbound_Events::store_comment_event($args);
                }
            }
        }

        /* if the comment was unapproved later, remove it from the db */
        if ($comment->comment_approved != 1) {

            $lead_id = LeadStorage::lookup_lead_by_email($comment->comment_author_email);

            if ($lead_id) { // if there isn't a lead id, then the comment isn't stored in the db

                Inbound_Events::remove_comment_event((int)$comment->comment_ID);
            }
        }
    }

    /**
     * Tracks comments that are auto approved
     * @param $id [comment id]
     * @param $comment [the comment object]
     */
    public static function track_comment_inserts($id, $comment) {
        global $inbound_settings;

        $inbound_settings['leads']['comment-tracking'] = (isset($inbound_settings['leads']['comment-tracking'])) ? $inbound_settings['leads']['comment-tracking'] : 1;
        /* exit if comment tracking is turned off */
        if (!defined('INBOUND_PRO_CURRENT_VERSION')) {
            if (get_option('wpl-main-comment-tracking', '') == 0) {
                return;
            }
        } else {
            $settings = Inbound_Options_API::get_option('inbound-pro', 'settings', array());
            if ($inbound_settings['leads']['comment-tracking'] == 0) {
                return;
            }
        }

        if ($comment->comment_approved == 1) {

            $lead_id = LeadStorage::lookup_lead_by_email($comment->comment_author_email);

            if ($lead_id) {

                /* exit if the comment came from a source we don't want to listen to */
                $agents_to_ignore = array('WooCommerce');
                if (in_array($comment->comment_agent, $agents_to_ignore)) {
                    return;
                }

                /* get the current time */
                $datetime = date_i18n('Y-m-d G:i:s');

                $args = array(
                    'page_id' => $comment->comment_post_ID,
                    'lead_id' => $lead_id,
                    'comment_id' => $comment->comment_ID,
                    'event_details' => json_encode(array(
                        'comment_id' => $comment->comment_ID,
                        'comment_content' => ($comment->comment_content) ? $comment->comment_content : '',
                        'comment_author' => ($comment->comment_author) ? $comment->comment_author : '',
                        'comment_author_email' => ($comment->comment_author_email) ? $comment->comment_author_email : '',
                        'comment_author_url' => ($comment->comment_author_url) ? $comment->comment_author_url : '',
                        'comment_agent' => ($comment->comment_agent) ? $comment->comment_agent : '',
                        'comment_type' => ($comment->comment_type) ? $comment->comment_type : '',
                        'comment_parent' => ($comment->comment_parent) ? $comment->comment_parent : '',
                        'user_id' => ($comment->user_id) ? $comment->user_id : '',
                        'page_id' => $comment->comment_post_ID,
                    )),
                    'datetime' => $datetime,
                );

                Inbound_Events::store_comment_event($args);
            }
        }
    }

    /**
     * Stores the user's searches in the database
     * @param $_POST ['data'] (array) lead data to store
     * @param $_POST ['nonce'] (string)
     */
    public static function ajax_inbound_search_store() {
        error_log('ajax_inbound_search_store');
        $timezone = get_option('gmt_offset');
        $data = json_decode(stripslashes(urldecode($_POST['data'])), true);
        $lead_id = intval($_POST['lead_id']);

        /* sanitize the input */
        $clean_data = array();
        foreach ($data as $key => $value) {
            error_log('data');
            $clean_data[$key] = array_map(function ($sub_value) {

                if (!isset($sub_value) && empty($sub_value)) {
                    return 0;
                }

                /* if the value isn't url encoded, return the sanitized value */
                if (urldecode($sub_value) === $sub_value) {
                    return sanitize_text_field($sub_value);
                }

                return sanitize_text_field(urldecode($sub_value));

            }, $value);
        }

        /* if a lead id isn't supplied directly, see if one was passed in the search data */
        if (!$lead_id) {
            $lead_id = 0;
            $emails = array();
            foreach ($clean_data as $key => $value) {
                if (isset($value['lead_id']) && !empty($value['lead_id'])) {
                    $lead_id = $value['lead_id'];
                    break;
                }

                if (is_email($value['email']) && !empty($value['email'])) {
                    $email[] = $value['email'];
                }
            }
        }

        /* if there isn't a lead id */
        if ($lead_id === 0) {
            // see if the email is provided, get lead_id from that if possible
            if (!empty($emails)) {
                $counted_emails = array_count_values($emails);
                foreach ($counted_emails as $email => $count) {
                    $lead = get_page_by_title($email, 'OBJECT', 'wp-lead');
                    if (!empty($lead) && !null) {
                        $lead_id = $lead->ID;
                        break;
                    }
                }
            }

            // exit if we still don't have a lead id
            if ($lead_id == 0) {
                error_log('die');
                // echo json_encode( array( 'error' => __( 'No id provided', 'inbound-pro' ) ) );
                die();
            }
        }

        if (!wp_verify_nonce($_POST['nonce'], 'inbound_lead_' . $lead_id . '_nonce')) {
            error_log('nonce');
            // echo json_encode( array( 'error' => __( 'Invalid nonce', 'inbound-pro' ) ) );
            die();
        }

        // check to see if the lead exists
        $lead = get_post($lead_id);

        // if the lead doesn't exist, exit
        if (!$lead) {
            error_log('no lead');
            die();
        }

        foreach ($clean_data as $key => $value) {
            /* if the gmt offset is set, account for wp time */
            if (!empty($timezone) || $timezone === 0) {
                $value['timestamp'] += ($timezone * 3600);
            }

            $args = array(
                'page_id' => $value['page_id'],
                'lead_id' => $lead_id,
                'lead_uid' => $value['user_UID'],
                'variation_id' => $value['variation'],
                'event_details' => json_encode(array(
                    'search_data' => $value['search_data'],
                    'post_type' => $value['post_type'],
                    'ip_address' => $value['ip_address'],
                    'page_id' => $value['page_id'],
                    'datetime' => date_i18n('Y-m-d G:i:s T', $value['timestamp']),
                )),
                'source' => $value['source'],
                'datetime' => date('Y-m-d G:i:s T', $value['timestamp']),
            );

            Inbound_Events::store_search_event($args);
            error_log('stored');
        }

        wp_send_json(array('success' => __('Searches successfully stored!', 'inbound-pro')));

    }
}

new Leads_Tracking;
Inbound Pro Plugin - PHP Codex API documentation generated by ApiGen