Priority File Manager

Base Directory:
/home/lvabrwqv/public_html/wp-content/plugins/elementor/includes
NameTypeSizeActions
📁 .. Folder -
📁 admin-templates Folder -
📄 api.php File 8813
Edit Download
📄 autoloader.php File 10022
Edit Download
📁 base Folder -
📄 beta-testers.php File 3059
Edit Download
📄 compatibility.php File 11221
Edit Download
📄 conditions.php File 2768
Edit Download
📁 controls Folder -
📄 db.php File 16276
Edit Download
📄 editor-assets-api.php File 1807
Edit Download
📁 editor-templates Folder -
📁 elements Folder -
📄 embed.php File 8679
Edit Download
📄 fonts.php File 64029
Edit Download
📄 frontend.php File 40070
Edit Download
📄 heartbeat.php File 2635
Edit Download
📁 interfaces Folder -
📁 libraries Folder -
📄 maintenance-mode.php File 11426
Edit Download
📄 maintenance.php File 2881
Edit Download
📁 managers Folder -
📄 plugin.php File 15979
Edit Download
📄 preview.php File 7874
Edit Download
📄 rollback.php File 4255
Edit Download
📁 settings Folder -
📄 shapes.php File 7999
Edit Download
📄 stylesheet.php File 9124
Edit Download
📁 template-library Folder -
📄 tracker.php File 17407
Edit Download
📄 user-data.php File 3522
Edit Download
📄 user.php File 10230
Edit Download
📄 utils.php File 24930
Edit Download
📁 widgets Folder -

View File: heartbeat.php

<?php
namespace Elementor;

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}

/**
 * Elementor heartbeat.
 *
 * Elementor heartbeat handler class is responsible for initializing Elementor
 * heartbeat. The class communicates with WordPress Heartbeat API while working
 * with Elementor.
 *
 * @since 1.0.0
 */
class Heartbeat {

	/**
	 * Heartbeat received.
	 *
	 * Locks the Heartbeat response received when editing with Elementor.
	 *
	 * Fired by `heartbeat_received` filter.
	 *
	 * @since 1.0.0
	 * @access public
	 *
	 * @param array $response The Heartbeat response.
	 * @param array $data     The `$_POST` data sent.
	 *
	 * @return array Heartbeat response received.
	 */
	public function heartbeat_received( $response, $data ) {
		if ( isset( $data['elementor_post_lock']['post_ID'] ) ) {
			$post_id = $data['elementor_post_lock']['post_ID'];
			$locked_user = Plugin::$instance->editor->get_locked_user( $post_id );

			if ( ! $locked_user || ! empty( $data['elementor_force_post_lock'] ) ) {
				Plugin::$instance->editor->lock_post( $post_id );
			} else {
				$response['locked_user'] = $locked_user->display_name;
			}

			/** @var Core\Common\Modules\Ajax\Module $ajax */
			$ajax = Plugin::$instance->common->get_component( 'ajax' );

			$response['elementorNonce'] = $ajax->create_nonce();
		}
		return $response;
	}

	/**
	 * Refresh nonces.
	 *
	 * Filter the nonces to send to the editor when editing with Elementor. Used
	 * to refresh the nonce when the nonce expires while editing. This way the
	 * user doesn't need to log-in again as Elementor fetches the new nonce from
	 * the server using ajax.
	 *
	 * Fired by `wp_refresh_nonces` filter.
	 *
	 * @since 1.8.0
	 * @access public
	 *
	 * @param array $response The no-priv Heartbeat response object or array.
	 * @param array $data     The `$_POST` data sent.
	 *
	 * @return array Refreshed nonces.
	 */
	public function refresh_nonces( $response, $data ) {
		if ( isset( $data['elementor_post_lock']['post_ID'] ) ) {
			/** @var Core\Common\Modules\Ajax\Module $ajax */
			$ajax = Plugin::$instance->common->get_component( 'ajax' );

			$response['elementor-refresh-nonces'] = [
				'elementorNonce' => $ajax->create_nonce(),
				'heartbeatNonce' => wp_create_nonce( 'heartbeat-nonce' ),
			];
		}

		return $response;
	}

	/**
	 * Heartbeat constructor.
	 *
	 * Initializing Elementor heartbeat.
	 *
	 * @since 1.0.0
	 * @access public
	 */
	public function __construct() {
		add_filter( 'heartbeat_received', [ $this, 'heartbeat_received' ], 10, 2 );
		add_filter( 'wp_refresh_nonces', [ $this, 'refresh_nonces' ], 30, 2 );
	}
}