當前位置: 首頁>>代碼示例>>PHP>>正文


PHP is_content_administrator_rs函數代碼示例

本文整理匯總了PHP中is_content_administrator_rs函數的典型用法代碼示例。如果您正苦於以下問題:PHP is_content_administrator_rs函數的具體用法?PHP is_content_administrator_rs怎麽用?PHP is_content_administrator_rs使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了is_content_administrator_rs函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: flt_sticky_posts

 function flt_sticky_posts($post_ids)
 {
     if ($post_ids && !is_content_administrator_rs()) {
         global $wpdb;
         $post_ids = scoper_get_col(apply_filters('objects_request_rs', "SELECT ID FROM {$wpdb->posts} WHERE ID IN ('" . implode("','", $post_ids) . "')", 'post'));
     }
     return $post_ids;
 }
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:8,代碼來源:query-interceptor-front_rs.php

示例2: flt_recent_comments

 function flt_recent_comments($query)
 {
     // Due to missing get_comments hook prior to WP 3.1, this filter operates on every front-end query.
     // If query doesn't pertain to comments, skip out with as little overhead as possible.
     if (strpos($query, 'comment') && strpos($query, "ELECT") && !strpos($query, 'posts as parent') && !strpos($query, "COUNT") && strpos($query, "comment_approved")) {
         if (!is_attachment() && !is_content_administrator_rs()) {
             global $wpdb;
             if (strpos($query, " {$wpdb->posts} ")) {
                 return $query;
             }
             if (awp_is_plugin_active('wp-wall')) {
                 $options = WPWall_GetOptions();
                 if (strpos($query, 'comment_post_ID=' . $options['pageId'])) {
                     return $query;
                 }
             }
             if (strpos($query, $wpdb->comments)) {
                 $query = str_replace(" post_status = 'publish'", " {$wpdb->posts}.post_status = 'publish'", $query);
                 // theoretically, a slight performance enhancement if we can simplify the query to skip filtering of attachment comments
                 if (defined('SCOPER_NO_ATTACHMENT_COMMENTS') || false !== strpos($query, 'comment_post_ID =')) {
                     if (!strpos($query, "JOIN {$wpdb->posts}")) {
                         $query = preg_replace("/FROM\\s*{$wpdb->comments}\\s*WHERE /", "FROM {$wpdb->comments} INNER JOIN {$wpdb->posts} ON {$wpdb->posts}.ID = {$wpdb->comments}.comment_post_ID WHERE ", $query);
                     }
                     $query = apply_filters('objects_request_rs', $query, 'post', '', array('skip_teaser' => true));
                 } else {
                     $query = str_replace("user_id ", "{$wpdb->comments}.user_id ", $query);
                     $query = str_replace("SELECT {$wpdb->comments}.* FROM {$wpdb->comments}", "SELECT DISTINCT {$wpdb->comments}.* FROM {$wpdb->comments}", $query);
                     if (!strpos($query, ' DISTINCT ')) {
                         $query = str_replace("SELECT ", "SELECT DISTINCT ", $query);
                     }
                     $post_types = array_diff(get_post_types(array('public' => true)), array('attachment'));
                     $post_type_in = "'" . implode("','", $post_types) . "'";
                     $join = "LEFT JOIN {$wpdb->posts} as parent ON parent.ID = {$wpdb->posts}.post_parent AND parent.post_type IN ({$post_type_in}) AND {$wpdb->posts}.post_type = 'attachment'";
                     $use_post_types = scoper_get_option('use_post_types');
                     $where = array();
                     foreach ($post_types as $type) {
                         if (!empty($use_post_types[$type])) {
                             $where_post = apply_filters('objects_where_rs', '', 'post', $type, array('skip_teaser' => true));
                         } else {
                             $where_post = "AND 1=1";
                         }
                         $where[] = "{$wpdb->posts}.post_type = '{$type}' {$where_post}";
                         $where[] = "{$wpdb->posts}.post_type = 'attachment' AND parent.post_type = '{$type}' " . str_replace("{$wpdb->posts}.", "parent.", $where_post);
                     }
                     $where = agp_implode(' ) OR ( ', $where, ' ( ', ' ) ');
                     if (!strpos($query, "JOIN {$wpdb->posts}")) {
                         $query = str_replace("WHERE ", "INNER JOIN {$wpdb->posts} ON {$wpdb->posts}.ID = {$wpdb->comments}.comment_post_ID {$join} WHERE ( {$where} ) AND ", $query);
                     } else {
                         $query = str_replace("WHERE ", "{$join} WHERE {$where} AND ", $query);
                     }
                 }
             }
         }
     }
     return $query;
 }
