मैं एक कस्टम रोल क्षमता कैसे बनाऊं?


26

मैं अपने प्लगइन के इंटरफेस तक पहुंचने के लिए एक कस्टम क्षमता बनाना चाहता हूं।

  • क्या प्लगइन को सक्रियण पर सभी व्यवस्थापक खातों में इस क्षमता को जोड़ना चाहिए?
  • यदि ऐसा है: क्या वर्डप्रेस मल्टी ब्लॉग इंस्टॉलेशन में सब ब्लॉग और सुपर एडमिनिस्ट्रेटर के सभी प्रशासकों को जोड़ने की क्षमता का प्रबंधन करता है, या उस फ़ंक्शन को प्लगइन द्वारा नियंत्रित करने की आवश्यकता है?

ए डिटेल ब्लॉग: goo.gl/xNuafH
सुरेश कमरुशी

जवाबों:


11

जो आप जोड़ते हैं, उसे हटा दें

सबसे पहले, कृपया सुनिश्चित करें कि आप सक्रियण पर जो कुछ भी जोड़ते हैं वह भी अनइंस्टॉल पर हटा दिया जाता है । मुझे आपके लिए उदाहरण कोड सहित एक छोटा ट्यूटोरियल मिला ।

एक छोटे प्लगइन के साथ टेस्ट करें:

मुझे वास्तव में MU के बारे में ज्यादा जानकारी नहीं है, लेकिन जहां तक ​​मैं बता सकता हूं, भूमिकाओं का उद्देश्य सभी ब्लॉगों में वैश्विक है। बस इस छोटे प्लगइन का प्रयास करें और देखें कि आपको क्या मिल सकता है:

<?php
/*
Plugin Name:    MU Roles check
Plugin URI:     https://github.com/franz-josef-kaiser/
Description:    Check roles during viewing a blog
Author:     Franz Josef Kaiser
Author URI:     https://plus.google.com/u/0/107110219316412982437
Version:        0.1
Text Domain:    murc
License:        GPL v2 - http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
*/

/**
 * Show the blog data and the role names in this blog
 * Also shows if the custom capability was successfully added, or displays n/a for the role
 * 
 * @return void
 */
function wpse35165_role_check()
{
    $blog = get_current_site();
    $custom_cap = 'name_of_your_custom_capability';

    $html = "<hr /><table>";
    $html .= "<caption>List roles in (Blog) {$blog->site_name} / ID#{$blog->id}</caption>"
    $html .= "<thead><tr><th>Role Name</th><th>Capabilties</th></tr></thead><tbody>";
    foreach ( $GLOBALS['wp_roles'] as $name => $role_obj )
    {
        $cap = in_array( $custom_cap, $role_obj->caps ) ? $custom_cap : 'n/a';
        $cap = $cap OR in_array( $custom_cap, $role_obj->allcaps ) ? $custom_cap : 'n/a';
        $html .= "<tr><td>{$name}</td><td>{$cap}</td></tr>";
    }
    $html .= '</tbody></table>';

    print $html;
}
add_action( 'shutdown', 'wpse35165_role_check' );

क्षमताओं को जोड़ना

/**
 * Add the capability to the role objects
 * Should be in your activation function and done before you inspect with your plugin
 * 
 * @return void
 */
function wpse35165_add_cap()
{
    $custom_cap = 'name_of_your_custom_capability';
    $min_cap    = 'the_minimum_required_built_in_cap'; // Check "Roles and objects table in codex!
    $grant      = true; 

    foreach ( $GLOBALS['wp_roles'] as $role_obj )
    {
        if ( 
            ! $role_obj->has_cap( $custom_cap ) 
            AND $role_obj->has_cap( $min_cap )
        )
            $role_obj->add_cap( $custom_cap, $grant );
    }
}

नोट: आप भूमिका तक पहुँच प्रदान किए बिना भूमिका में क्षमता जोड़ सकते हैं - बस दूसरा तर्क सेट करें $grant = false;। यह केवल अंतिम तर्क सहित टोपी को सच के रूप में जोड़ने के साथ एकल उपयोगकर्ताओं को श्वेत सूची देने की अनुमति देता है।


17

वर्तमान में मैं जिस प्लगइन पर काम कर रहा हूं, उसके लिए मैं प्रति रोल बेस पर प्लगइन सेटिंग्स (यानी, व्यवस्थापक मेनू पृष्ठों के अनुसार) तक पहुंच को प्रतिबंधित / प्रतिबंधित करना चाहता था ।
इसलिए, मैं करने के लिए किया था एक नया प्लगइन विशेष जोड़ने capabilityके लिएuser roles

दुर्भाग्य से, काइसर का जवाब अब काम नहीं कर रहा है, इसलिए मैंने कुछ समय बिताने की कोशिश की, जो कि उपर्युक्त कार्यक्षमता के लिए अनुमति दें।


कार्यक्रम

इससे पहले कि मैं आपके साथ अपना कोड साझा करूं, यहाँ पर यह सब है, सादे पाठ में:

  1. प्लगइन सक्रियण पर, THE_NEW_CAPएक निश्चित अंतर्निहित क्षमता वाली भूमिकाओं में नई क्षमता जोड़ें BUILT_IN_CAP(मेरे मामले में:) edit_pages
  2. प्रत्येक पृष्ठ लोड पर, 1. करें (यानी, क्षमता जोड़ें, फिर से)। यह केवल तभी आवश्यक है जब आप संभावित नई भूमिकाओं के लिए खाता बनाना चाहते हैं जो प्लगइन की सक्रियता के बाद बनाई गई हैं। इसलिए, इन नई भूमिकाओं में प्लग-विशिष्ट क्षमता नहीं है, भले ही उनके पास आवश्यक अंतर्निहित क्षमता हो।
  3. आप जो भी चाहते हैं उसके लिए नई क्षमता का उपयोग करें। जैसा कि पहले बताया गया है, मैं इसे प्लगइन के व्यवस्थापक मेनू पृष्ठों तक पहुंच प्रदान करने / प्रतिबंधित करने के लिए उपयोग करता हूं, इसलिए यह निम्न कोड उदाहरण में किया गया है।
  4. प्लगइन निष्क्रिय करने पर, क्षमता को हटा दें। बेशक, आप ऐसा तब भी कर सकते हैं जब प्लगइन की स्थापना रद्द की जा रही है। किसी भी तरह से, अंततः यह करो।

कोड

और यहाँ उपरोक्त सूची को कोड में परिवर्तित किया गया है:

»इसे स्थापित करना

class WPSE35165Plugin {

    public function __construct() {
        // Register hooks
        register_activation_hook(__FILE__, array(__CLASS__, 'activation'));
        register_deactivation_hook(__FILE__, array(__CLASS__, 'deactivation'));

        // Add actions
        add_action('admin_menu', array(__CLASS__, 'admin_menu'));
    }

    public function activation() {
        self::add_cap();
    }

    // Add the new capability to all roles having a certain built-in capability
    private static function add_cap() {
        $roles = get_editable_roles();
        foreach ($GLOBALS['wp_roles']->role_objects as $key => $role) {
            if (isset($roles[$key]) && $role->has_cap('BUILT_IN_CAP')) {
                $role->add_cap('THE_NEW_CAP');
            }
        }
    }

" उसका इस्तेमाल कर रहे हैं

    // Add plugin menu pages to admin menu
    public function admin_menu() {
        // Remove the following line if you don't care about new roles
        // that have been created after plugin activation
        self::add_cap();

        // Set up the plugin admin menu
        add_menu_page('Menu', 'Menu', 'THE_NEW_CAP', …);
        add_submenu_page('wpse35165', 'Submenu', 'Submenu', 'THE_NEW_CAP', ...);
    }

»इसे साफ करना

    public function deactivation() {
        self::remove_cap();
    }

    // Remove the plugin-specific custom capability
    private static function remove_cap() {
        $roles = get_editable_roles();
        foreach ($GLOBALS['wp_roles']->role_objects as $key => $role) {
            if (isset($roles[$key]) && $role->has_cap('THE_NEW_CAP')) {
                $role->remove_cap('THE_NEW_CAP');
            }
        }
    }

}

नोट: कृपया ऊपरी केस क्षमताओं का उपयोग न करें। यह सिर्फ पठनीयता के लिए है।


1
हमेशा उन get_editable_roles()भूमिकाओं का उपयोग करें जिन्हें आप संपादित करना चाहते हैं। आप प्लगइन्स को अन्यथा तोड़ देंगे
FUXIA

1
@toscho ठीक है, ठीक है, मुझे लगता है कि इन कार्यों में से एक भी कोडेक्स के बारे में पता नहीं है ... है लगता है;) बेशक, इस समारोह का अस्तित्व अपने अधिकार है, फिर भी, मैं वैश्विक WP_Roles पंक्ति का उपयोग करते नहीं दिख रहा तोड़ने मेरे मामले में कोई भी प्लगइन्स
tfrommen

2
कुछ प्लगइन्स विशिष्ट उपयोगकर्ता भूमिकाएँ बनाते हैं और क्षमताओं के सटीक सेट पर भरोसा करते हैं। कुछ मामलों में एक क्षमता प्रोग्राम लॉजिक में दूसरे के उपयोग को शामिल नहीं करती है। आप नहीं जान सकते कि ऐसा कब है।
FUXIA

0

यह मेरे लिए काम करता है:

    add_action('admin_init', 'add_custom_cap');
    function add_custom_cap()
    {
        $custom_cap = 'test_cap';
        $min_cap    = 'read';
        $grant      = true;
        $to_role = 'your_user_role';
        $role = 'user_role';

        foreach ( $GLOBALS['wp_roles'] as $role_obj )
        {
            if (is_object($role_obj[$role])) {
                if (!$role_obj[$role]->has_cap( $custom_cap ) && $role_obj[$role]->has_cap( $min_cap )) {
                    $role_obj[$role]->add_cap( $custom_cap, $grant );
                }
            }
        }
    }

भूमिकाओं के ग्लोबल्स को कभी भी संशोधित न करें ! कभी नहीँ। नहीं करें! आप किसी भी हुक को ट्रिगर नहीं करेंगे और फ़िल्टर से इनकार करते हैं और अपने कोड को एक चलती लक्ष्य बनाते हैं। किसी को भी यह पता नहीं चलेगा कि आपने उस भूमिका को कब और कहां दर्ज किया (आपने नहीं किया, आपने इसे कहीं और, कहीं, किसी तरह से भर दिया)। कृपया: कभी मत करो। खासकर भूमिकाओं के साथ नहीं।
केसर
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.