Edit File by line
/home/zeestwma/ceyloniy.../wp-conte.../plugins/elemento.../modules/componen...
File: document-lock-manager.php
<?php
[0] Fix | Delete
namespace Elementor\Modules\Components;
[1] Fix | Delete
[2] Fix | Delete
if ( ! defined( 'ABSPATH' ) ) {
[3] Fix | Delete
exit; // Exit if accessed directly.
[4] Fix | Delete
}
[5] Fix | Delete
[6] Fix | Delete
/**
[7] Fix | Delete
* Manages document locking for Elementor documents.
[8] Fix | Delete
*
[9] Fix | Delete
* This class handles locking/unlocking documents to prevent multiple users
[10] Fix | Delete
* from editing the same document simultaneously.
[11] Fix | Delete
*/
[12] Fix | Delete
class Document_Lock_Manager {
[13] Fix | Delete
// 5 minutes
[14] Fix | Delete
const DEFAULT_TIME = 60 * 5;
[15] Fix | Delete
[16] Fix | Delete
private $lock_duration;
[17] Fix | Delete
private const LOCK_USER_META = '_lock_user';
[18] Fix | Delete
private const LOCK_TIME_META = '_lock_time';
[19] Fix | Delete
private const LOCK_EDIT_LOCK_META = '_edit_lock';
[20] Fix | Delete
[21] Fix | Delete
/**
[22] Fix | Delete
* Initialize the lock manager.
[23] Fix | Delete
*
[24] Fix | Delete
* @param int $lock_duration Lock duration in seconds (default: 300 = 5 minutes)
[25] Fix | Delete
*/
[26] Fix | Delete
public function __construct( $lock_duration = self::DEFAULT_TIME ) {
[27] Fix | Delete
$this->lock_duration = $lock_duration;
[28] Fix | Delete
}
[29] Fix | Delete
[30] Fix | Delete
/**
[31] Fix | Delete
* Lock a document for the current user.
[32] Fix | Delete
*
[33] Fix | Delete
* @param int $document_id The document ID to lock
[34] Fix | Delete
* @return bool True if lock was successful, false otherwise
[35] Fix | Delete
*/
[36] Fix | Delete
public function lock( $document_id ) {
[37] Fix | Delete
try {
[38] Fix | Delete
$user_id = get_current_user_id();
[39] Fix | Delete
if ( ! $user_id ) {
[40] Fix | Delete
return false;
[41] Fix | Delete
}
[42] Fix | Delete
[43] Fix | Delete
$post = get_post( $document_id );
[44] Fix | Delete
if ( ! $post ) {
[45] Fix | Delete
return false;
[46] Fix | Delete
}
[47] Fix | Delete
[48] Fix | Delete
if ( $this->is_lock_expired( $document_id ) ) {
[49] Fix | Delete
$this->unlock( $document_id );
[50] Fix | Delete
}
[51] Fix | Delete
[52] Fix | Delete
$existing_lock = $this->get_lock_data( $document_id );
[53] Fix | Delete
if ( $existing_lock['locked_by'] ) {
[54] Fix | Delete
return false;
[55] Fix | Delete
}
[56] Fix | Delete
[57] Fix | Delete
update_post_meta( $document_id, self::LOCK_USER_META, $user_id );
[58] Fix | Delete
update_post_meta( $document_id, self::LOCK_TIME_META, time() );
[59] Fix | Delete
[60] Fix | Delete
if ( ! function_exists( 'wp_set_post_lock' ) ) {
[61] Fix | Delete
require_once ABSPATH . 'wp-admin/includes/post.php';
[62] Fix | Delete
}
[63] Fix | Delete
[64] Fix | Delete
wp_set_post_lock( $document_id );
[65] Fix | Delete
[66] Fix | Delete
return true;
[67] Fix | Delete
} catch ( \Exception $e ) {
[68] Fix | Delete
error_log( 'Document lock error: ' . $e->getMessage() );
[69] Fix | Delete
return false;
[70] Fix | Delete
}
[71] Fix | Delete
}
[72] Fix | Delete
[73] Fix | Delete
/**
[74] Fix | Delete
* Unlock a document.
[75] Fix | Delete
*
[76] Fix | Delete
* @param int $document_id The document ID to unlock
[77] Fix | Delete
* @return bool True if unlock was successful, false otherwise
[78] Fix | Delete
*/
[79] Fix | Delete
public function unlock( $document_id ) {
[80] Fix | Delete
try {
[81] Fix | Delete
[82] Fix | Delete
delete_post_meta( $document_id, self::LOCK_USER_META );
[83] Fix | Delete
delete_post_meta( $document_id, self::LOCK_TIME_META );
[84] Fix | Delete
delete_post_meta( $document_id, self::LOCK_EDIT_LOCK_META );
[85] Fix | Delete
[86] Fix | Delete
return true;
[87] Fix | Delete
} catch ( \Exception $e ) {
[88] Fix | Delete
error_log( 'Document unlock error: ' . $e->getMessage() );
[89] Fix | Delete
return false;
[90] Fix | Delete
}
[91] Fix | Delete
}
[92] Fix | Delete
[93] Fix | Delete
/**
[94] Fix | Delete
* Check if a document is currently locked.
[95] Fix | Delete
*
[96] Fix | Delete
* @param int $document_id The document ID to check
[97] Fix | Delete
* @return array Lock data with 'locked_by' (int|null), 'locked_at' (int|null)
[98] Fix | Delete
*/
[99] Fix | Delete
public function get_lock_data( $document_id ) {
[100] Fix | Delete
$locked_by = $this->get_document_lock_user( $document_id );
[101] Fix | Delete
$locked_at = $this->get_document_lock_time( $document_id );
[102] Fix | Delete
[103] Fix | Delete
return [
[104] Fix | Delete
'locked_by' => $locked_by,
[105] Fix | Delete
'locked_at' => $locked_at,
[106] Fix | Delete
];
[107] Fix | Delete
}
[108] Fix | Delete
[109] Fix | Delete
/**
[110] Fix | Delete
* Check if a document lock has expired.
[111] Fix | Delete
*
[112] Fix | Delete
* @param int $document_id The document ID to check
[113] Fix | Delete
* @return bool True if lock exists and is expired, false if not locked or not expired
[114] Fix | Delete
*/
[115] Fix | Delete
public function is_lock_expired( $document_id ) {
[116] Fix | Delete
$lock_data = $this->get_lock_data( $document_id );
[117] Fix | Delete
if ( ! $lock_data['locked_by'] ) {
[118] Fix | Delete
return false;
[119] Fix | Delete
}
[120] Fix | Delete
[121] Fix | Delete
return $lock_data['locked_at'] && (int) $lock_data['locked_at'] + $this->lock_duration <= time();
[122] Fix | Delete
}
[123] Fix | Delete
[124] Fix | Delete
/**
[125] Fix | Delete
* Extend the lock for a document.
[126] Fix | Delete
*
[127] Fix | Delete
* @param int $document_id The document ID
[128] Fix | Delete
* @return bool True if extended successfully, false if not locked or locked by another user
[129] Fix | Delete
*/
[130] Fix | Delete
public function extend_lock( $document_id ) {
[131] Fix | Delete
$lock_data = $this->get_lock_data( $document_id );
[132] Fix | Delete
if ( ! $lock_data['locked_by'] ) {
[133] Fix | Delete
return false;
[134] Fix | Delete
}
[135] Fix | Delete
[136] Fix | Delete
$current_user_id = get_current_user_id();
[137] Fix | Delete
if ( (int) $lock_data['locked_by'] !== (int) $current_user_id ) {
[138] Fix | Delete
return false;
[139] Fix | Delete
}
[140] Fix | Delete
[141] Fix | Delete
update_post_meta( $document_id, self::LOCK_TIME_META, time() );
[142] Fix | Delete
return true;
[143] Fix | Delete
}
[144] Fix | Delete
[145] Fix | Delete
public function get_document_lock_user( $document_id ) {
[146] Fix | Delete
$lock_user_meta = get_post_meta( $document_id, self::LOCK_USER_META, true );
[147] Fix | Delete
if ( $lock_user_meta ) {
[148] Fix | Delete
return (int) $lock_user_meta;
[149] Fix | Delete
}
[150] Fix | Delete
[151] Fix | Delete
if ( ! function_exists( 'wp_check_post_lock' ) ) {
[152] Fix | Delete
require_once ABSPATH . 'wp-admin/includes/post.php';
[153] Fix | Delete
}
[154] Fix | Delete
[155] Fix | Delete
$wp_lock_user = wp_check_post_lock( $document_id );
[156] Fix | Delete
return $wp_lock_user ? (int) $wp_lock_user : null;
[157] Fix | Delete
}
[158] Fix | Delete
[159] Fix | Delete
/**
[160] Fix | Delete
* Get the lock time of a document.
[161] Fix | Delete
*
[162] Fix | Delete
* @param int $document_id The document ID to check
[163] Fix | Delete
* @return int|null Lock time, or null if not locked
[164] Fix | Delete
*/
[165] Fix | Delete
public function get_document_lock_time( $document_id ) {
[166] Fix | Delete
$lock_time = get_post_meta( $document_id, self::LOCK_TIME_META, true );
[167] Fix | Delete
if ( $lock_time ) {
[168] Fix | Delete
return (int) $lock_time;
[169] Fix | Delete
}
[170] Fix | Delete
[171] Fix | Delete
return null;
[172] Fix | Delete
}
[173] Fix | Delete
}
[174] Fix | Delete
[175] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function