開發者ID:Netsoro,項目名稱:gdnlteamgroup,代碼行數:56,代碼來源:hardway-front-legacy_rs.php

示例3: user_can_admin_object_rs

function user_can_admin_object_rs($src_name, $object_type, $object_id = false, $any_obj_role_check = false, $user = '')
{
    if (is_content_administrator_rs()) {
        return true;
    }
    global $scoper;
    // TODO: is this necessary?
    $is_new_object = !$object_id && false !== $object_id || 'post' == $src_name && !empty($GLOBALS['post']) && 'auto-draft' == $GLOBALS['post']->post_status;
    if ($is_new_object) {
        $status_name = 'post' == $src_name ? 'draft' : '';
    } else {
        $status_name = sanitize_key($scoper->data_sources->detect('status', $src_name, $object_id));
    }
    // TODO: is multi-value array ever passed?
    if (is_array($object_type)) {
        if (count($object_type) == 1) {
            $object_type = reset($object_type);
        } else {
            // only WP roles should ever have multiple sources / otypes
            $object_type = $scoper->data_sources->get_from_db('type', $src_name, $object_id);
        }
    }
    $base_caps_only = $is_new_object;
    // Possible TODO: re-implement OP_ADMIN distinction with admin-specific capabilities
    //$admin_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_ADMIN_RS, $status_name, $base_caps_only);
    $admin_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_EDIT_RS, $status_name, $base_caps_only);
    $delete_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_DELETE_RS, $status_name, $base_caps_only);
    $reqd_caps = array_merge(array_keys($admin_caps), array_keys($delete_caps));
    if (!$reqd_caps) {
        return true;
    }
    // apparantly this src/otype has no admin caps, so no restriction to apply
    // Note on 'require_full_object_role' argument:
    // Normally we want to disregard "others" cap requirements if a role is assigned directly for an object
    // This is an exception - we need to retain a "delete_others" cap requirement in case it is the
    // distinguishing cap of an object administrator
    $return = cr_user_can($reqd_caps, $object_id, 0, array('require_full_object_role' => true, 'skip_revision_allowance' => true));
    if (!$return && !$object_id && $any_obj_role_check) {
        // No object ID was specified, and current user does not have the cap blog-wide.  Credit user for capability on any individual object.
        // Possible TODO: re-implement OP_ADMIN distinction with admin-specific capabilities
        //$admin_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_ADMIN_RS, STATUS_ANY_RS);
        $admin_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_EDIT_RS, STATUS_ANY_RS);
        $delete_caps = $scoper->cap_defs->get_matching($src_name, $object_type, OP_DELETE_RS, STATUS_ANY_RS);
        if ($reqd_caps = array_merge(array_keys($admin_caps), array_keys($delete_caps))) {
            if (!defined('DISABLE_QUERYFILTERS_RS')) {
                global $cap_interceptor;
                if ($cap_interceptor->user_can_for_any_object($reqd_caps)) {
                    $return = true;
                }
            }
        }
    }
    return $return;
}
開發者ID:btj,項目名稱:cscircles-wp-content,代碼行數:54,代碼來源:permission_lib_rs.php

示例4: act_attachment_access

 function act_attachment_access()
 {
     if (is_admin() || defined('DISABLE_QUERYFILTERS_RS') || is_content_administrator_rs() || !scoper_get_option('file_filtering')) {
         return;
     }
     // if ( is_attachment() ) {  as of WP 2.6, is_attachment() returns false for custom permalink attachment URL
     if (is_attachment_rs()) {
         //rs_errlog( 'IS an attachment:' );
         require_once dirname(__FILE__) . '/attachment-template_rs.php';
         AttachmentTemplate_RS::attachment_access();
     }
 }
