Sindbad~EG File Manager

Current Path : /var/www/html/taet.readinessglobal.com/wp-content/plugins/userpro1/functions/
Upload File :
Current File : /var/www/html/taet.readinessglobal.com/wp-content/plugins/userpro1/functions/user-functions.php

<?php
/* Find if user is admin by ID */
function userpro_is_admin($user_id)
{

	$user = get_userdata($user_id);
	if($user->user_level >= 10) {
		return TRUE;
	}

	return FALSE;
}

/* Add logout link */
function userpro_logout_link($user_id, $redirect = 'current', $logout_redirect = NULL)
{

	global $current_user, $wp;
	$current_user = wp_get_current_user();
	if($user_id == $current_user->ID) {
		if($redirect == 'current' || !$redirect) {
			$url = get_permalink();
		} else {
			$url = $redirect;
		}
		if($logout_redirect) {
			$url = $logout_redirect;
		}
		?>
        <a class="userpro-small-link" href="<?php echo wp_logout_url($url); ?>"
           title="<?php _e('Logout', 'userpro'); ?>"><?php _e('Logout', 'userpro'); ?></a>
		<?php
	}
}

/* Get logout url */
function userpro_logout_url($user_id, $redirect = 'current', $logout_redirect = NULL)
{

	global $current_user, $wp;
	$current_user = wp_get_current_user();
	if($user_id == $current_user->ID) {
		if($redirect == 'current' || !$redirect) {
			$url = get_permalink();
		} else {
			$url = $redirect;
		}
		if($logout_redirect) {
			$url = $logout_redirect;
		}

		return wp_logout_url($url);
	}
}

/* Add a class to open profile via popup */
function userpro_user_via_popup($args)
{

	if($args['memberlist_popup_view'] || $args['list_popup_view'])
		echo 'popup-view';
}

/* Find if a user cannot edit field */
function userpro_user_cannot_edit($array)
{

	global $current_user;
	if(isset($array['locked']) && $array['locked'] == 1 && !current_user_can('manage_options')) {
		return TRUE;
	}

	return FALSE;
}

/* Privacy of fields */
function userpro_private_field_class($array)
{

	global $current_user;
	if(isset($array['private']) && $array['private'] == 1 && !current_user_can('manage_options'))
		return 'userpro-field-private';

	return '';
}

/* Auto login user */
function userpro_auto_login($username, $remember = TRUE, $redirect = NULL, $action = NULL)
{

	#require user redirects file
	require_once userpro_path . "functions/user-redirects.php";
	ob_start();
	if(!is_user_logged_in()) {
		$user    = get_user_by('login', $username);
		$user_id = $user->ID;
		wp_set_current_user($user_id, $username);
		wp_set_auth_cookie($user_id, $remember);
		do_action('wp_login', $username, $user);

		#Redirect user
		if(isset($action)) {

			$url = userpro_user_redirect($username, $redirect, $action);

			return $url;
		} else {
			userpro_user_redirect($username, $redirect);
		}
		#Redirect end

	} else {
		wp_logout();
		$user    = get_user_by('login', $username);
		$user_id = $user->ID;
		wp_set_current_user($user_id, $username);
		wp_set_auth_cookie($user_id, $remember);
		do_action('wp_login', $username, $user);

	}
	ob_end_flush();
}

/* Can edit user profile */
function userpro_can_edit_user($user_id)
{

	if(current_user_can('edit_users') || $user_id == get_current_user_id())
		return TRUE;

	return FALSE;
}

/* Can delete user profile */
function userpro_can_delete_user($user_id)
{

	if(userpro_get_option('user_can_delete_profile')) {
		if(current_user_can('delete_users') || $user_id == get_current_user_id()) {
			return TRUE;
		}
	}

	return FALSE;
}

function userpro_get_edit_userrole()
{

	global $userpro;
	$array = (array)userpro_get_option('roles_can_edit_profiles');
	$array = array_merge($array, ['administrator']);

	return $userpro->user_role_in_array(get_current_user_id(), $array);

}

