| Server IP : 27.254.66.5 / Your IP : 216.73.217.39 Web Server : Apache/2 System : Linux cs82.hostneverdie.com 3.10.0-1160.45.1.el7.x86_64 #1 SMP Wed Oct 13 17:20:51 UTC 2021 x86_64 User : technic2 ( 1951) PHP Version : 7.4.30 Disable Function : apache_child_terminate, apache_setenv, define_syslog_variables, escapeshellarg, escapeshellcmd,exec, fp, fput, highlight_file, ini_alter, ini_restore, inject_code, passthru,phpAds_remoteInfo, phpAds_XmlRpc,phpAds_xmlrpcDecode, phpAds_xmlrpcEncode, popen, posix_getpwuid, posix_kill, posix_mkfifo, posix_setpgid, posix_setsid,posix_setuid, posix_setuid, posix_uname,proc_open,proc_close, proc_get_status, proc_nice, proc_terminate, shell_exec, syslog, system, xmlrpc_entity_decode, show_source,sleep,pcntl_exec,virtual,suexec,dbmopen,dl,symlink,disk_free_space,diskfreespace,leak MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /home/technic2/public_html/old-website/wp-content/plugins/members/inc/ |
Upload File : |
<?php
/**
* User-related functions and filters.
*
* @package Members
* @subpackage Includes
* @author Justin Tadlock <justintadlock@gmail.com>
* @copyright Copyright (c) 2009 - 2018, Justin Tadlock
* @link https://themehybrid.com/plugins/members
* @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
*/
// Filter `user_has_cap` if denied caps should take precedence.
if ( members_explicitly_deny_caps() ) {
add_filter( 'user_has_cap', 'members_user_has_cap_filter', 10, 4 );
}
/**
* Filter on `user_has_cap` to explicitly deny caps if there are conflicting caps when a
* user has multiple roles. WordPress doesn't consistently handle two or more roles that
* have the same capability but a conflict between being granted or denied. Core WP
* merges the role caps so that the last role the user has will take precedence. This
* has the potential for granting permission for things that a user shouldn't have
* permission to do.
*
* @since 1.0.0
* @access public
* @param array $allcaps
* @param array $caps
* @param array $args
* @param object $user
* @return array
*/
function members_user_has_cap_filter( $allcaps, $caps, $args, $user ) {
// If the user doesn't have more than one role, bail.
if ( 1 >= count( (array) $user->roles ) )
return $allcaps;
// Get the denied caps.
$denied_caps = array_keys( $allcaps, false );
// Loop through the user's roles and find any denied caps.
foreach ( (array) $user->roles as $role ) {
// Get the role object.
$role_obj = get_role( $role );
// If we have an object, merge it's denied caps.
if ( ! is_null( $role_obj ) )
$denied_caps = array_merge( $denied_caps, array_keys( $role_obj->capabilities, false ) );
}
// If there are any denied caps, make sure they take precedence.
if ( $denied_caps ) {
foreach ( $denied_caps as $denied_cap ) {
$allcaps[ $denied_cap ] = false;
}
}
// Return all the user caps.
return $allcaps;
}
/**
* Conditional tag to check whether a user has a specific role.
*
* @since 1.0.0
* @access public
* @param int $user_id
* @param string|array $roles
* @return bool
*/
function members_user_has_role( $user_id, $roles ) {
$user = new WP_User( $user_id );
foreach ( (array) $roles as $role ) {
if ( in_array( $role, (array) $user->roles ) )
return true;
}
return false;
}
/**
* Conditional tag to check whether the currently logged-in user has a specific role.
*
* @since 1.0.0
* @access public
* @param string|array $roles
* @return bool
*/
function members_current_user_has_role( $roles ) {
return is_user_logged_in() ? members_user_has_role( get_current_user_id(), $roles ) : false;
}
/**
* Wrapper for `current_user_can()` that checks if the user can perform any action.
* Accepts an array of caps instead of a single cap.
*
* @since 2.0.0
* @access public
* @param array $caps
* @return bool
*/
function members_current_user_can_any( $caps = array() ) {
foreach ( $caps as $cap ) {
if ( current_user_can( $cap ) )
return true;
}
return false;
}
/**
* Wrapper for `current_user_can()` that checks if the user can perform all actions.
* Accepts an array of caps instead of a single cap.
*
* @since 2.0.0
* @access public
* @param array $caps
* @return bool
*/
function members_current_user_can_all( $caps = array() ) {
foreach ( $caps as $cap ) {
if ( ! current_user_can( $cap ) )
return false;
}
return true;
}
/**
* Returns an array of the role names a user has.
*
* @since 1.0.0
* @access public
* @param int $user_id
* @return array
*/
function members_get_user_role_names( $user_id ) {
$user = new WP_User( $user_id );
$names = array();
foreach ( $user->roles as $role )
$names[ $role ] = members_get_role( $role )->get( 'label' );
return $names;
}