開發者ID:Netsoro,項目名稱:gdnlteamgroup,代碼行數:12,代碼來源:attachment-interceptor_rs.php

示例5: flt_comments_clauses

 function flt_comments_clauses($clauses, &$qry_obj)
 {
     global $wpdb;
     if (is_content_administrator_rs()) {
         $stati = array_merge(get_post_stati(array('public' => true)), get_post_stati(array('private' => true)));
         if (!defined('SCOPER_NO_ATTACHMENT_COMMENTS')) {
             $stati[] = 'inherit';
         }
         $status_csv = "'" . implode("','", $stati) . "'";
         $clauses['where'] = preg_replace("/\\s*AND\\s*{$wpdb->posts}.post_status\\s*=\\s*[']?publish[']?/", "AND {$wpdb->posts}.post_status IN ({$status_csv})", $clauses['where']);
     }
     return $clauses;
 }
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:13,代碼來源:comments-int-administrator_rs.php

示例6: _validate_assigner_roles

 function _validate_assigner_roles($scope, $src_or_tx_name, $item_id, $roles)
 {
     if (!$item_id && !is_user_administrator_rs()) {
         return false;
     }
     $user_has_role = array();
     if (TERM_SCOPE_RS == $scope) {
         foreach (array_keys($roles) as $role_handle) {
             $role_attributes = $this->scoper->role_defs->get_role_attributes($role_handle);
             $args = array('src_name' => $role_attributes->src_name, 'object_type' => $role_attributes->object_type);
             $user_has_role[$role_handle] = $this->user_has_role_in_term($role_handle, $src_or_tx_name, $item_id, $args);
         }
     } else {
         if ($require_blogwide_editor = scoper_get_option('role_admin_blogwide_editor_only')) {
             global $current_user;
             $is_user_administrator = is_user_administrator_rs();
             $is_content_administrator = is_content_administrator_rs();
         }
         foreach (array_keys($roles) as $role_handle) {
             // a user must have a blog-wide edit cap to modify editing role assignments (even if they have Editor role assigned for some current object)
             if ($require_blogwide_editor) {
                 if (!$is_user_administrator && 'admin' == $require_blogwide_editor) {
                     $user_has_role[$role_handle] = false;
                     continue;
                 }
                 if (!$is_content_administrator && 'admin_content' == $require_blogwide_editor) {
                     $user_has_role[$role_handle] = false;
                     continue;
                 }
                 $src_name = $this->scoper->role_defs->member_property($role_handle, 'src_name');
                 $object_type = $this->scoper->role_defs->member_property($role_handle, 'object_type');
                 static $can_edit_blogwide;
                 if (!isset($can_edit_blogwide)) {
                     $can_edit_blogwide = array();
                 }
                 if (!isset($can_edit_blogwide[$src_name][$object_type])) {
                     $can_edit_blogwide[$src_name][$object_type] = $this->scoper->user_can_edit_blogwide($src_name, $object_type, array('require_others_cap' => true));
                 }
                 if (!$can_edit_blogwide[$src_name][$object_type]) {
                     $user_has_role[$role_handle] = false;
                     continue;
                 }
             }
             if (!empty($this->scoper->role_defs->role_caps[$role_handle])) {
                 $user_has_role[$role_handle] = cr_user_can(array_keys($this->scoper->role_defs->role_caps[$role_handle]), $item_id);
             }
         }
     }
     return $user_has_role;
 }
開發者ID:btj,項目名稱:cscircles-wp-content,代碼行數:50,代碼來源:role_assigner_rs.php

示例7: flt_admin_bar_menu

 function flt_admin_bar_menu(&$bar)
 {
     if (is_content_administrator_rs()) {
         return;
     }
     $type = 'new-content';
     foreach (get_post_types(array('public' => true), 'object') as $_post_type => $type_obj) {
         $var = 'new-' . $_post_type;
         if (isset($bar->menu->{$type}['children']->{$var})) {
             if (!cr_user_can($type_obj->cap->edit_posts, 0, 0, array('skip_id_generation' => true, 'skip_any_object_check' => true))) {
                 unset($bar->menu->{$type}['children']->{$var});
             }
         }
     }
 }
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:15,代碼來源:hardway-front_rs.php