/* Get user id to edit */
function userpro_get_edit_user()
{

	global $userpro;
	$array = (array)userpro_get_option('roles_can_edit_profiles');
	$array = array_merge($array, ['administrator']);
	if(userpro_is_logged_in()) {
		if(get_query_var('up_username')) {
			$user = $userpro->get_member_by(get_query_var('up_username'));
			if($user->ID && current_user_can('manage_options') || $user->ID == get_current_user_id()) {
				$user_id = $user->ID;
			} elseif($user->ID && $userpro->user_role_in_array(get_current_user_id(), $array)) {
				$user_id = $user->ID;
			} elseif(!$user->ID && current_user_can('manage_options')) {
				$user_id = 'not_found';
			} elseif($user->ID && !current_user_can('manage_options')) {
				$user_id = 'not_authorized';
			}
		} else {
			global $current_user;
			$current_user = wp_get_current_user();
			$user_id      = $current_user->ID;
		}

		return $user_id;
	}
}

/* Get user id to view */
function userpro_get_view_user($arg = NULL, $force = 0)
{

	global $userpro;
	$user_id = 0;
	if($arg) {
		$user = $userpro->get_member_by($arg, $force);
		if(isset($user))
			if($user->ID || ($user->ID > 0 && $user->ID == get_current_user_id())) {
				$temp_user = $user->ID;
			} elseif(!$user->ID) {
				$temp_user = 'not_found';
			}
	}
	if(userpro_is_logged_in()) {
		if($arg) {
			if(!$userpro->can_view_profile($arg)) {
				$user_id = 'not_authorized';
			} else {
				$user_id = $temp_user;
			}
		} else {
			global $current_user;
			$current_user = wp_get_current_user();
			$user_id      = $current_user->ID;
		}
	} elseif($arg) {
		if(!$userpro->can_view_profile()) {
			$user_id = 'not_authorized';
		} elseif(userpro_get_option('allow_guests_view_profiles')) {
			$user_id = $temp_user;
		} else {
			$user_id = 'login_to_view_others';
		}
	} else {
		/* show him the login form */
		$user_id = 'login_to_view';
	}

	return $user_id;
}

/* Checks if a user is logged in */
function userpro_is_logged_in()
{

	if(is_user_logged_in())
		return TRUE;

	return FALSE;
}

/* Get a profile data for user id */
function userpro_profile_data($field, $user_id)
{

	global $userpro;
	$user   = get_userdata($user_id);
	$output = '';
	if($user != FALSE) {
		switch($field) {
			default:
				$output                 = get_user_meta($user_id, $field, TRUE);
				$default_background_img = userpro_get_option('default_background_img');
				if($field == 'custom_profile_bg' && !empty($default_background_img) && empty($output)) {
					$output = userpro_get_option('default_background_img');
				}

				if(!is_array($output) && strpos(str_replace(' ', '', $output), '">') === 0) {
					$output = substr_replace(trim($output), "", 0, 2);
				}
				$output = str_replace('onerror', 'not allowed', $output);
				$output = str_replace("<script>", "", $output);
				$output = str_replace("</script>", "", $output);
				$output = str_replace("alert", "", $output);
				break;
			case 'id':
				$output = $user_id;
				break;
			case 'display_name':
				$output = $user->display_name;
				if(userpro_get_option('user_display_name') == 'name')
					$output = $userpro->get_full_name($user_id);
				if(userpro_get_option('user_display_name_key'))
					$output = userpro_profile_data(userpro_get_option('user_display_name_key'), $user_id);
				break;
			case 'user_url':
				$output = $user->user_url;
				break;
			case 'user_email':
				$output = $user->user_email;
				break;
			case 'user_login':
				$output = $user->user_login;
				break;
			case 'role':
				$user_roles = $user->roles;
				$user_role  = array_shift($user_roles);
				$output     = $user_role;
				break;
		}
	}

	return $output;
}

/* nicer user role */
function userpro_user_role($role)
{

	global $wp_roles;
	$roles = $wp_roles->get_names();

	return $roles[$role];
}

/* Get nice name of profile field value */
function userpro_profile_data_nicename($field, $value)
{

	$output     = [];
	$get_fields = get_option('userpro_fields');
	if(is_array($value)) {
		foreach($value as $s => $l) {
			$output[] = $l;
		}

		return implode(', ', $output);
	} else {
		//comment for dropdown displaying next numerical value Change by Vipin.
		/*if (isset($get_fields[$field]['options'][$value])){
		return $get_fields[$field]['options'][$value];
		} else {*/

		return $value;
		//}
	}
}

/* HTML returned values */
function userpro_profile_nohtml($value)
{

	return wp_strip_all_tags($value);
}

