mirror of
https://github.com/proelements/proelements.git
synced 2026-04-17 17:42:19 +00:00
v3.33.1
This commit is contained in:
39
core/security/access-control.php
Normal file
39
core/security/access-control.php
Normal file
@@ -0,0 +1,39 @@
|
||||
<?php
|
||||
|
||||
namespace ElementorPro\Core\Security;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly
|
||||
}
|
||||
|
||||
class Access_Control {
|
||||
public static function user_can_edit( int $post_id ): bool {
|
||||
return current_user_can( Capability::EDIT_POST_META, $post_id );
|
||||
}
|
||||
|
||||
public static function user_can_edit_posts(): bool {
|
||||
return current_user_can( Capability::EDIT_POSTS );
|
||||
}
|
||||
|
||||
public static function user_can_access_private_posts(): bool {
|
||||
return current_user_can( Capability::READ_PRIVATE_POSTS );
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \Exception
|
||||
*/
|
||||
public static function verify_post_edit_access( int $post_id ): void {
|
||||
if ( ! self::user_can_edit( $post_id ) ) {
|
||||
throw new \Exception( 'You do not have permission to edit this post.' );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \Exception
|
||||
*/
|
||||
public static function verify_user_editing_capability(): void {
|
||||
if ( ! self::user_can_edit_posts() ) {
|
||||
throw new \Exception( 'Access denied: User does not have editing capabilities.' );
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user