示例8: get_page_titles

 function get_page_titles()
 {
     global $wpdb;
     $is_administrator = is_content_administrator_rs();
     if (!$is_administrator) {
         remove_filter('get_pages', array('ScoperHardway', 'flt_get_pages'), 1, 2);
     }
     // don't retrieve post_content, to save memory
     $all_pages = scoper_get_results("SELECT ID, post_parent, post_title, post_date, post_date_gmt, post_status, post_name, post_modified, post_modified_gmt, guid, menu_order, comment_count FROM {$wpdb->posts} WHERE post_type = 'page'");
     foreach (array_keys($all_pages) as $key) {
         $all_pages[$key]->post_content = '';
     }
     // add an empty post_content property to each item, in case some plugin filter requires it
     $all_pages = apply_filters('get_pages', $all_pages);
     if (!$is_administrator) {
         add_filter('get_pages', array('ScoperHardway', 'flt_get_pages'), 1, 2);
     }
     return scoper_get_property_array($all_pages, 'ID', 'post_title');
 }
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:19,代碼來源:admin_lib-bulk-parent_rs.php

示例9: police_xmlrpc_action

 function police_xmlrpc_action($method_name)
 {
     if (function_exists('is_content_administrator_rs') && is_content_administrator_rs()) {
         return;
     }
     switch ($method_name) {
         // This method has no business passing an empty array of categories.  It usually means none are selected for a new post, and does not provide a hook for RS to filtering the default category prior to insertion
         case 'mt.setPostCategories':
             global $scoper_last_raw_post_data;
             if (empty($scoper_last_raw_post_data)) {
                 return;
             }
             if (!$this->load_ixr()) {
                 return;
             }
             $msg = new IXR_Message($scoper_last_raw_post_data);
             if ($msg->parse()) {
                 // params[0] = object id, params[3] = categories
                 if (is_array($msg->params) && !empty($msg->params[0]) && isset($msg->params[3]) && !$msg->params[3]) {
                     if ($terms = wp_get_object_terms($msg->params[0], 'category', array('fields' => 'ids'))) {
                         foreach ($terms as $key => $val) {
                             $terms[$key] = (int) $val;
                         }
                         // otherwise wp_set_object_terms will store as a new category named "id"
                         if (empty($this->scheduled_term_restoration)) {
                             $this->scheduled_term_restoration = array();
                             add_action('set_object_terms', array(&$this, 'maybe_restore_object_terms'), 99, 6);
                         }
                         $this->scheduled_term_restoration[$msg->params[0]]['category'] = $terms;
                     }
                 }
             }
             break;
             // 'mt.setPostCategories'
     }
     // end switch
 }
開發者ID:Netsoro,項目名稱:gdnlteamgroup,代碼行數:37,代碼來源:xmlrpc_rs.php

示例10: act_maybe_hide_quickedit

 function act_maybe_hide_quickedit()
 {
     if (is_content_administrator_rs()) {
         return;
     }
     $object_type = awp_post_type_from_uri();
     if (!$GLOBALS['scoper']->user_can_edit_blogwide('post', $object_type, array('require_others_cap' => true))) {
         echo "<div id='rs_hide_quickedit'></div>";
     }
 }
開發者ID:Netsoro,項目名稱:gdnlteamgroup,代碼行數:10,代碼來源:filters-admin-ui-listing_rs.php

示例11: scoper_init

function scoper_init()
{
    global $scoper;
    // Work around bug in More Taxonomies (and possibly other plugins) where category taxonomy is overriden without setting it public
    foreach (array('category', 'post_tag') as $taxonomy) {
        if (isset($GLOBALS['wp_taxonomies'][$taxonomy])) {
            $GLOBALS['wp_taxonomies'][$taxonomy]->public = true;
        }
    }
    if (IS_MU_RS && agp_is_plugin_network_active(SCOPER_BASENAME)) {
        global $scoper_sitewide_options;
        $scoper_sitewide_options = apply_filters('sitewide_options_rs', $scoper_sitewide_options);
    }
    require_once dirname(__FILE__) . '/wp-cap-helper_cr.php';
    WP_Cap_Helper_CR::establish_status_caps();
    WP_Cap_Helper_CR::force_distinct_post_caps();
    WP_Cap_Helper_CR::force_distinct_taxonomy_caps();
    if (is_admin()) {
        require_once dirname(__FILE__) . '/admin/admin-init_rs.php';
        // TODO: why is the require statement up top not sufficient for NGG 1.7.2 uploader?
        scoper_admin_init();
    }
    //log_mem_usage_rs( 'scoper_admin_init done' );
    require_once dirname(__FILE__) . '/scoped-user.php';
    require_once dirname(__FILE__) . '/role-scoper_main.php';
    //log_mem_usage_rs( 'require role-scoper_main' );
    if (empty($scoper)) {
        // set_current_user may have already triggered scoper creation and role_cap load
        $scoper = new Scoper();
        //log_mem_usage_rs( 'new Scoper done' );
        $scoper->init();
    }
    // ensure that content administrators (as defined by SCOPER_CONTENT_ADMIN_CAP) have all caps for custom types by default
    if (is_content_administrator_rs()) {
        global $current_rs_user;
        if (!empty($current_rs_user)) {
            // user object not set when scoper_init() is manually invoked to support htaccess rule generation on plugin activation
            foreach (get_post_types(array('public' => true, '_builtin' => false)) as $name) {
                $current_rs_user->assigned_blog_roles[ANY_CONTENT_DATE_RS]["rs_{$name}_editor"] = true;
            }
            $taxonomies = get_taxonomies(array('public' => true, '_builtin' => false));
            $taxonomies[] = 'nav_menu';
            foreach ($taxonomies as $name) {
                $current_rs_user->assigned_blog_roles[ANY_CONTENT_DATE_RS]["rs_{$name}_manager"] = true;
            }
            $current_rs_user->merge_scoped_blogcaps();
            $GLOBALS['current_user']->allcaps = array_merge($GLOBALS['current_user']->allcaps, $current_rs_user->allcaps);
            $GLOBALS['current_user']->assigned_blog_roles = $current_rs_user->assigned_blog_roles;
        }
    }
    if (!empty($_GET['action']) && 'expire_file_rules' == $_GET['action']) {
        require_once dirname(__FILE__) . '/attachment-helper_rs.php';
        scoper_requested_file_rule_expire();
    }
    //log_mem_usage_rs( 'scoper->init() done' );
}
開發者ID:btj,項目名稱:cscircles-wp-content,代碼行數:56,代碼來源:role-scoper_init.php

示例12: add_main_filters

 function add_main_filters()
 {
     $is_admin = is_admin();
     $is_administrator = is_content_administrator_rs();
     $disable_queryfilters = defined('DISABLE_QUERYFILTERS_RS');
     $frontend_admin = false;
     if (!defined('DOING_CRON')) {
         if ($this->is_front()) {
             if (!$disable_queryfilters) {
                 require_once dirname(__FILE__) . '/query-interceptor-front_rs.php';
             }
             if (!$is_administrator) {
                 require_once dirname(__FILE__) . '/qry-front_non-administrator_rs.php';
                 $GLOBALS['feed_interceptor'] = new FeedInterceptor_RS();
                 // file already required in role-scoper.php
             }
             require_once dirname(__FILE__) . '/template-interceptor_rs.php';
             $GLOBALS['template_interceptor'] = new TemplateInterceptor_RS();
             $frontend_admin = !scoper_get_option('no_frontend_admin');
             // potential performance enhancement
             if (!empty($_REQUEST['s']) && function_exists('relevanssi_query')) {
                 require_once dirname(__FILE__) . '/relevanssi-helper-front_rs.php';
                 $rel_helper_rs = new Relevanssi_Search_Filter_RS();
             }
         }
         // ===== Filters which are always loaded (except on plugin scripts), for any access type
         include_once dirname(__FILE__) . '/hardway/wp-patches_agp.php';
         // simple patches for WP
         if ($this->is_front() || 'edit.php' == $GLOBALS['pagenow']) {
             require_once dirname(__FILE__) . '/query-interceptor-base_rs.php';
             $GLOBALS['query_interceptor_base'] = new QueryInterceptorBase_RS();
             // listing filter used for role status indication in edit posts/pages and on front end by template functions
         }
     }
     // ===== Filters which support automated role maintenance following content creation/update
     // Require an explicitly set option to skip these for front end access, just in case other plugins modify content from the front end.
     if ($is_admin || defined('XMLRPC_REQUEST') || $frontend_admin || defined('DOING_CRON')) {
         require_once dirname(__FILE__) . '/admin/cache_flush_rs.php';
         require_once dirname(__FILE__) . '/admin/filters-admin_rs.php';
         $GLOBALS['scoper_admin_filters'] = new ScoperAdminFilters();
         if (defined('RVY_VERSION')) {
             // Support Revisionary references to $scoper->filters_admin (TODO: eventually phase this out)
             $this->filters_admin =& $GLOBALS['scoper_admin_filters'];
         }
     }
     // =====
 }
