whoami7 - Manager
:
/
home
/
rattkxnv
/
knockdubai.ae
/
wp-content
/
plugins
/
the-post-grid
/
app
/
Controllers
/
Upload File:
files >> /home/rattkxnv/knockdubai.ae/wp-content/plugins/the-post-grid/app/Controllers/BlocksController.php
<?php namespace RT\ThePostGrid\Controllers; use RT\ThePostGrid\Controllers\Blocks\GridLayout; use RT\ThePostGrid\Controllers\Blocks\ListLayout; use RT\ThePostGrid\Controllers\Blocks\GridHoverLayout; use RT\ThePostGrid\Controllers\Blocks\SectionTitle; use RT\ThePostGrid\Controllers\Blocks\RttpgRow; use RT\ThePostGrid\Helpers\Fns; class BlocksController { /** * Css Handler to generate dynamic ss for guten blocks */ private $version; public function __construct() { // Layout initialize new GridLayout(); new ListLayout(); new GridHoverLayout(); new SectionTitle(); new RttpgRow(); $this->version = defined( 'WP_DEBUG' ) && WP_DEBUG ? time() : RT_THE_POST_GRID_VERSION; add_action( 'enqueue_block_editor_assets', [ $this, 'editor_assets' ] ); // All css/js file load in back-end and front-end add_action( 'wp_enqueue_scripts', [ $this, 'tpg_block_enqueue' ] ); add_action( 'enqueue_block_editor_assets', [ $this, 'tpg_block_enqueue' ] ); if ( version_compare( get_bloginfo( 'version' ), '5.8', '>=' ) ) { add_filter( 'block_categories_all', [ $this, 'rttpg_block_categories' ], 1, 2 ); } else { add_filter( 'block_categories', [ $this, 'rttpg_block_categories' ], 1, 2 ); } add_action( 'wp_ajax_rttpg_block_css_save', [ $this, 'save_block_css' ] ); add_action( 'wp_ajax_rttpg_block_css_get_posts', [ $this, 'get_posts_call' ] ); add_action( 'wp_ajax_rttpg_block_css_appended', [ $this, 'appended' ] ); add_action( 'wp_ajax_rttpg_get_layouts', [ $this, 'rttpg_get_layouts' ] ); add_action( 'wp_ajax_rttpg_guten_layout_count', [ $this, 'rttpg_guten_layout_count' ] ); // Decide how css file will be loaded. default filesystem eg: filesystem or at header $option_data = get_option( 'rttpg_options' ); if ( isset( $option_data['css_save_as'] ) && 'filesystem' === $option_data['css_save_as'] ) { add_action( 'wp_enqueue_scripts', [ $this, 'add_block_css_file' ] ); } else { add_action( 'wp_head', [ $this, 'add_block_inline_css' ], 100 ); } } public function rttpg_guten_layout_count() { $BASE_URL = 'https://www.radiustheme.com/demo/plugins/the-post-grid-gutenberg/wp-json/rttpgapi/v1/layoutinfo/'; // Verify the request. check_ajax_referer( 'rttpg_nonce', 'nonce' ); // It's good let's do some capability check. $user = wp_get_current_user(); $allowed_roles = [ 'editor', 'administrator', 'author' ]; if ( ! array_intersect( $allowed_roles, $user->roles ) ) { wp_die( esc_html__( 'You don\'t have permission to perform this action', 'the-post-grid' ) ); } // Cool, we're almost there, let's check the user authenticity a little bit, shall we! if ( ! is_user_logged_in() && $user->ID !== sanitize_text_field( $_REQUEST['user_id'] ) ) { wp_die( esc_html__( 'You don\'t have proper authorization to perform this action', 'the-post-grid' ) ); } $status = isset( $_REQUEST['status'] ) ? $_REQUEST['status'] : ''; $layout_id = isset( $_REQUEST['layout_id'] ) ? $_REQUEST['layout_id'] : ''; $post_args = [ 'timeout' => 120 ]; $post_args['body'] = [ 'status' => $status, 'layout_id' => $layout_id, ]; $layoutRequest = wp_remote_post( $BASE_URL, $post_args ); if ( is_wp_error( $layoutRequest ) ) { wp_send_json_error( [ 'messages' => $layoutRequest->get_error_messages() ] ); } $layoutData = json_decode( $layoutRequest['body'], true ); wp_send_json_success( $layoutData ); } /** * @return void */ public function rttpg_get_layouts() { $BASE_URL = 'https://www.radiustheme.com/demo/plugins/the-post-grid-gutenberg/wp-json/rttpgapi/v1/layouts/'; // Verify the request. check_ajax_referer( 'rttpg_nonce', 'nonce' ); // It's good let's do some capability check. $user = wp_get_current_user(); $allowed_roles = [ 'editor', 'administrator', 'author' ]; if ( ! array_intersect( $allowed_roles, $user->roles ) ) { wp_die( esc_html__( 'You don\'t have permission to perform this action', 'the-post-grid' ) ); } // Cool, we're almost there, let's check the user authenticity a little bit, shall we! if ( ! is_user_logged_in() && $user->ID !== sanitize_text_field( $_REQUEST['user_id'] ) ) { wp_die( esc_html__( 'You don\'t have proper authorization to perform this action', 'the-post-grid' ) ); } $status = isset( $_REQUEST['status'] ) ? $_REQUEST['status'] : ''; $post_args = [ 'timeout' => 120 ]; $post_args['body'] = [ 'status' => $status ]; $layoutRequest = wp_remote_post( $BASE_URL, $post_args ); if ( is_wp_error( $layoutRequest ) ) { wp_send_json_error( [ 'messages' => $layoutRequest->get_error_messages() ] ); } $layoutData = json_decode( $layoutRequest['body'], true ); wp_send_json_success( $layoutData ); } /** * Block Category Add * * @param $categories * @param $post * * @return array|\string[][]|\void[][] */ public function rttpg_block_categories( $categories, $post ) { return array_merge( [ [ 'slug' => 'rttpg', 'title' => __( 'The Post Grid', 'the-post-grid' ), ], ], $categories ); } /** * Add Block files foe css * * @return void */ public function add_block_css_file() { $post_id = get_the_ID(); $rttpg_upload_dir = wp_upload_dir()['basedir'] . '/rttpg/'; $rttpg_upload_url = wp_upload_dir()['baseurl'] . '/rttpg/'; // phpcs:ignore if ( isset( $_GET['preview'] ) && ! empty( $_GET['preview'] ) ) { $css_path = $rttpg_upload_dir . 'rttpg-block-preview.css'; if ( file_exists( $css_path ) ) { if ( ! $this->is_editor_screen() ) { wp_enqueue_style( 'rttpg-block-post-preview', $rttpg_upload_url . 'rttpg-block-preview.css', false, $this->version ); } } } elseif ( $post_id ) { $css_dir_path = $rttpg_upload_dir . "rttpg-block-$post_id.css"; $css_dir_url = $rttpg_upload_dir . "rttpg-block-$post_id.css"; if ( file_exists( $css_dir_path ) ) { if ( ! $this->is_editor_screen() ) { wp_enqueue_style( "rttpg-block-post-{$post_id}", $css_dir_url, false, $this->version ); } $this->add_reusable_css(); } else { // phpcs:ignore WordPress.WP.EnqueuedResourceParameters.MissingVersion wp_register_style( 'rttpg-post-data', false ); wp_enqueue_style( 'rttpg-post-data' ); wp_add_inline_style( 'rttpg-post-data', get_post_meta( get_the_ID(), '_rttpg_block_css', true ) ); } } } /** * Common css load * * @return void */ public function tpg_block_enqueue() { if ( ! is_admin() ) { return; } wp_enqueue_style( 'rt-fontawsome' ); wp_enqueue_style( 'rt-flaticon' ); wp_enqueue_style( 'rt-tpg-block' ); // Custom CSS From Settings $css = isset( $settings['custom_css'] ) ? stripslashes( $settings['custom_css'] ) : null; if ( $css ) { wp_add_inline_style( 'rt-tpg-block', $css ); } } /** * Determine if wppb editor is open * * @return bool * * @since V.1.0.0 * @since v.1.0.0 */ private function is_editor_screen() { //phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( ! empty( $_GET['action'] ) && 'wppb_editor' === $_GET['action'] ) { return true; } return false; } /** * Load Editor Assets * * @return void */ public function editor_assets() { // Block editor css wp_enqueue_style( 'rttpg-block-admin-css', rtTPG()->get_assets_uri( 'css/admin/block-admin.css' ), '', $this->version ); // Main compile css and js file wp_enqueue_style( 'rttpg-blocks-css', rtTPG()->get_assets_uri( 'blocks/main.css' ), '', $this->version ); wp_enqueue_script( 'rttpg-blocks-js', rtTPG()->get_assets_uri( 'blocks/main.js' ), [ 'wp-block-editor', 'wp-blocks', 'wp-components', 'wp-element', 'wp-i18n', ], $this->version, true ); global $pagenow; $editor_type = 'edit-post'; if ( 'site-editor.php' === $pagenow ) { $editor_type = 'edit-site'; } $get_tax_object = get_taxonomies( [], 'objects' ); $exclude_tax = Fns::get_excluded_taxonomy(); foreach ( $exclude_tax as $_tax ) { unset( $get_tax_object[ $_tax ] ); } $settings = get_option( rtTPG()->options['settings'] ); $ssList = ! empty( $settings['social_share_items'] ) ? $settings['social_share_items'] : []; $chatgpt_status = ! empty( $settings['chatgpt_status'] ) ? $settings['chatgpt_status'] : ''; wp_localize_script( 'rttpg-blocks-js', 'rttpgParams', [ 'editor_type' => $editor_type, 'nonce' => wp_create_nonce( 'rttpg_nonce' ), 'ajaxurl' => admin_url( 'admin-ajax.php' ), 'site_url' => site_url(), 'admin_url' => admin_url(), 'plugin_url' => RT_THE_POST_GRID_PLUGIN_URL, 'plugin_pro_url' => rtTPG()->getProPath(), 'post_type' => Fns::get_post_types(), 'all_term_list' => Fns::get_all_taxonomy_guten(), 'get_taxonomies' => $get_tax_object, 'get_users' => Fns::rt_get_users(), 'hasPro' => rtTPG()->hasPro(), 'pageTitle' => get_the_title(), 'hasWoo' => Fns::is_woocommerce(), 'hasAcf' => Fns::is_acf(), 'ssList' => $ssList, 'current_user_id' => get_current_user_id(), 'disableImportButton' => apply_filters( 'rttpg_disable_gutenberg_import_button', 'no' ), 'enableChatGPTButton' => $chatgpt_status ? 'yes' : 'no', 'iconFont' => Fns::tpg_option( 'tpg_icon_font' ), 'avatar' => esc_url( get_avatar_url( get_current_user_id() ) ), ] ); } /** * Add inLine css for page or post * * @return void */ public function add_block_inline_css() { $post_id = apply_filters( 'tpg_page_id_for_block_css', get_the_ID() ); if ( $post_id ) { $rttpg_upload_dir = wp_upload_dir()['basedir'] . '/rttpg/'; $css_dir_path = $rttpg_upload_dir . "rttpg-block-$post_id.css"; if ( file_exists( $css_dir_path ) ) { $blockCss = file_get_contents( $css_dir_path ); //phpcs:ignore WordPress.WP.AlternativeFunctions.file_get_contents_file_get_contents echo '<style>' . sanitize_textarea_field( $blockCss ) . '</style>'; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped } elseif ( $metaCss = get_post_meta( $post_id, '_rttpg_block_css', true ) ) { echo '<style>' . sanitize_textarea_field( $metaCss ) . '</style>'; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped } } $this->add_reusable_css(); } /** * Add reusable css */ public function add_reusable_css() { $post_id = get_the_ID(); $rttpg_upload_dir = wp_upload_dir()['basedir'] . '/rttpg/'; $rttpg_upload_url = wp_upload_dir()['baseurl'] . '/rttpg/'; if ( $post_id ) { $content_post = get_post( $post_id ); if ( isset( $content_post->post_content ) ) { $content = $content_post->post_content; $parse_blocks = parse_blocks( $content ); $css_id = $this->reference_id( $parse_blocks ); if ( is_array( $css_id ) ) { if ( ! empty( $css_id ) ) { $css_id = array_unique( $css_id ); foreach ( $css_id as $value ) { $css_dir_path = $rttpg_upload_dir . "rttpg-block-$value.css"; if ( file_exists( $css_dir_path ) ) { wp_enqueue_style( "rttpg-block-{$value}", $rttpg_upload_url . "rttpg-block-{$value}.css", false, RTTPG_VERSION ); } } } } } } } /** * Save Import CSS in the top of the File * * @return void Array of the Custom Message */ public function save_block_css() { try { if ( ! current_user_can( 'edit_others_posts' ) ) { throw new Exception( __( 'User permission error', 'the-post-grid' ) ); } check_ajax_referer( 'rttpg_nonce', 'nonce' ); global $wp_filesystem; if ( ! $wp_filesystem ) { require_once ABSPATH . 'wp-admin/includes/file.php'; } $post_id = ! empty( $_POST['post_id'] ) ? sanitize_text_field( $_POST['post_id'] ) : ''; $blockCss = ! empty( $_POST['block_css'] ) ? sanitize_text_field( $_POST['block_css'] ) : ''; if ( $post_id == 'rttpg-widget' && isset( $_POST['has_block'] ) ) { update_option( $post_id, $blockCss ); wp_send_json_success( [ 'message' => __( 'Widget CSS Saved', 'the-post-grid' ) ] ); } $post_id = absint( $post_id ); $filename = "rttpg-block-css-{$post_id}.css"; $upload_dir_url = wp_upload_dir(); $dir = trailingslashit( $upload_dir_url['basedir'] ) . 'rttpg/'; if ( ! empty( $_POST['has_block'] ) ) { update_post_meta( $post_id, '_rttpg_block_active', 1 ); $block_css = $this->set_top_css( $blockCss ); WP_Filesystem( false, $upload_dir_url['basedir'], true ); if ( ! $wp_filesystem->is_dir( $dir ) ) { $wp_filesystem->mkdir( $dir ); } if ( ! $wp_filesystem->put_contents( $dir . $filename, $block_css ) ) { wp_send_json_error( [ 'message' => __( 'CSS can not be saved due to permission!!!', 'the-post-grid' ) ] ); } update_post_meta( $post_id, '_rttpg_block_css', $block_css ); wp_send_json_success( [ 'message' => __( 'Css file has been updated', 'the-post-grid' ) ] ); } else { delete_post_meta( $post_id, '_rttpg_block_active' ); if ( file_exists( $dir . $filename ) ) { unlink( $dir . $filename ); //phpcs:ignore WordPress.WP.AlternativeFunctions.unlink_unlink } delete_post_meta( $post_id, '_rttpg_block_css' ); wp_send_json_success( [ 'message' => __( 'Data Delete Done', 'the-post-grid' ) ] ); } } catch ( Exception $e ) { wp_send_json_error( [ 'message' => $e->getMessage() ] ); } } /** * Save Import CSS in the top of the File * * @param STRING * * @return STRING * @since v.1.0.0 */ public function set_top_css( $get_css = '' ) { $css_url = "@import url('https://fonts.googleapis.com/css?family="; $font_exists = substr_count( $get_css, $css_url ); if ( $font_exists ) { $pattern = sprintf( '/%s(.+?)%s/ims', preg_quote( $css_url, '/' ), preg_quote( "');", '/' ) ); if ( preg_match_all( $pattern, $get_css, $matches ) ) { $fonts = $matches[0]; $get_css = str_replace( $fonts, '', $get_css ); if ( preg_match_all( '/font-weight[ ]?:[ ]?[\d]{3}[ ]?;/', $get_css, $matche_weight ) ) { $weight = array_map( function ( $val ) { $process = trim( str_replace( [ 'font-weight', ':', ';' ], '', $val ) ); if ( is_numeric( $process ) ) { return $process; } }, $matche_weight[0] ); foreach ( $fonts as $key => $val ) { $fonts[ $key ] = str_replace( "');", '', $val ) . ':' . implode( ',', $weight ) . "');"; } } $fonts = array_unique( $fonts ); $get_css = implode( '', $fonts ) . $get_css; } } return $get_css; } /** * Save Import CSS in the top of the File * * @return void */ public function get_posts_call() { if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_success( new WP_Error( 'rttpg_block_user_permission', __( 'User permission error', 'the-post-grid' ) ) ); } $post_id = absint( $_POST['postId'] ); check_ajax_referer( 'rttpg_nonce', 'nonce' ); if ( $post_id ) { wp_send_json_success( get_post( $post_id )->post_content ); } else { wp_send_json_error( new WP_Error( 'rttpg_block_data_not_found', __( 'Data not found!!', 'the-post-grid' ) ) ); } } /** * Save Import CSS in the top of the File * * @return void * @throws Exception * @since v.1.0.0 */ public function appended( $server ) { if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_success( new WP_Error( 'rttpg_block_user_permission', __( 'User permission error', 'the-post-grid' ) ) ); } check_ajax_referer( 'rttpg_nonce', 'nonce' ); global $wp_filesystem; if ( ! $wp_filesystem ) { require_once ABSPATH . 'wp-admin/includes/file.php'; } $post = $server->get_params(); $css = $post['inner_css']; $post_id = (int) sanitize_text_field( $post['post_id'] ); if ( $post_id ) { $upload_dir_url = wp_upload_dir(); $filename = "rttpg-block-css-$post_id.css"; $dir = trailingslashit( $upload_dir_url['basedir'] ) . 'rttpg/'; WP_Filesystem( false, $upload_dir_url['basedir'], true ); if ( ! $wp_filesystem->is_dir( $dir ) ) { $wp_filesystem->mkdir( $dir ); } if ( ! $wp_filesystem->put_contents( $dir . $filename, $css ) ) { wp_send_json_error( [ 'message' => __( 'CSS can not be saved due to permission!!!', 'the-post-grid' ) ] ); } wp_send_json_success( [ 'message' => __( 'Data retrieve done', 'the-post-grid' ) ] ); } else { wp_send_json_error( [ 'message' => __( 'Data not found!!', 'the-post-grid' ) ] ); } } /** * Return reference id * * @param array $parse_blocks * * @return bool */ public function reference_id( $parse_blocks ) { $extra_id = []; if ( ! empty( $parse_blocks ) ) { foreach ( $parse_blocks as $key => $block ) { if ( $block['blockName'] == 'core/block' ) { $extra_id[] = $block['attrs']['ref']; } if ( count( $block['innerBlocks'] ) > 0 ) { $extra_id = array_merge( $this->reference_id( $block['innerBlocks'] ), $extra_id ); } } } return $extra_id; } }
Copyright ©2021 || Defacer Indonesia