/* default hidden state for field */
function userpro_field_default_hidden($key, $template, $group)
{

	$groups = get_option('userpro_fields_groups');
	if(isset($groups[$template][$group][$key]['hidden'])) {
		$ret = $groups[$template][$group][$key]['hidden'];
		if($ret == 1) {
			return TRUE;
		}
	}

	return FALSE;
}

/* no args field is viewable */
function userpro_field_is_viewable_noargs($key, $user_id)
{

	if(current_user_can('manage_options'))

		return TRUE;

	if($user_id == get_current_user_id())
		return TRUE;

	$test = get_user_meta($user_id, 'hide_' . $key, TRUE);
	if($test == 1 && $user_id != get_current_user_id())
		return FALSE;

	return TRUE;
}

/* Check if field can be viewed */
function userpro_field_is_viewable($key, $user_id, $args)
{

	if(current_user_can('manage_options'))
		return TRUE;

	if($user_id == get_current_user_id())
		return TRUE;

	if(isset($args[$args['template'] . '_group']) && userpro_field_default_hidden($key, $args['template'], $args[$args['template'] . '_group']))
		return FALSE;

	$test = get_user_meta($user_id, 'hide_' . $key, TRUE);
	if($test == 1 && $user_id != get_current_user_id())
		return FALSE;

	return TRUE;
}

/* Update user profile from google */
function userpro_update_profile_via_google($user_id, $array)
{

	global $userpro;

	$id          = (isset($array['id'])) ? $array['id'] : 0;
	$displayName = (isset($array['user_login'])) ? $array['user_login'] : 0;
	$first_name  = (isset($array['first_name'])) ? $array['first_name'] : '';
	$last_name   = (isset($array['last_name'])) ? $array['last_name'] : '';
	$email       = (isset($array['email'])) ? $array['email'] : 0;
	$url         = (isset($array['url'])) ? $array['url'] : 0;
	$gender      = (isset($array['gender'])) ? $array['gender'] : 0;

	if(userpro_is_logged_in() && ($user_id != get_current_user_id()) && !current_user_can('manage_options'))
		die();

	if($id) {
		update_user_meta($user_id, 'userpro_google_id', $id);
	}

	/* begin display name */
	if($displayName) {
		$display_name = $displayName;
	} else if(isset($first_name) && isset($last_name)) {
		$display_name = $first_name . ' ' . $last_name;
	} else {
		$display_name = $email;
	}

	if($url) {
		update_user_meta($user_id, 'google_plus', $url);
	}

	if($email) {
		wp_update_user(['ID' => $user_id, 'user_email' => $email]);
		update_user_meta($user_id, 'user_email', $email);
	}

	if($gender) {
		update_user_meta($user_id, 'gender', ucfirst($gender));
	}

	if(isset($first_name) && isset($last_name)) {
		update_user_meta($user_id, 'first_name', $first_name);
		update_user_meta($user_id, 'last_name', $last_name);
	}

	do_action('userpro_after_profile_updated_google');

}

/* Update user profile from facebook */
function userpro_update_profile_via_facebook($user_id, $array)
{

	global $userpro;

	$id         = (isset($array['id'])) ? $array['id'] : 0;
	$id         = trim($id);
	$first_name = (isset($array['first_name'])) ? $array['first_name'] : 0;
	$last_name  = (isset($array['last_name'])) ? $array['last_name'] : 0;
	$gender     = (isset($array['gender'])) ? $array['gender'] : 0;
	$link       = (isset($array['link'])) ? $array['link'] : 0;
	$email      = (isset($array['email'])) ? $array['email'] : 0;
	$username   = (isset($array['username'])) ? $array['username'] : 0;

	if(userpro_is_logged_in() && ($user_id != get_current_user_id()) && !current_user_can('manage_options'))
		die();

	if($id && $id != 'undefined') {
		update_user_meta($user_id, 'userpro_facebook_id', $id);
	}

	if($first_name && $first_name != 'undefined') {
		update_user_meta($user_id, 'first_name', $first_name);
	}
	if($last_name && $last_name != 'undefined') {
		update_user_meta($user_id, 'last_name', $last_name);
	}

	if($gender && $gender != 'undefined') {
		update_user_meta($user_id, 'gender', $gender);
	}

	if($link && $link != 'undefined') {
		update_user_meta($user_id, 'facebook', $link);
	}

	/* begin display name */
	if(isset($name) && $name != 'undefined' && $name != 0) {
		$display_name = $name;
	} else if($first_name && $last_name && $first_name != 'undefined' && $last_name != 'undefined') {
		$display_name = $first_name . ' ' . $last_name;
	} else if($email) {
		$display_name = $email;
	} else {
		$display_name = $username;
	}

	if($display_name) {
		if($userpro->display_name_exists($display_name)) {
			$display_name = $userpro->unique_display_name($display_name);
		}
		$display_name = $userpro->remove_denied_chars($display_name);
		wp_update_user(['ID' => $user_id, 'display_name' => $display_name]);
		update_user_meta($user_id, 'display_name', $display_name);
	}
	/* end display name */

	do_action('userpro_after_profile_updated_fb');

}