開發者ID:Netsoro,項目名稱:gdnlteamgroup,代碼行數:47,代碼來源:role-scoper_main.php

示例13: user_can_associate_main

 function user_can_associate_main($post_type)
 {
     if (is_content_administrator_rs()) {
         return true;
     }
     if ('no_parent_filter' == scoper_get_option('lock_top_pages')) {
         return true;
     }
     if (!($post_type_obj = get_post_type_object($post_type))) {
         return true;
     }
     if (!$post_type_obj->hierarchical) {
         return true;
     }
     // currently used only for page type, or for all if constant is set
     $top_pages_locked = scoper_get_option('lock_top_pages');
     if ('page' == $post_type || defined('SCOPER_LOCK_OPTION_ALL_TYPES')) {
         if ('1' === $top_pages_locked) {
             // only administrators can change top level structure
             return false;
         } elseif ('no_parent_filter' === $top_pages_locked) {
             return true;
         } else {
             $reqd_caps = 'author' === $top_pages_locked ? array($post_type_obj->cap->publish_posts) : array($post_type_obj->cap->edit_others_posts);
             $roles = $GLOBALS['scoper']->role_defs->qualify_roles($reqd_caps);
             return array_intersect_key($roles, $GLOBALS['current_rs_user']->blog_roles[ANY_CONTENT_DATE_RS]);
         }
     } else {
         return true;
     }
 }
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:31,代碼來源:filters-admin_rs.php

