%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /proc/1857783/root/var/www/cwg/wp-content/plugins/user-role-editor/includes/classes/
Upload File :
Create Path :
Current File : //proc/1857783/root/var/www/cwg/wp-content/plugins/user-role-editor/includes/classes/capability.php

<?php
/**
 * Class to work with user capability
 *
 * @package    User-Role-Editor
 * @subpackage Admin
 * @author     Vladimir Garagulya <support@role-editor.com>
 * @copyright  Copyright (c) 2010 - 2016, Vladimir Garagulya
 **/

class URE_Capability {

    const SPACE_REPLACER = '_URE-SR_';
    const SLASH_REPLACER = '_URE-SLR_';
    const VERT_LINE_REPLACER = '_URE-VLR_';

    
    public static function escape($cap_id) {
        
        $search = array(' ', '/', '|');
        $replace = array(self::SPACE_REPLACER, self::SLASH_REPLACER, self::VERT_LINE_REPLACER);
        
        $cap_id_esc = str_replace($search, $replace, $cap_id);
                
        return $cap_id_esc;
    }
    // end escape()

    
    // sanitize user input for security
    // do not allow to use internally used capabilities
    public static function validate($cap_id_raw) {
        $match = array();
        $found = preg_match('/[A-Za-z0-9_\-]*/', $cap_id_raw, $match);
        if (!$found || ($found && ($match[0]!=$cap_id_raw))) { // some non-alphanumeric charactes found!    
            $data = array(
                'result'=>false, 
                'message'=>esc_html__('Error: Capability name must contain latin characters and digits only!', 'user-role-editor'),
                'cap_id'=>'');
            return $data;
        } 
        
        $cap_id = strtolower($match[0]);
        if ($cap_id=='do_not_allow') {
            $data = array(
                'result'=>false, 
                'message'=>esc_html__('Error: this capability is used internally by WordPress', 'user-role-editor'),
                'cap_id'=>'do_not_allow');
            return $data;
        }
        if ($cap_id=='administrator') {
            $data = array(
                'result'=>false, 
                'message'=>esc_html__('Error: this word is used by WordPress as a role ID', 'user-role-editor'),
                'cap_id'=>'administrator');
            return $data;
        }
        
        $data = array(
            'result'=>true, 
            'message'=>'Success',
            'cap_id'=>$cap_id);
        
        return $data;
    }
    // end of validate()
    
    
    /**
     * Add new user capability
     * 
     * @global WP_Roles $wp_roles
     * @return string
     */
    public static function add( $ure_object ) {
        global $wp_roles;

        $response = array('result'=>'error', 'capability_id'=>'', 'html'=>'', 'message'=>'');
        if ( !current_user_can( 'ure_create_capabilities' ) ) {
            $response['message'] = esc_html__( 'Insufficient permissions to work with User Role Editor', 'user-role-editor' );
            return $response;
        }
        
        $mess = '';
        if ( !isset( $_POST['capability_id'] ) || empty( $_POST['capability_id'] ) ) {
            $response['message'] = esc_html__( 'Wrong Request', 'user-role-editor' );
            return $response;
        }
        
        $data = self::validate( $_POST['capability_id'] );
        if ( !$data['result'] ) {
            $response['message'] = $data['message'];
            return $response;
        }
        
        $cap_id = $data['cap_id'];                
        $lib = URE_Lib::get_instance();
        $full_capabilities = $lib->init_full_capabilities( $ure_object );
        if ( !isset( $full_capabilities[$cap_id] ) ) {
            $admin_role = $lib->get_admin_role();
            $wp_roles->use_db = true;
            $wp_roles->add_cap( $admin_role, $cap_id );
            $response['result'] = 'success';
            $response['message'] = sprintf( esc_html__( 'Capability %s was added successfully', 'user-role-editor' ), $cap_id );
        } else {
            $response['message']  = sprintf( esc_html__( 'Capability %s exists already', 'user-role-editor' ), $cap_id );
        }
        
        return $response;
    }
    // end of add()
    
    
    /**
     * Extract capabilities selected from deletion from the $_POST global
     * 
     * @return array
     */
    private static function get_caps_for_deletion_from_post( $caps_allowed_to_remove ) {
        
        if ( isset( $_POST['values'] ) ) {
            $input_buff = $_POST['values'];
        } else {
            $input_buff = $_POST;
        }
        
        $caps = array();
        foreach( $input_buff as $key=>$value ) {
            if ( substr( $key, 0, 3 )!=='rm_' ) {
                continue;
            }
            if ( !isset( $caps_allowed_to_remove[$value])  ) {
                continue;
            }
            $caps[] = $value;
        }
        
        return $caps;
    }
    // end of get_caps_for_deletion_from_post()
            
        
    private static function revoke_caps_from_user($user_id, $caps) {
        $user = get_user_to_edit($user_id);
        foreach($caps as $cap_id) {
            if (!isset($user->caps[$cap_id])) {
                continue;
            }
            // Prevent sudden revoke role 'administrator' from a user during 'administrator' capability deletion.
            if ($cap_id=='administrator') { 
                continue;
            }
            $user->remove_cap($cap_id);            
        }
    }
    // end of revoke_caps_from_user()
    
    
    private static function revoke_caps_from_role($wp_role, $caps) {
        foreach($caps as $cap_id) {
            if ($wp_role->has_cap($cap_id)) {
                $wp_role->remove_cap($cap_id);
            }
        }
    }
    // end of revoke_caps_from_role()
    
    
    private static function revoke_caps($caps) {
        global $wpdb, $wp_roles;
        
        // remove caps from users
        $users_ids = $wpdb->get_col("SELECT $wpdb->users.ID FROM $wpdb->users");
        foreach ($users_ids as $user_id) {
            self::revoke_caps_from_user($user_id, $caps);
        }

        // remove caps from roles
        foreach ($wp_roles->role_objects as $wp_role) {
            self::revoke_caps_from_role($wp_role, $caps);            
        }        
    }
    // end of revoke_caps()
    
            
    /**
     * Delete capability
     * 
     * @global WP_Roles $wp_roles
     * @return string - information message
     */
    public static function delete() {        
               
        if ( !current_user_can( 'ure_delete_capabilities' ) ) {
            return esc_html__( 'Insufficient permissions to work with User Role Editor','user-role-editor' );
        }
                        
        $capabilities = URE_Capabilities::get_instance();
        $mess = '';                
        $caps_allowed_to_remove = $capabilities->get_caps_to_remove();
        if ( !is_array( $caps_allowed_to_remove ) || count( $caps_allowed_to_remove )==0 ) {
            return esc_html__( 'There are no capabilities available for deletion!', 'user-role-editor' );
        }
        
        $caps = self::get_caps_for_deletion_from_post( $caps_allowed_to_remove );
        if ( empty($caps) ) {
            return esc_html__( 'There are no capabilities available for deletion!', 'user-role-editor' );
        }

        self::revoke_caps( $caps );
        
        if ( count($caps)==1 ) {
            $mess = sprintf( esc_html__( 'Capability %s was removed successfully', 'user-role-editor' ), $caps[0] );
        } else {
            $lib = URE_Lib::get_instance();
            $short_list_str = $lib->get_short_list_str( $caps );
            $mess = count( $caps ) .' '. esc_html__( 'capabilities were removed successfully', 'user-role-editor' ) .': '. 
                    $short_list_str;
        }

        return array('message'=>$mess, 'deleted_caps'=>$caps);
    }
    // end of delete()
    
}
// end of class URE_Capability

Zerion Mini Shell 1.0