File "class-admin.php"
Full Path: /home/elegucvf/public_html/video/wp-content/wp-includes/wp-content/plugins/post-views-counter/includes/class-admin.php
File size: 5.7 KB
MIME-type: text/x-php
Charset: utf-8
<?php
// exit if accessed directly
if ( ! defined( 'ABSPATH' ) )
exit;
/**
* Post_Views_Counter_Admin class.
*
* @class Post_Views_Counter_Admin
*/
class Post_Views_Counter_Admin {
/**
* Class constructor.
*
* @return void
*/
public function __construct() {
// actions
add_action( 'plugins_loaded', [ $this, 'init_block_editor' ] );
add_action( 'admin_enqueue_scripts', [ $this, 'register_chartjs' ], 9 );
}
/**
* Register Chart.js.
*
* @return void
*/
public function register_chartjs() {
wp_register_script( 'pvc-chartjs', POST_VIEWS_COUNTER_URL . '/assets/chartjs/chart.min.js', [ 'jquery' ], '4.4.8', true );
}
/**
* Init block editor actions.
*
* @return void
*/
public function init_block_editor() {
add_action( 'rest_api_init', [ $this, 'block_editor_rest_api_init' ] );
add_action( 'enqueue_block_editor_assets', [ $this, 'block_editor_enqueue_scripts' ] );
}
/**
* Register REST API block editor endpoints.
*
* @return void
*/
public function block_editor_rest_api_init() {
// get views route
register_rest_route(
'post-views-counter',
'/update-post-views/',
[
'methods' => [ 'POST' ],
'callback' => [ $this, 'block_editor_update_callback' ],
'permission_callback' => [ $this, 'check_rest_route_permissions' ],
'args' => [
'id' => [
'sanitize_callback' => 'absint',
]
]
]
);
}
/**
* Check whether user has permissions to perform post views update in block editor.
*
* @param object $request WP_REST_Request
* @return bool|WP_Error
*/
public function check_rest_route_permissions( $request ) {
// break if current user can't edit this post
if ( ! current_user_can( 'edit_post', (int) $request->get_param( 'id' ) ) )
return new WP_Error( 'pvc-user-not-allowed', __( 'You are not allowed to edit this item.', 'post-views-counter' ) );
// break if views editing is restricted
if ( (bool) Post_Views_Counter()->options['general']['restrict_edit_views'] === true && ! current_user_can( apply_filters( 'pvc_restrict_edit_capability', 'manage_options' ) ) )
return new WP_Error( 'pvc-user-not-allowed', __( 'You are not allowed to edit this item.', 'post-views-counter' ) );
return true;
}
/**
* REST API callback for block editor endpoint.
*
* @param array $data
* @return string|int
*/
public function block_editor_update_callback( $data ) {
// get main instance
$pvc = Post_Views_Counter();
// cast post ID
$post_id = ! empty( $data['id'] ) ? (int) $data['id'] : 0;
// cast post views
$post_views = ! empty( $data['post_views'] ) ? (int) $data['post_views'] : 0;
// get countable post types
$post_types = $pvc->options['general']['post_types_count'];
// check if post exists
$post = get_post( $post_id );
// whether to count this post type or not
if ( empty( $post_types ) || empty( $post ) || ! in_array( $post->post_type, $post_types, true ) )
return wp_send_json_error( __( 'Invalid post ID.', 'post-views-counter' ) );
// break if current user can't edit this post
if ( ! current_user_can( 'edit_post', $post_id ) )
return wp_send_json_error( __( 'You are not allowed to edit this item.', 'post-views-counter' ) );
// break if views editing is restricted
if ( (bool) $pvc->options['general']['restrict_edit_views'] === true && ! current_user_can( apply_filters( 'pvc_restrict_edit_capability', 'manage_options' ) ) )
return wp_send_json_error( __( 'You are not allowed to edit this item.', 'post-views-counter' ) );
// update post views
pvc_update_post_views( $post_id, $post_views );
do_action( 'pvc_after_update_post_views_count', $post_id );
return $post_id;
}
/**
* Enqueue frontend and editor JavaScript and CSS.
*
* @global string $pagenow
* @global string $wp_version
*
* @return void
*/
public function block_editor_enqueue_scripts() {
global $pagenow, $wp_version;
// get main instance
$pvc = Post_Views_Counter();
// skip widgets and customizer pages
if ( $pagenow === 'widgets.php' || $pagenow === 'customize.php' )
return;
// enqueue the bundled block JS file
wp_enqueue_script( 'pvc-block-editor', POST_VIEWS_COUNTER_URL . '/js/block-editor.min.js', [ 'wp-element', 'wp-components', 'wp-edit-post', 'wp-data', 'wp-plugins' ], $pvc->defaults['version'] );
// restrict editing
$can_edit = false;
$restrict = (bool) $pvc->options['general']['restrict_edit_views'];
if ( $restrict === false || ( $restrict === true && current_user_can( apply_filters( 'pvc_restrict_edit_capability', 'manage_options' ) ) ) )
$can_edit = true;
// get total post views
$id = get_the_ID();
$count = pvc_get_post_views( $id );
// disable views display and editing?
if ( apply_filters( 'pvc_admin_display_views', true, $id ) === false ) {
$count = '—';
$can_edit = false;
}
// prepare script data
$script_data = [
'postID' => $id,
'postViews' => $count,
'canEdit' => $can_edit,
'nonce' => wp_create_nonce( 'wp_rest' ),
'wpGreater53' => version_compare( $wp_version, '5.3', '>=' ),
'textPostViews' => esc_html__( 'Post Views', 'post-views-counter' ),
'textHelp' => esc_html__( 'Adjust the views count for this post.', 'post-views-counter' ),
'textCancel' => esc_html__( 'Cancel', 'post-views-counter' )
];
wp_add_inline_script( 'pvc-block-editor', 'var pvcEditorArgs = ' . wp_json_encode( $script_data ) . ";\n", 'before' );
// enqueue frontend and editor block styles
wp_enqueue_style( 'pvc-block-editor', POST_VIEWS_COUNTER_URL . '/css/block-editor.min.css', '', $pvc->defaults['version'] );
}
}