/* Update user profile data */
function userpro_update_user_profile($user_id, $form, $action=null) {
	global $userpro;
	$template = (isset($form['template'])) ? $form['template'] : 0;
	$group = (isset($form['group'])) ? $form['group'] : 0;

	if ($action == 'new_user' && !$userpro->user_exists($user_id) )
		die();

	if (!$userpro->user_exists($user_id))
		die();

	if ( $action == 'ajax_save' && $user_id != get_current_user_id() && !current_user_can('manage_options') &&  !userpro_get_edit_userrole() )
		die();


	if (!$template) die();

	/* hooks before saving profile fields */
	do_action('userpro_pre_profile_update', $form, $user_id);
	$form = apply_filters('userpro_pre_profile_update_filters', $form, $user_id);
	$email_change = false;
	//validate email change
	if( !userpro_is_admin($user_id) && !current_user_can('manage_options') ){
		global $userpro;
		if (isset($form['user_email'])){
			$old_email = userpro_profile_data('user_email', $user_id);
			$new_email = $form['user_email'];

			//code added by Samir Patil for reverification of email address after changing the email address of the user
			if( $new_email != $old_email ){
				$new_account_salt = wp_generate_password( $length=20, $include_standard_special_chars=false );
				update_user_meta($user_id, '_account_verify', $new_account_salt);
				update_user_meta($user_id, '_account_status', 'pending');
				userpro_mail($user_id, 'verifyemail_change', null, $form );
				$email_change = true;
			}
		}
	}

	$fields = userpro_fields_group_by_template( $template, $group );
	$allfields=get_option('userpro_fields_groups');
	$editfields=$allfields['edit']['default'];

	foreach($form as $key => $form_value) {
	    if($action !== 'new_user'){
            if( isset($editfields[$key]['locked']) && $editfields[$key]['locked'] == 1 && !current_user_can('manage_options') ){
                continue;
            }
        }


		//$form_value = esc_attr($form_value);  // Commented to solve Array issue
		/* hidden from public */
		if (!isset($form["hide_$key"])) {
			update_user_meta( $user_id, 'hide_'.$key, 0 );
		} elseif (isset($form["hide_$key"])){
			update_user_meta( $user_id, 'hide_'.$key, 1 );
		}

		/* UPDATE PRIMARY META */
		if ( isset($key) && in_array($key, array('user_url', 'display_name', 'role', 'user_login', 'user_pass', 'user_pass_confirm', 'user_email')) ) {

			/* Save passwords */
			if ($key == 'user_pass') {
				if (!empty($form_value)) {
					wp_update_user( array ( 'ID' => $user_id, $key => $form_value ) ) ;
					if($action != 'new_user')
						userpro_mail($user_id, 'passwordchange', $form_value);
				}
			} else {
				if($key=='role' && $form[$key]=='administrator' && !is_admin()){
					continue;
				}
				else{
					wp_update_user( array ( 'ID' => $user_id, $key => $form_value ) ) ;
				}
			}

		}

		/* delete unused uploads */
		if ( ( isset($fields[$key]['type']) && $fields[$key]['type'] == 'picture' || isset($fields[$key]['type']) && $fields[$key]['type'] == 'file'  ) && isset($form_value) && !empty($form_value) && basename($form_value) != basename( userpro_profile_data( $key, $user_id ) ) ) {
			$userpro->delete_file($user_id, $key);
		}


		if (isset($key) && !strstr($key, 'pass')){

			$countrylist=get_option('userpro_fields');
			if(isset($countrylist['billing_country']['options']))
				$country=$countrylist['billing_country']['options'];
			if($key=='billing_country' )
			{

				foreach($country as $country_code => $country_name)
				{

					if($country_name==$form_value)
					{
						$form_value = $country_code;

						update_user_meta( $user_id, $key, $form_value );
					}
				}

			}


			if($key=='shipping_country' )
			{
				foreach($country as $country_code => $country_name)
				{

					if($country_name==$form_value)
					{
						$form_value = $country_code;

						update_user_meta( $user_id, $key, $form_value );
					}
				}
			}
			else
			{
				update_user_meta( $user_id, $key, $form_value );
			}



		} else {
			delete_user_meta( $user_id, $key );
		}

		/* move user pics to his folder */
		if ( ( isset($fields[$key]['type']) && $fields[$key]['type'] == 'picture' || isset($fields[$key]['type']) && $fields[$key]['type'] == 'file'  ) && isset($form_value) && !empty($form_value) ) {

			$userpro->do_uploads_dir( $user_id );

			if ( file_exists( $userpro->get_uploads_dir() . basename( userpro_profile_data( $key, $user_id ) ) ) ) {
				rename( $userpro->get_uploads_dir() . basename( userpro_profile_data( $key, $user_id ) ),  $userpro->get_uploads_dir($user_id) . basename( userpro_profile_data( $key, $user_id ) ) );

				update_user_meta($user_id, $key, $userpro->get_uploads_url($user_id) . basename( userpro_profile_data( $key, $user_id ) ) );
				if( $key == 'profilepicture' ){
					$meta_value = get_user_meta( $user_id, 'up-timeline-actions', true );
					$timeline_actions = empty($meta_value)?array():$meta_value;
					$timestamp = time();
					$timeline_actions[] = array( 'action'=>'profilepic_update', 'timestamp'=>$timestamp );
					update_user_meta( $user_id, 'up-timeline-actions', $timeline_actions );
				}
			}

		}
		/* MailChimp Integration */
		if ( ( isset($fields[$key]['type']) && $fields[$key]['type'] == 'mailchimp') ) {
			if ($form[$key] == 'unsubscribed'){
				if(userpro_get_option('aweber_api')!='' && userpro_get_option('aweber_listname')!='')
					$userpro->makeAweberSubscribeEntry($user_id);
				if(userpro_get_option('Campaignmonitor_listname')!='' && userpro_get_option('Campaignmonitor_api')!='')
					$userpro->makeCampaignmonitorEntry($user_id);
				$userpro->mailchimp_subscribe( $user_id, $fields[$key]['list_id'] );
			} elseif ($form[$key] == 'subscribed') {

				$userpro->mailchimp_unsubscribe( $user_id, $fields[$key]['list_id'] );
			}
		}

	}

	foreach($editfields as $editfieldkey=>$editfieldvalue)
	{
		if(isset($editfieldvalue['type']))
			if($editfieldvalue['type']=='checkbox-full' || $editfieldvalue['type']=='multiselect'  || $editfieldvalue['type']=='checkbox')
			{
				if (!array_key_exists($editfieldkey,$form))
				{
					delete_user_meta($user_id,$editfieldkey);

				}

			}

	}

	/* do action while updating profile (use $form) */
	do_action('userpro_profile_update', $form, $user_id);

	/* after profile update no args */
	do_action('userpro_after_profile_updated');

	return $email_change;

}



/******************************************
 * Check if profile exist if yes add to existing profile @Kiro.Tech
 ******************************************/

function social_profile_check($user_email, $id, $type)
{

	# get user by email

	$user = get_user_by('email', $user_email);

	if(!empty($user)) {

		switch($type) {

			case 'linkedin';

				$exist_linkedin = get_user_meta($user->ID, 'userpro_linkedin_id', $id);

				if(empty($exist_linkedin))
					update_user_meta($user->ID, 'userpro_linkedin_id', $id);

				return $user->user_login;

				break;

			case 'google';

				$exist_google = get_user_meta($user->ID, 'userpro_google_id', $id);

				if(empty($exist_google))
					update_user_meta($user->ID, 'userpro_google_id', $id);

				return $user->user_login;

				break;

			case 'facebook';

				$exist_google = get_user_meta($user->ID, 'userpro_facebook_id', $id);

				if(empty($exist_google))
					update_user_meta($user->ID, 'userpro_facebook_id', $id);

				return $user->user_login;

				break;

		}

	} else {

		return FALSE;
	}

}

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists