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


PHP WP_Roles::is_role方法代碼示例

本文整理匯總了PHP中WP_Roles::is_role方法的典型用法代碼示例。如果您正苦於以下問題:PHP WP_Roles::is_role方法的具體用法?PHP WP_Roles::is_role怎麽用?PHP WP_Roles::is_role使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在WP_Roles的用法示例。


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

示例1: orbis_update_roles

function orbis_update_roles($roles)
{
    global $wp_roles;
    if (!isset($wp_roles)) {
        $wp_roles = new WP_Roles();
    }
    foreach ($roles as $role => $data) {
        if (isset($data['display_name'], $data['capabilities'])) {
            $display_name = $data['display_name'];
            $capabilities = $data['capabilities'];
            if ($wp_roles->is_role($role)) {
                foreach ($capabilities as $cap => $grant) {
                    $wp_roles->add_cap($role, $cap, $grant);
                }
            } else {
                $wp_roles->add_role($role, $display_name, $capabilities);
            }
        }
    }
}
開發者ID:joffcrabtree,項目名稱:wp-orbis-keychains,代碼行數:20,代碼來源:post.php

示例2: ure_newRoleCreate

function ure_newRoleCreate(&$ure_currentRole)
{
    global $wp_roles;
    $mess = '';
    $ure_currentRole = '';
    if (isset($_GET['user_role']) && $_GET['user_role']) {
        $user_role = utf8_decode(urldecode($_GET['user_role']));
        // sanitize user input for security
        $valid_name = preg_match('/^[A-Za-z_][A-Za-z0-9_]*/', $user_role, $match);
        if (!$valid_name || $valid_name && $match[0] != $user_role) {
            // some non-alphanumeric charactes found!
            return __('Error: Role name must contain latin characters and digits only!', 'ure');
        }
        if ($user_role) {
            if (!isset($wp_roles)) {
                $wp_roles = new WP_Roles();
            }
            if (isset($wp_roles->roles[$user_role])) {
                return sprintf('Error! ' . __('Role %s exists already', 'ure'), $user_role);
            }
            // add new role to the roles array
            $ure_currentRole = strtolower($user_role);
            $user_role_copy_from = isset($_GET['user_role_copy_from']) ? $_GET['user_role_copy_from'] : false;
            if (!empty($user_role_copy_from) && $user_role_copy_from != 'none' && $wp_roles->is_role($user_role_copy_from)) {
                $role = $wp_roles->get_role($user_role_copy_from);
                $capabilities = $role->capabilities;
            } else {
                $capabilities = array('read' => 1, 'level_0' => 1);
            }
            $result = add_role($ure_currentRole, $user_role, $capabilities);
            if (!isset($result) || !$result) {
                $mess = 'Error! ' . __('Error is encountered during new role create operation', 'ure');
            } else {
                $mess = sprintf(__('Role %s is created successfully', 'ure'), $user_role);
            }
        }
    }
    return $mess;
}
開發者ID:kitfrench,項目名稱:Futurestep,代碼行數:39,代碼來源:ure-lib.php