示例14: display_ui_user_roles

 function display_ui_user_roles($user, $groups_only = false)
 {
     global $scoper;
     $blog_roles = array();
     $term_roles = array();
     $blog_roles = $user->get_blog_roles_daterange('rs', array('include_role_duration_key' => true, 'enforce_duration_limits' => false));
     // arg: return array with additional key dimension for role duration
     // for Administrators, display any custom post General Roles which were auto-assigned to maintain default editing rights
     global $current_rs_user;
     if ($current_rs_user->ID == $user->ID) {
         if (is_content_administrator_rs()) {
             $blog_roles[''][''] = isset($blog_roles['']['']) ? array_merge($current_rs_user->assigned_blog_roles['']) : $current_rs_user->assigned_blog_roles[''];
         }
     }
     foreach ($this->scoper->taxonomies->get_all() as $taxonomy => $tx) {
         $term_roles[$taxonomy] = $user->get_term_roles_daterange($taxonomy, 'rs', array('include_role_duration_key' => true, 'enforce_duration_limits' => false));
     }
     // arg: return array with additional key dimension for role duration
     $duration_limits_enabled = scoper_get_option('role_duration_limits');
     $content_date_limits_enabled = scoper_get_option('role_content_date_limits');
     $html = '';
     if ($groups_only) {
         if (IS_MU_RS && scoper_get_option('mu_sitewide_groups', true)) {
             global $blog_id;
             $list = scoper_get_blog_list(0, 'all');
             $blog_path = '';
             foreach ($list as $blog) {
                 if ($blog['blog_id'] == $blog_id) {
                     $blog_path = $blog['path'];
                     break;
                 }
             }
             $group_caption = sprintf(__('Group Roles %1$s(for %2$s)%3$s', 'scoper'), '<span style="font-weight: normal">', rtrim($blog_path, '/'), '</span>');
         } else {
             $group_caption = __('Group Roles', 'scoper');
         }
     } else {
         $html .= "<div id='userprofile_rolesdiv_rs' class='rs-scoped_role_profile'>";
         $html .= "<h3>" . __('Scoped Roles', 'scoper') . "</h3>";
         $wp_blog_roles = array_intersect_key($user->assigned_blog_roles[''], $scoper->role_defs->get_matching('wp'));
         if (!empty($wp_blog_roles)) {
             $display_names = array();
             foreach (array_keys($wp_blog_roles) as $role_handle) {
                 $display_names[] = $scoper->role_defs->get_display_name($role_handle);
             }
             $html .= sprintf(__("<strong>Assigned WordPress Role:</strong> %s", 'scoper'), implode(", ", $display_names));
             if ($contained_roles = $this->scoper->role_defs->get_contained_roles(array_keys($wp_blog_roles), false, 'rs')) {
                 $display_names = array();
                 foreach (array_keys($contained_roles) as $role_handle) {
                     $display_names[] = $this->scoper->role_defs->get_display_name($role_handle);
                 }
                 $html .= '<br /><span class="rs-gray">';
                 $html .= sprintf(__("(contains %s)", 'scoper'), implode(", ", $display_names));
                 $html .= '</span>';
             }
         }
         $html .= '<br /><br />';
     }
     $display_names = array();
     foreach (array_keys($blog_roles) as $duration_key) {
         if (is_serialized($duration_key)) {
             $role_date_limits = unserialize($duration_key);
             $role_date_limits->date_limited = true;
         } else {
             $role_date_limits = array();
         }
         foreach (array_keys($blog_roles[$duration_key]) as $date_key) {
             $display_names = array();
             if (is_serialized($date_key)) {
                 $content_date_limits = unserialize($date_key);
                 $content_date_limits->content_date_limited = true;
             } else {
                 $content_date_limits = array();
             }
             $date_caption = '';
             if ($role_date_limits || $content_date_limits) {
                 $limit_class = '';
                 // unused byref arg
                 $limit_style = '';
                 // unused byref arg
                 $link_class = '';
                 // unused byref arg
                 ScoperAdminUI::set_agent_formatting(array_merge((array) $role_date_limits, (array) $content_date_limits), $date_caption, $limit_class, $link_class, $limit_style, false);
                 // arg: no title='' wrapper around date_caption
                 $date_caption = '<span class="rs-gray"> ' . trim($date_caption) . '</span>';
             }
             if ($rs_blog_roles = $this->scoper->role_defs->filter($blog_roles[$duration_key][$date_key], array('role_type' => 'rs'))) {
                 foreach (array_keys($rs_blog_roles) as $role_handle) {
                     $display_names[] = $this->scoper->role_defs->get_display_name($role_handle);
                 }
                 $url = "admin.php?page=rs-general_roles";
                 $linkopen = "<strong><a href='{$url}'>";
                 $linkclose = "</a></strong>";
                 $list = implode(", ", $display_names);
                 if ($groups_only) {
                     $html .= sprintf(_n('<strong>%1$sGeneral Role%2$s</strong>%4$s: %3$s', '<strong>%1$sGeneral Roles%2$s</strong>%4$s: %3$s', count($display_names), 'scoper'), $linkopen, $linkclose, $list, $date_caption);
                 } else {
                     $html .= sprintf(_n('<strong>Additional %1$sGeneral Role%2$s</strong>%4$s: %3$s', '<strong>Additional %1$sGeneral Roles%2$s</strong>%4$s: %3$s', count($display_names), 'scoper'), $linkopen, $linkclose, $list, $date_caption);
                 }
                 if ($contained_roles = $this->scoper->role_defs->get_contained_roles(array_keys($rs_blog_roles), false, 'rs')) {
//.........這裏部分代碼省略.........
開發者ID:joostrijneveld,項目名稱:cscircles-wp-content,代碼行數:101,代碼來源:profile_ui_rs.php

示例15: flt_objects_listing

 function flt_objects_listing($results, $src_name, $object_types, $args = array())
 {
     global $wpdb;
     // it's not currently necessary or possible to log listed revisions from here
     //if ( isset($wpdb->last_query) && strpos( $wpdb->last_query, "post_type = 'revision'") )
     //	return $results;
     // if currently listed IDs are not already in post_cache, make our own equivalent memcache
     // ( create this cache for any data source, front end or admin )
     if ('post' == $src_name) {
         global $wp_object_cache;
     }
     $listed_ids = array();
     //if ( ('post' != $src_name) || empty($wp_object_cache->cache['posts']) ) {
     if (empty($this->scoper->listed_ids[$src_name])) {
         if ($col_id = $this->scoper->data_sources->member_property($src_name, 'cols', 'id')) {
             $listed_ids = array();
             // In edit.php, WP forces all objects into recordset for hierarchical post types.  But for perf enchancement, we need to know IDs of items which are actually listed
             if ('edit.php' == $GLOBALS['pagenow']) {
                 $post_type = !empty($_GET['post_type']) ? sanitize_key($_GET['post_type']) : 'post';
                 $determine_listed_ids = !is_content_administrator_rs() && is_post_type_hierarchical($post_type) && !empty($GLOBALS['query_interceptor']->last_request[$src_name]) && !strpos($GLOBALS['query_interceptor']->last_request[$src_name], 'LIMIT ');
                 if ($determine_listed_ids) {
                     // mimic recordset paging used in edit.php
                     $pagenum = isset($_GET['paged']) ? absint($_GET['paged']) : 0;
                     if (empty($pagenum)) {
                         $pagenum = 1;
                     }
                     $edit_per_page = 'edit_' . $post_type . '_per_page';
                     $per_page = (int) get_user_option($edit_per_page);
                     if (empty($per_page) || $per_page < 1) {
                         $per_page = 20;
                     }
                     $per_page = apply_filters($edit_per_page, $per_page);
                     $per_page = apply_filters('edit_posts_per_page', $per_page, $post_type);
                     if (count($results) <= $per_page) {
                         $determine_listed_ids = false;
                     }
                 }
             } else {
                 $determine_listed_ids = false;
             }
             if ($determine_listed_ids) {
                 // Construct and execute a secondary query (for IDs only) which includes the paging clause that would be used if edit.php did not defeat it
                 $pgstrt = ($pagenum - 1) * $per_page . ', ';
                 $limits = ' LIMIT ' . $pgstrt . $per_page;
                 global $wpdb;
                 $qry = $GLOBALS['query_interceptor']->last_request[$src_name] . $limits;
                 $qry = str_replace("{$wpdb->posts}.*", "{$wpdb->posts}.ID", $qry);
                 $_results = scoper_get_results($qry);
                 foreach ($_results as $row) {
                     if (isset($row->{$col_id})) {
                         $listed_ids[$row->{$col_id}] = true;
                     }
                 }
             } else {
                 // No secondary query, just buffer all IDs in the results set
                 foreach ($results as $row) {
                     if (isset($row->{$col_id})) {
                         $listed_ids[$row->{$col_id}] = true;
                     }
                 }
             }
             if (empty($this->scoper->listed_ids)) {
                 $this->scoper->listed_ids = array();
             }
             $this->scoper->listed_ids[$src_name] = $listed_ids;
         }
     } else {
         return $results;
     }
     //}
     // now determine what restrictions were in place on these results
     // (currently only for post data source, front end or manage posts/pages)
     //
     // possible todo: support other data sources, WP role type
     if ('edit.php' == $GLOBALS['pagenow']) {
         if (scoper_get_otype_option('restrictions_column', 'post') || scoper_get_otype_option('term_roles_column', 'post') || scoper_get_otype_option('object_roles_column', 'post')) {
             global $scoper_role_usage;
             require_once dirname(__FILE__) . '/role_usage_rs.php';
             $scoper_role_usage = new Role_Usage_RS();
             $scoper_role_usage->determine_role_usage_rs('post', $listed_ids);
         }
     }
     return $results;
 }
開發者ID:btj,項目名稱:cscircles-wp-content,代碼行數:84,代碼來源:query-interceptor-base_rs.php


注:本文中的is_content_administrator_rs函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。