<?php
/**
* CPT data controller class
*/
// If this file is called directly, abort.
if ( ! defined( 'WPINC' ) ) {
die;
}
if ( ! class_exists( 'Jet_Engine_CPT_Tax_Data' ) ) {
/**
* Define Jet_Engine_CPT_Tax_Data class
*/
class Jet_Engine_CPT_Tax_Data extends Jet_Engine_Base_Data {
/**
* Table name
*
* @var string
*/
public $table = 'taxonomies';
/**
* Table format
*
* @var string
*/
public $table_format = array( '%s', '%s', '%s', '%s', '%s', '%s' );
/**
* Edit slug
*
* @var string
*/
public $edit = 'edit-tax';
/**
* Sanitizr post type request
*
* @return void
*/
public function sanitize_item_request() {
$valid = true;
$request = $this->request;
if ( empty( $request['slug'] ) ) {
$valid = false;
$this->cpt->add_notice(
'error',
__( 'Please set taxonomy slug', 'jet-engine' )
);
}
if ( empty( $request['slug'] ) ) {
$valid = false;
$this->cpt->add_notice(
'error',
__( 'Please set taxonomy name', 'jet-engine' )
);
}
if ( empty( $request['object_type'] ) ) {
$valid = false;
$this->cpt->add_notice(
'error',
__( 'Please set post type for taxonomy', 'jet-engine' )
);
}
if ( isset( $request['slug'] ) && in_array( $request['slug'], $this->items_blacklist() ) ) {
$valid = false;
$this->cpt->add_notice(
'error',
__( 'Please change taxonomy slug. Current is reserved for WordPress needs', 'jet-engine' )
);
}
return $valid;
}
/**
* Returns blacklisted post types slugs
*
* @return array
*/
public function items_blacklist() {
return array(
'attachment',
'attachment_id',
'author',
'author_name',
'calendar',
'cat',
'category',
'category__and',
'category__in',
'category__not_in',
'category_name',
'comments_per_page',
'comments_popup',
'customize_messenger_channel',
'customized',
'cpage',
'day',
'debug',
'error',
'exact',
'feed',
'fields',
'hour',
'link_category',
'm',
'minute',
'monthnum',
'more',
'name',
'nav_menu',
'nonce',
'nopaging',
'offset',
'order',
'orderby',
'p',
'page',
'page_id',
'paged',
'pagename',
'pb',
'perm',
'post',
'post__in',
'post__not_in',
'post_format',
'post_mime_type',
'post_status',
'post_tag',
'post_type',
'posts',
'posts_per_archive_page',
'posts_per_page',
'preview',
'robots',
's',
'search',
'second',
'sentence',
'showposts',
'static',
'subpost',
'subpost_id',
'tag',
'tag__and',
'tag__in',
'tag__not_in',
'tag_id',
'tag_slug__and',
'tag_slug__in',
'taxonomy',
'tb',
'term',
'theme',
'type',
'w',
'withcomments',
'withoutcomments',
'year',
'content',
);
}
/**
* Returns blacklisted post types slugs
*
* @return array
*/
public function meta_blacklist() {
return array(
'action',
'screen',
'taxonomy',
'action',
'post_type',
'_wp_http_referer',
'tag-name',
'slug',
'description',
);
}
/**
* Prepare post data from request to write into database
*
* @return array
*/
public function sanitize_item_from_request() {
$request = $this->request;
$result = array(
'slug' => '',
'status' => 'publish',
'labels' => array(),
'args' => array(),
'meta_fields' => array(),
);
$slug = ! empty( $request['slug'] ) ? $this->sanitize_slug( $request['slug'] ) : false;
$name = ! empty( $request['name'] ) ? sanitize_text_field( $request['name'] ) : false;
if ( ! $slug ) {
return false;
}
$labels = array(
'name' => $name,
);
$labels_list = array(
'name',
'singular_name',
'menu_name',
'all_items',
'edit_item',
'view_item',
'update_item',
'add_new_item',
'new_item_name',
'parent_item',
'parent_item_colon',
'search_items',
'popular_items',
'separate_items_with_commas',
'add_or_remove_items',
'choose_from_most_used',
'not_found',
);
foreach ( $labels_list as $label_key ) {
if ( ! empty( $request[ $label_key ] ) ) {
$labels[ $label_key ] = $request[ $label_key ];
}
}
$args = array();
$ensure_bool = array(
'public',
'publicly_queryable',
'show_ui',
'show_in_menu',
'show_in_nav_menus',
'show_in_rest',
'query_var',
'rewrite',
'hierarchical',
'with_front',
'show_edit_link',
);
foreach ( $ensure_bool as $key ) {
$args[ $key ] = ! empty( $request[ $key ] )
? filter_var( $request[ $key ], FILTER_VALIDATE_BOOLEAN )
: false;
}
$regular_args = array(
'rewrite_slug' => $slug,
'capability_type' => '',
);
foreach ( $regular_args as $key => $default ) {
$args[ $key ] = ! empty( $request[ $key ] ) ? $request[ $key ] : $default;
}
/**
* @todo Validate meta fields before saving - ensure that used correct types and all names was set.
*/
$meta_fields = ! empty( $request['meta_fields'] ) ? $request['meta_fields'] : array();
$result['slug'] = $slug;
$result['object_type'] = $request['object_type'];
$result['labels'] = $labels;
$result['args'] = $args;
$result['meta_fields'] = $this->sanitize_meta_fields( $meta_fields );
return $result;
}
/**
* Filter post type for register
*
* @return array
*/
public function filter_item_for_register( $item ) {
$result = array();
$args = maybe_unserialize( $item['args'] );
$item['labels'] = maybe_unserialize( $item['labels'] );
$item['meta_fields'] = maybe_unserialize( $item['meta_fields'] );
$item['object_type'] = maybe_unserialize( $item['object_type'] );
$result = array_merge( $item, $args );
if ( false !== $result['rewrite'] ) {
$with_front = isset( $result['with_front'] ) ? $result['with_front'] : true;
$with_front = filter_var( $with_front, FILTER_VALIDATE_BOOLEAN );
$result['rewrite'] = array(
'slug' => $result['rewrite_slug'],
'with_front' => $with_front,
);
unset( $result['rewrite_slug'] );
}
unset( $result['args'] );
unset( $result['status'] );
return $result;
}
/**
* Filter post type for edit
*
* @return array
*/
public function filter_item_for_edit( $item ) {
$result = array(
'general_settings' => array(),
'labels' => array(),
'advanced_settings' => array(),
'meta_fields' => array(),
);
$args = maybe_unserialize( $item['args'] );
$labels = maybe_unserialize( $item['labels'] );
$object_type = maybe_unserialize( $item['object_type'] );
$name = ! empty( $labels['name'] ) ? $labels['name'] : '';
$result['general_settings'] = array(
'name' => $name,
'slug' => $item['slug'],
'object_type' => $object_type,
'show_edit_link' => isset( $args['show_edit_link'] ) ? $args['show_edit_link'] : false,
);
$meta_fields = array();
if ( ! empty( $item['meta_fields'] ) ) {
$meta_fields = maybe_unserialize( $item['meta_fields'] );
$meta_fields = array_values( $meta_fields );
if ( jet_engine()->meta_boxes ) {
$meta_fields = jet_engine()->meta_boxes->data->sanitize_repeater_fields( $meta_fields );
}
}
$with_front = isset( $args['with_front'] ) ? $args['with_front'] : true;
$with_front = filter_var( $with_front, FILTER_VALIDATE_BOOLEAN );
$args['with_front'] = $with_front;
$result['labels'] = $labels;
$result['advanced_settings'] = $args;
$result['meta_fields'] = $meta_fields;
if ( isset( $result['advanced_settings']['query_var'] ) && false === $result['advanced_settings']['query_var'] ) {
$result['advanced_settings']['query_var'] = '';
}
return $result;
}
/**
* Sanitize meta fields
*
* @param [type] $meta_fields [description]
* @return [type] [description]
*/
public function sanitize_meta_fields( $meta_fields ) {
foreach ( $meta_fields as $key => $field ) {
// If name is empty - create it from title, else - santize it
if ( empty( $field['name'] ) ) {
$field['name'] = $this->sanitize_slug( $field['title'] );
} else {
$field['name'] = $this->sanitize_slug( $field['name'] );
}
// If still empty - create random name
if ( empty( $field['name'] ) ) {
$field['name'] = '_field_' . rand( 10000, 99999 );
}
// If name in blak list - add underscore at start
if ( in_array( $field['name'], $this->meta_blacklist() ) ) {
$meta_fields[ $key ]['name'] = '_' . $field['name'];
} else {
$meta_fields[ $key ]['name'] = $field['name'];
}
}
return $meta_fields;
}
/**
* Before item delete
*/
public function before_item_delete( $item_id ) {
$item = $this->get_item_for_edit( $item_id );
if ( ! $item ) {
return;
}
if ( empty( $item['advanced_settings']['capability_type'] ) ) {
return;
}
$cap = $item['advanced_settings']['capability_type'];
$this->remove_capability( $cap );
}
/**
* Before item update
*/
public function before_item_update( $item ) {
if ( empty( $item['id'] ) ) {
return;
}
$old_item = $this->get_item_for_edit( $item['id'] );
if ( ! $old_item ) {
return;
}
if ( empty( $old_item['advanced_settings']['capability_type'] ) ) {
return;
}
$old_cap = $old_item['advanced_settings']['capability_type'];
$new_cap = ! empty( $item['args']['capability_type'] ) ? $item['args']['capability_type'] : false;
if ( $old_cap === $new_cap ) {
return;
}
$this->remove_capability( $old_cap );
if ( $new_cap ) {
$this->add_capability( $new_cap );
}
}
public function after_item_update( $item, $is_new = false ) {
if ( ! $is_new ) {
return;
}
$new_cap = ! empty( $item['args']['capability_type'] ) ? $item['args']['capability_type'] : false;
if ( ! $new_cap ) {
return;
}
$this->add_capability( $new_cap );
}
public function add_capability( $cap ) {
$cap = 'manage_' . $cap;
global $wp_roles;
if ( ! class_exists( 'WP_Roles' ) ) {
return;
}
if ( ! isset( $wp_roles ) ) {
$wp_roles = new WP_Roles();
}
$wp_roles->add_cap( 'administrator', $cap );
$wp_roles->add_cap( 'editor', $cap );
}
public function remove_capability( $cap ) {
$cap = 'manage_' . $cap;
global $wp_roles;
if ( ! class_exists( 'WP_Roles' ) ) {
return;
}
if ( ! isset( $wp_roles ) ) {
$wp_roles = new WP_Roles();
}
$wp_roles->remove_cap( 'administrator', $cap );
$wp_roles->remove_cap( 'editor', $cap );
}
}
}