示例3: add_new_role

 /**
  * process new role create request
  * 
  * @global WP_Roles $wp_roles
  * 
  * @return string   - message about operation result
  * 
  */
 protected function add_new_role()
 {
     global $wp_roles;
     if (!current_user_can('ure_create_roles')) {
         return esc_html__('Insufficient permissions to work with User Role Editor', 'user-role-editor');
     }
     $mess = '';
     $this->current_role = '';
     if (isset($_POST['user_role_id']) && $_POST['user_role_id']) {
         $user_role_id = utf8_decode($_POST['user_role_id']);
         // sanitize user input for security
         $valid_name = preg_match('/[A-Za-z0-9_\\-]*/', $user_role_id, $match);
         if (!$valid_name || $valid_name && $match[0] != $user_role_id) {
             // some non-alphanumeric charactes found!
             return esc_html__('Error: Role ID must contain latin characters, digits, hyphens or underscore only!', 'user-role-editor');
         }
         $numeric_name = preg_match('/[0-9]*/', $user_role_id, $match);
         if ($numeric_name && $match[0] == $user_role_id) {
             // numeric name discovered
             return esc_html__('Error: WordPress does not support numeric Role name (ID). Add latin characters to it.', 'user-role-editor');
         }
         if ($user_role_id) {
             $user_role_name = isset($_POST['user_role_name']) ? $_POST['user_role_name'] : false;
             if (!empty($user_role_name)) {
                 $user_role_name = sanitize_text_field($user_role_name);
             } else {
                 $user_role_name = $user_role_id;
                 // as user role name is empty, use user role ID instead
             }
             if (!isset($wp_roles)) {
                 $wp_roles = new WP_Roles();
             }
             if (isset($wp_roles->roles[$user_role_id])) {
                 return sprintf('Error! ' . esc_html__('Role %s exists already', 'user-role-editor'), $user_role_id);
             }
             $user_role_id = strtolower($user_role_id);
             $this->current_role = $user_role_id;
             $user_role_copy_from = isset($_POST['user_role_copy_from']) ? $_POST['user_role_copy_from'] : false;
             if (!empty($user_role_copy_from) && $user_role_copy_from != 'none' && $wp_roles->is_role($user_role_copy_from)) {
                 $role = $wp_roles->get_role($user_role_copy_from);
                 $capabilities = $this->remove_caps_not_allowed_for_single_admin($role->capabilities);
             } else {
                 $capabilities = array('read' => true, 'level_0' => true);
             }
             // add new role to the roles array
             $result = add_role($user_role_id, $user_role_name, $capabilities);
             if (!isset($result) || empty($result)) {
                 $mess = 'Error! ' . esc_html__('Error is encountered during new role create operation', 'user-role-editor');
             } else {
                 $mess = sprintf(esc_html__('Role %s is created successfully', 'user-role-editor'), $user_role_name);
             }
         }
     }
     return $mess;
 }
開發者ID:pwsclau,項目名稱:kurastar_dev,代碼行數:63,代碼來源:class-ure-lib.php

示例4: _update_user

 /**
  * Updates a specific Wordpress user account
  * 
  * @param string $username
  * @param array $userinfo
  * @param string $display_name
  * @param string $role
  * @param string $password
  * @return integer user_id
  */
 protected function _update_user($username, $userinfo, $display_name = '', $role = '', $password = '', $bulkimport = false)
 {
     global $wp_version;
     $info = $this->_create_info_array($userinfo);
     // get UPN suffix
     $parts = explode('@', $info['userprincipalname']);
     if (isset($parts[1])) {
         $account_suffix = '@' . $parts[1];
     } else {
         $account_suffix = '';
     }
     if (isset($info['mail'])) {
         $email = $info['mail'];
     } else {
         $email = '';
     }
     if ($email == '') {
         if (trim($this->_default_email_domain) != '') {
             $email = $username . '@' . $this->_default_email_domain;
         } else {
             if (strpos($username, '@') !== false) {
                 $email = $username;
             }
         }
     }
     if ($this->_append_suffix_to_new_users) {
         $username .= $account_suffix;
     }
     $this->_log(ADI_LOG_NOTICE, 'Updating user "' . $username . "\" with following data:\n" . "- email         : {$email}\n" . "- first name    : " . $info['givenname'] . "\n" . "- last name     : " . $info['sn'] . "\n" . "- display name  : {$display_name}\n" . "- account suffix: {$account_suffix}\n" . "- role          : {$role}");
     if (version_compare($wp_version, '3.1', '<')) {
         require_once ABSPATH . WPINC . DIRECTORY_SEPARATOR . 'registration.php';
     }
     $user_id = username_exists($username);
     if ($user_id === false) {
         return false;
     }
     $this->_log(ADI_LOG_NOTICE, '- user_id       : ' . $user_id);
     if (!$user_id) {
         $this->_log(ADI_LOG_FATAL, 'Error updating user.');
         die('Error updating user!');
     } else {
         update_user_meta($user_id, 'first_name', $info['givenname']);
         update_user_meta($user_id, 'last_name', $info['sn']);
         if ($this->_auto_update_description) {
             update_user_meta($user_id, 'description', $info['description']);
         }
         // set display_name
         if ($display_name != '') {
             wp_update_user(array('ID' => $user_id, 'display_name' => $display_name));
         }
         // set role
         if ($role != '') {
             $roles = new WP_Roles();
             if ($roles->is_role($role)) {
                 // Updates role only if role exists
                 wp_update_user(array('ID' => $user_id, 'role' => $role));
             } else {
                 $this->_log(ADI_LOG_WARN, 'Role "' . $role . '" currently does not exist in WordPress. Role of "' . $username . '" is not set.');
             }
         }
         // set email if not empty
         if ($email != '') {
             // if we allow duplicate email addresses just set it
             if ($this->_duplicate_email_prevention == ADI_DUPLICATE_EMAIL_ADDRESS_ALLOW) {
                 $return = wp_update_user(array('ID' => $user_id, 'user_email' => $email));
             } else {
                 // duplicate email addresses disallowed
                 // if we don't have a conflict, just set it
                 if (!email_exists($email)) {
                     $return = wp_update_user(array('ID' => $user_id, 'user_email' => $email));
                 } else {
                     // we have a conflict, so only update when the "create" option is set
                     if ($this->_duplicate_email_prevention == ADI_DUPLICATE_EMAIL_ADDRESS_CREATE) {
                         $userdata = get_userdata($user_id);
                         // only update if the email is not already set
                         if ($userdata->user_email == '') {
                             $new_email = $this->_create_non_duplicate_email($email);
                             $this->_log(ADI_LOG_NOTICE, "Duplicate email address prevention: Email changed from {$email} to {$new_email}.");
                             $return = wp_update_user(array('ID' => $user_id, 'user_email' => $new_email));
                         } else {
                             $this->_log(ADI_LOG_NOTICE, "Duplicate email address prevention: Existing email " . $userdata->user_email . " left unchanged.");
                         }
                     }
                 }
             }
         }
     }
     // Update password if needed (NOT on Bulk Import)
     if ($this->_auto_update_password === true && $bulkimport === false) {
         $this->_log(ADI_LOG_NOTICE, 'Setting local password to the one used for this login.');
//.........這裏部分代碼省略.........
開發者ID:kc596,項目名稱:cse.nits.ac.in,代碼行數:101,代碼來源:ad-integration.php

示例5: wp_user_profiles_additional_capabilities_metabox

/**
 * Render the capabilities metabox for user profile screen
 *
 * @since 0.1.0
 *
 * @param WP_User $user The WP_User object to be edited.
 */
function wp_user_profiles_additional_capabilities_metabox($user = null)
{
    // Get the roles global
    $wp_roles = new WP_Roles();
    ?>

	<table class="form-table">

		<?php 
    if (is_multisite() && is_network_admin() && !IS_PROFILE_PAGE && current_user_can('manage_network_options') && !isset($GLOBALS['super_admins'])) {
        ?>

			<tr class="user-super-admin-wrap"><th><?php 
        esc_html_e('Super Admin', 'wp-user-profiles');
        ?>
</th>
				<td>

					<?php 
        if ($user->user_email !== get_site_option('admin_email') || !is_super_admin($user->ID)) {
            ?>

						<p>
							<label>
								<input type="checkbox" id="super_admin" name="super_admin"<?php 
            checked(is_super_admin($user->ID));
            ?>
 />
								<?php 
            esc_html_e('Grant this user super admin privileges for the Network.', 'wp-user-profiles');
            ?>
							</label>
						</p>

					<?php 
        } else {
            ?>

						<p><?php 
            esc_html_e('Super admin privileges cannot be removed because this user has the network admin email.', 'wp-user-profiles');
            ?>
</p>

					<?php 
        }
        ?>

				</td>
			</tr>

		<?php 
    }
    ?>

		<tr class="user-capabilities-wrap">
			<th scope="row"><?php 
    esc_html_e('Capabilities', 'wp-user-profiles');
    ?>
</th>
			<td>
				<?php 
    $output = '';
    foreach ($user->caps as $cap => $value) {
        if (!$wp_roles->is_role($cap)) {
            if ('' !== $output) {
                $output .= ', ';
            }
            $output .= $value ? sprintf(esc_html__('Allowed: %s', 'wp-user-profiles'), $cap) : sprintf(esc_html__('Denied: %s', 'wp-user-profiles'), $cap);
        }
    }
    if (!empty($output)) {
        echo $output;
    } else {
        esc_html_e('No additional capabilities', 'wp-user-profiles');
    }
    ?>
			</td>
		</tr>
	</table>

<?php 
}
開發者ID:LaconicTranslator,項目名稱:wp-user-profiles,代碼行數:89,代碼來源:permissions-capabilities.php

示例6: authLdap_login


//.........這裏部分代碼省略.........
            }
            $dn = $attribs[0]['dn'];
            $realuid = $attribs[0][strtolower($authLDAPUidAttr)][0];
        } catch (Exception $e) {
            authLdap_debug('Exception getting LDAP user: ' . $e->getMessage());
            return false;
        }
        $uid = authLdap_get_uid($realuid);
        $role = '';
        // we only need this if either LDAP groups are disabled or
        // if the WordPress role of the user overrides LDAP groups
        if (!$authLDAPGroupEnable || !$authLDAPGroupOverUser) {
            $role = authLdap_user_role($uid);
        }
        // do LDAP group mapping if needed
        // (if LDAP groups override worpress user role, $role is still empty)
        if (empty($role) && $authLDAPGroupEnable) {
            $role = authLdap_groupmap($realuid, $dn);
            authLdap_debug('role from group mapping: ' . $role);
        }
        // if we don't have a role yet, use default role
        if (empty($role) && !empty($authLDAPDefaultRole)) {
            authLdap_debug('no role yet, set default role');
            $role = $authLDAPDefaultRole;
        }
        if (empty($role)) {
            // Sorry, but you are not in any group that is allowed access
            trigger_error('no group found');
            authLdap_debug('user is not in any group that is allowed access');
            return false;
        } else {
            $roles = new WP_Roles();
            // not sure if this is needed, but it can't hurt
            if (!$roles->is_role($role)) {
                trigger_error('no group found');
                authLdap_debug('role is invalid');
                return false;
            }
        }
        // from here on, the user has access!
        // now, lets update some user details
        $user_info = array();
        $user_info['user_login'] = $realuid;
        $user_info['role'] = $role;
        $user_info['user_email'] = '';
        // first name
        if (isset($attribs[0][strtolower($authLDAPNameAttr)][0])) {
            $user_info['first_name'] = $attribs[0][strtolower($authLDAPNameAttr)][0];
        }
        // last name
        if (isset($attribs[0][strtolower($authLDAPSecName)][0])) {
            $user_info['last_name'] = $attribs[0][strtolower($authLDAPSecName)][0];
        }
        // mail address
        if (isset($attribs[0][strtolower($authLDAPMailAttr)][0])) {
            $user_info['user_email'] = $attribs[0][strtolower($authLDAPMailAttr)][0];
        }
        // website
        if (isset($attribs[0][strtolower($authLDAPWebAttr)][0])) {
            $user_info['user_url'] = $attribs[0][strtolower($authLDAPWebAttr)][0];
        }
        // display name, nickname, nicename
        if (array_key_exists('first_name', $user_info)) {
            $user_info['display_name'] = $user_info['first_name'];
            $user_info['nickname'] = $user_info['first_name'];
            $user_info['user_nicename'] = sanitize_title_with_dashes($user_info['first_name']);
開發者ID:heiglandreas,項目名稱:authLdap,代碼行數:67,代碼來源:authLdap.php

示例7: roles

	/**
	 * Installed roles and capabilities used for Ecart
	 *
	 * Capabilities						Role
	 * _______________________________________________
	 *
	 * ecart_settings					admin
	 * ecart_settings_checkout
	 * ecart_settings_payments
	 * ecart_settings_shipping
	 * ecart_settings_taxes
	 * ecart_settings_presentation
	 * ecart_settings_system
	 * ecart_settings_update
	 * ecart_financials					merchant
	 * ecart_promotions
	 * ecart_products
	 * ecart_categories
	 * ecart_orders						ecart-csr
	 * ecart_customers
	 * ecart_menu
	 *
	 * @author John Dillick
	 * @since 1.1
	 *
	 **/
	function roles () {
		global $wp_roles; // WP_Roles roles container
		if(!$wp_roles) $wp_roles = new WP_Roles();
		$ecart_roles = array('administrator'=>'Administrator', 'ecart-merchant'=>__('Merchant','Ecart'), 'ecart-csr'=>__('Customer Service Rep','Ecart'));
		$caps['ecart-csr'] = array('ecart_customers', 'ecart_orders','ecart_menu','read');
		$caps['ecart-merchant'] = array_merge($caps['ecart-csr'],
			array('ecart_categories',
				'ecart_products',
				'ecart_promotions',
				'ecart_financials',
				'ecart_export_orders',
				'ecart_export_customers',
				'ecart_delete_orders',
				'ecart_delete_customers'));
		$caps['administrator'] = array_merge($caps['ecart-merchant'],
			array('ecart_settings_update',
				'ecart_settings_system',
				'ecart_settings_presentation',
				'ecart_settings_taxes',
				'ecart_settings_shipping',
				'ecart_settings_payments',
				'ecart_settings_checkout',
				'ecart_settings'));
		$wp_roles->remove_role('ecart-csr');
		$wp_roles->remove_role('ecart-merchant');

		foreach($ecart_roles as $role => $display) {
			if($wp_roles->is_role($role)) {
				foreach($caps[$role] as $cap) $wp_roles->add_cap($role, $cap, true);
			} else {
				$wp_roles->add_role($role, $display, array_combine($caps[$role],array_fill(0,count($caps[$role]),true)));
			}
		}
	}
開發者ID:robbiespire,項目名稱:paQui,代碼行數:60,代碼來源:Install.php

示例8: setupCustomCaps

 private static function setupCustomCaps()
 {
     global $wp_roles;
     if (function_exists('wpcf_access_register_caps')) {
         cred_log('Access Active', 'access.log');
         add_filter('types-access-area', array('CRED_CRED', 'register_access_cred_area'));
         add_filter('types-access-group', array('CRED_CRED', 'register_access_cred_group'), 10, 2);
         add_filter('types-access-cap', array('CRED_CRED', 'register_access_cred_caps'), 10, 3);
     } elseif (function_exists('ure_not_edit_admin') || class_exists('Members_Load')) {
         if (!isset($wp_roles) && class_exists('WP_Roles')) {
             $wp_roles = new WP_Roles();
         }
         $wp_roles->use_db = true;
         if ($wp_roles->is_role('administrator')) {
             $administrator = $wp_roles->get_role('administrator');
         } else {
             $administrator = false;
             trigger_error(__('Administrator Role not found! CRED capabilities will not work', 'wp-cred'), E_USER_NOTICE);
         }
         if ($administrator) {
             $forms = self::getAllFormsCached();
             // register custom CRED Frontend capabilities specific to each form type
             //foreach ($wp_roles as $role)
             //{
             foreach ($forms as $form) {
                 $settings = isset($form->meta) ? maybe_unserialize($form->meta) : false;
                 // caps for forms that create
                 if ($settings && $settings->form_type == 'new') {
                     $cred_cap = 'create_posts_with_cred_' . $form->ID;
                     if (!$administrator->has_cap($cred_cap)) {
                         $wp_roles->add_cap('administrator', $cred_cap);
                     }
                     /*if (!$role->has_cap($cred_cap))
                       $role->add_cap($cred_cap);*/
                 } elseif ($settings && $settings->form_type == 'edit') {
                     $cred_cap = 'edit_own_posts_with_cred_' . $form->ID;
                     if (!$administrator->has_cap($cred_cap)) {
                         $wp_roles->add_cap('administrator', $cred_cap);
                     }
                     /*if (!$role->has_cap($cred_cap))
                       $role->add_cap($cred_cap);*/
                     $cred_cap = 'edit_other_posts_with_cred_' . $form->ID;
                     if (!$administrator->has_cap($cred_cap)) {
                         $wp_roles->add_cap('administrator', $cred_cap);
                     }
                     /*if (!$role->has_cap($cred_cap))
                       $role->add_cap($cred_cap);*/
                 }
             }
             // these caps do not require a specific form
             $cred_cap = 'delete_own_posts_with_cred';
             if (!$administrator->has_cap($cred_cap)) {
                 $wp_roles->add_cap('administrator', $cred_cap);
             }
             /*if (!$role->has_cap($cred_cap))
               $role->add_cap($cred_cap);*/
             $cred_cap = 'delete_other_posts_with_cred';
             if (!$administrator->has_cap($cred_cap)) {
                 $wp_roles->add_cap('administrator', $cred_cap);
             }
             /*if (!$role->has_cap($cred_cap))
               $role->add_cap($cred_cap);*/
         }
         //}
     } else {
         $forms = self::getAllFormsCached();
         // register custom CRED Frontend capabilities specific to each form type
         foreach ($forms as $form) {
             $settings = isset($form->meta) ? maybe_unserialize($form->meta) : false;
             // caps for forms that create
             if ($settings && $settings->form_type == 'new') {
                 $cred_cap = 'create_posts_with_cred_' . $form->ID;
                 self::$caps[] = $cred_cap;
             } elseif ($settings && $settings->form_type == 'edit') {
                 $cred_cap = 'edit_own_posts_with_cred_' . $form->ID;
                 self::$caps[] = $cred_cap;
                 $cred_cap = 'edit_other_posts_with_cred_' . $form->ID;
                 self::$caps[] = $cred_cap;
             }
         }
         // these caps do not require a specific form
         $cred_cap = 'delete_own_posts_with_cred';
         self::$caps[] = $cred_cap;
         $cred_cap = 'delete_other_posts_with_cred';
         self::$caps[] = $cred_cap;
         add_filter('user_has_cap', array('CRED_CRED', 'default_cred_caps_filter'), 5, 3);
     }
 }
開發者ID:adisonc,項目名稱:MaineLearning,代碼行數:88,代碼來源:CRED.php

示例9: array

 /**
  * Adds specified cap(s) to specified role(s)
  *
  * @param String/Array $role_names Role name(s)
  * @param String/Array $caps Capability(-es) to add.
  */
 function add_caps($role_names, $caps)
 {
     $role = new WP_Roles();
     if (!is_array($role_names)) {
         $role_names = array($role_names);
     }
     # add_cap() writes to database on every call if use_db is true, don't need that
     $role->use_db = false;
     foreach ((array) $role_names as $name) {
         if ($role->is_role($name)) {
             foreach ((array) $caps as $cap) {
                 $role->add_cap($name, $cap);
             }
         }
     }
     $role->use_db = true;
     update_option($role->role_key, $role->roles);
 }
開發者ID:farvig,項目名稱:wp-boilerplate,代碼行數:24,代碼來源:class.i8Core.php

示例10: ure_newRoleCreate

function ure_newRoleCreate(&$ure_currentRole) {

  global $wp_roles;
  
  $mess = '';
  $ure_currentRole = '';
  if (isset($_POST['user_role_id']) && $_POST['user_role_id']) {
    $user_role_id = utf8_decode($_POST['user_role_id']);
    // sanitize user input for security
    $valid_name = preg_match('/[A-Za-z0-9_\-]*/', $user_role_id, $match);
    if (!$valid_name || ($valid_name && ($match[0]!=$user_role_id))) { // some non-alphanumeric charactes found!
      return __('Error: Role ID must contain latin characters, digits, hyphens or underscore only!', 'ure');
    }  
        
    if ($user_role_id) {      
      $user_role_name = isset( $_POST['user_role_name']) ? $_POST['user_role_name'] : false;
      if (!empty($user_role_name)) {
        $user_role_name = sanitize_text_field( $user_role_name );      
      } else {
        $user_role_name = $user_role_id;  // as user role name is empty, use user role ID instead
      }
      
      if (!isset($wp_roles)) {
        $wp_roles = new WP_Roles();
      }
      if ( isset( $wp_roles->roles[ $user_role_id ] ) ) {      
        return sprintf( 'Error! '.__('Role %s exists already', 'ure'), $user_role_id );
      }
      $user_role_id = strtolower($user_role_id);
      $ure_currentRole = $user_role_id;
      
      $user_role_copy_from = isset($_POST['user_role_copy_from']) ? $_POST['user_role_copy_from'] : false;
      if ( !empty($user_role_copy_from) && $user_role_copy_from!='none' && $wp_roles->is_role($user_role_copy_from) ) {
        $role = $wp_roles->get_role( $user_role_copy_from );
        $capabilities = $role->capabilities;
      } else {
        $capabilities = array('read'=>1, 'level_0'=>1);
      }
      // add new role to the roles array      
      $result = add_role($user_role_id, $user_role_name, $capabilities);
      if ( !isset($result) || empty($result) ) {
        $mess = 'Error! '.__('Error is encountered during new role create operation', 'ure');
      } else {
        $mess = sprintf(__('Role %s is created successfully', 'ure'), $user_role_name);
      }
    }
  }
  return $mess;
}
開發者ID:Jtgadbois,項目名稱:Pedadida,代碼行數:49,代碼來源:ure-lib.php

示例11: roles

 /**
  * Installed roles and capabilities used for Shopp
  *
  * Capabilities						Role
  * _______________________________________________
  *
  * shopp_settings					admin
  * shopp_settings_checkout
  * shopp_settings_payments
  * shopp_settings_shipping
  * shopp_settings_taxes
  * shopp_settings_presentation
  * shopp_settings_system
  * shopp_settings_update
  * shopp_financials					merchant
  * shopp_promotions
  * shopp_products
  * shopp_categories
  * shopp_export_orders
  * shopp_export_customers
  * shopp_delete_orders
  * shopp_delete_customers
  * shopp_void
  * shopp_refund
  * shopp_orders						shopp-csr
  * shopp_customers
  * shopp_capture
  * shopp_menu
  *
  * @author John Dillick
  * @since 1.1
  *
  * @return void
  **/
 public function roles()
 {
     global $wp_roles;
     // WP_Roles roles container
     if (!$wp_roles) {
         $wp_roles = new WP_Roles();
     }
     $shopp_roles = apply_filters('shopp_user_roles', array('administrator' => 'Administrator', 'shopp-merchant' => __('Merchant', 'Shopp'), 'shopp-csr' => __('Customer Service', 'Shopp')));
     $caps['shopp-csr'] = array('shopp_capture', 'shopp_customers', 'shopp_orders', 'shopp_menu', 'read');
     $caps['shopp-merchant'] = array_merge($caps['shopp-csr'], array('shopp_categories', 'shopp_products', 'shopp_memberships', 'shopp_promotions', 'shopp_financials', 'shopp_export_orders', 'shopp_export_customers', 'shopp_delete_orders', 'shopp_delete_customers', 'shopp_void', 'shopp_refund'));
     $caps['administrator'] = array_merge($caps['shopp-merchant'], array('shopp_settings_update', 'shopp_settings_system', 'shopp_settings_presentation', 'shopp_settings_taxes', 'shopp_settings_shipping', 'shopp_settings_payments', 'shopp_settings_checkout', 'shopp_settings'));
     $caps = apply_filters('shopp_role_caps', $caps, $shopp_roles);
     foreach ($shopp_roles as $role => $display) {
         if ($wp_roles->is_role($role)) {
             foreach ($caps[$role] as $cap) {
                 $wp_roles->add_cap($role, $cap, true);
             }
         } else {
             $wp_roles->add_role($role, $display, array_combine($caps[$role], array_fill(0, count($caps[$role]), true)));
         }
     }
 }
開發者ID:crunnells,項目名稱:shopp,代碼行數:56,代碼來源:Install.php

示例12:

 function create_role_if_missing()
 {
     $wp_roles = new WP_Roles();
     if ($wp_roles->is_role('webmaster')) {
         return;
     }
     $this->deactivate(is_multisite());
     $this->activate(is_multisite());
 }
開發者ID:xingline,項目名稱:wp-webmaster-user-role,代碼行數:9,代碼來源:webmaster-user-role.php

示例13: setupCustomUserCaps

 public static function setupCustomUserCaps()
 {
     global $wp_roles;
     if (function_exists('wpcf_access_register_caps')) {
         // integrate with Types Access
         //cred_log('Access Active', 'access.log');
         add_filter('types-access-area', array(__CLASS__, 'register_access_cred_user_area'));
         add_filter('types-access-group', array(__CLASS__, 'register_access_cred_user_group'), 10, 2);
         add_filter('types-access-cap', array(__CLASS__, 'register_access_cred_user_caps'), 10, 3);
         // do any necessary changes when access imports / exports custom capabilities
         add_filter('access_import_custom_capabilities_' . '__CRED_CRED_USER', array(__CLASS__, 'import_access_cred_user_caps'), 1, 2);
         add_filter('access_export_custom_capabilities_' . '__CRED_CRED_USER', array(__CLASS__, 'export_access_cred_user_caps'), 1, 2);
     } elseif (function_exists('ure_not_edit_admin') || class_exists('Members_Load')) {
         // export custom cred caps to admin role for other plugins to manipulate them (eg User Role Editor or Members)
         if (!isset($wp_roles) && class_exists('WP_Roles')) {
             $wp_roles = new WP_Roles();
         }
         $wp_roles->use_db = true;
         if ($wp_roles->is_role('administrator')) {
             $administrator = $wp_roles->get_role('administrator');
         } else {
             $administrator = false;
             trigger_error(__('Administrator Role not found! CRED Users capabilities will not work', 'wp-cred'), E_USER_NOTICE);
             return;
         }
         if ($administrator) {
             self::addCredUserCapsToRoleUser($administrator);
         }
     } else {
         self::$caps = array_merge(self::$caps, self::buildCredUserCaps());
         add_filter('user_has_cap', array('CRED_Helper', 'defaultCredCapsFilter'), 5, 3);
     }
 }
開發者ID:rebeccayshen,項目名稱:kitlist,代碼行數:33,代碼來源:CRED_Helper.php


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