mirror of
https://github.com/10h30/ultimatemember.git
synced 2026-06-05 15:09:37 +09:00
494 lines
16 KiB
PHP
494 lines
16 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Submit account page changes
|
|
*/
|
|
add_action('um_submit_account_details','um_submit_account_details');
|
|
function um_submit_account_details( $args ) {
|
|
global $ultimatemember;
|
|
|
|
$tab = ( get_query_var('um_tab') ) ? get_query_var('um_tab') : 'general';
|
|
|
|
if ( $_POST['user_password'] && $_POST['confirm_user_password'] ) {
|
|
$changes['user_pass'] = $_POST['user_password'];
|
|
|
|
$args['id'] = um_user('ID');
|
|
|
|
do_action('send_password_change_email', $args );
|
|
|
|
wp_set_password( $changes['user_pass'], um_user('ID') );
|
|
|
|
wp_signon( array('user_login' => um_user('user_login'), 'user_password' => $changes['user_pass']) );
|
|
}
|
|
|
|
$arr_fields = array();
|
|
$account_fields = get_user_meta( um_user('ID'), 'um_account_secure_fields', true );
|
|
$secure_fields = apply_filters('um_secure_account_fields', $account_fields , um_user('ID') );
|
|
|
|
if( isset( $secure_fields ) ){
|
|
foreach ( $secure_fields as $tab_key => $fields ) {
|
|
if( isset( $fields ) ){
|
|
foreach ($fields as $key => $value) {
|
|
$arr_fields[ ] = $key;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
$changes = array();
|
|
foreach( $_POST as $k => $v ) {
|
|
if ( !strstr( $k, 'password' ) && !strstr( $k, 'um_account' ) && in_array( $k, $arr_fields ) ) {
|
|
$changes[ $k ] = $v;
|
|
}
|
|
}
|
|
|
|
if ( isset( $changes['hide_in_members'] ) && $changes['hide_in_members'] == __('No','ultimate-member') ) {
|
|
delete_user_meta( um_user('ID'), 'hide_in_members' );
|
|
unset( $changes['hide_in_members'] );
|
|
}
|
|
|
|
// fired on account page, just before updating profile
|
|
do_action('um_account_pre_update_profile', $changes, um_user('ID') );
|
|
|
|
$ultimatemember->user->update_profile( $changes );
|
|
|
|
// delete account
|
|
$user = get_user_by('login', um_user('user_login') );
|
|
$current_tab = isset( $_POST['_um_account_tab'] ) ? $_POST['_um_account_tab']: '';
|
|
|
|
if ( isset( $_POST['single_user_password'] ) && wp_check_password( $_POST['single_user_password'], $user->data->user_pass, $user->data->ID ) && $current_tab == 'delete' ) {
|
|
if ( current_user_can('delete_users') || um_user('can_delete_profile') ) {
|
|
if ( !um_user('super_admin') ) {
|
|
$ultimatemember->user->delete();
|
|
if ( um_user('after_delete') && um_user('after_delete') == 'redirect_home' ) {
|
|
um_redirect_home();
|
|
} elseif ( um_user('delete_redirect_url') ) {
|
|
exit( wp_redirect( um_user('delete_redirect_url') ) );
|
|
} else {
|
|
um_redirect_home();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
do_action('um_post_account_update');
|
|
|
|
do_action('um_after_user_account_updated', get_current_user_id() );
|
|
|
|
$url = $ultimatemember->account->tab_link( $tab );
|
|
|
|
$url = add_query_arg( 'updated', 'account', $url );
|
|
|
|
if ( function_exists('icl_get_current_language') ) {
|
|
if ( icl_get_current_language() != icl_get_default_language() ) {
|
|
$url = $ultimatemember->permalinks->get_current_url( true );
|
|
$url = add_query_arg( 'updated', 'account', $url );
|
|
exit( wp_redirect( $url ) );
|
|
}
|
|
}
|
|
|
|
exit( wp_redirect( $url ) );
|
|
|
|
}
|
|
|
|
/**
|
|
* Validate for errors in account form
|
|
*/
|
|
add_action('um_submit_account_errors_hook','um_submit_account_errors_hook');
|
|
function um_submit_account_errors_hook( $args ) {
|
|
global $ultimatemember;
|
|
|
|
$current_tab = isset( $_POST['_um_account_tab'] ) ? $_POST['_um_account_tab']: '';
|
|
$user = get_user_by('login', um_user('user_login') );
|
|
|
|
if( isset( $_POST['_um_account_tab'] ) && $current_tab != "delete" ){
|
|
// errors on general tab
|
|
if ( isset($_POST['um_account_submit']) ) {
|
|
|
|
if( $current_tab != 'password' ){
|
|
|
|
$account_name_require = um_get_option("account_name_require");
|
|
|
|
if ( isset($_POST['first_name']) && ( strlen(trim( $_POST['first_name'] ) ) == 0 && $account_name_require ) ) {
|
|
$ultimatemember->form->add_error('first_name', __('You must provide your first name','ultimate-member') );
|
|
}
|
|
|
|
if ( isset($_POST['last_name']) && ( strlen(trim( $_POST['last_name'] ) ) == 0 && $account_name_require ) ) {
|
|
$ultimatemember->form->add_error('last_name', __('You must provide your last name','ultimate-member') );
|
|
}
|
|
|
|
if ( isset($_POST['user_email']) && strlen(trim( $_POST['user_email'] ) ) == 0 ) {
|
|
$ultimatemember->form->add_error('user_email', __('You must provide your e-mail','ultimate-member') );
|
|
}
|
|
|
|
if ( isset($_POST['user_email']) && !is_email( $_POST['user_email'] ) ) {
|
|
$ultimatemember->form->add_error('user_email', __('Please provide a valid e-mail','ultimate-member') );
|
|
}
|
|
|
|
if ( email_exists( $_POST['user_email'] ) && email_exists( $_POST['user_email'] ) != get_current_user_id() ) {
|
|
$ultimatemember->form->add_error('user_email', __('Email already linked to another account','ultimate-member') );
|
|
}
|
|
}
|
|
|
|
}
|
|
$ultimatemember->account->current_tab = 'general';
|
|
|
|
// change password
|
|
if ( ( isset( $_POST['current_user_password'] ) && $_POST['current_user_password'] != '' ) ||
|
|
( isset( $_POST['user_password'] ) && $_POST['user_password'] != '' ) ||
|
|
( isset( $_POST['confirm_user_password'] ) && $_POST['confirm_user_password'] != '') ) {
|
|
|
|
if ( $_POST['current_user_password'] == '' || ! wp_check_password( $_POST['current_user_password'], $user->data->user_pass, $user->data->ID ) ) {
|
|
|
|
$ultimatemember->form->add_error('current_user_password', __('This is not your password','ultimate-member') );
|
|
$ultimatemember->account->current_tab = 'password';
|
|
} else { // correct password
|
|
|
|
if ( $_POST['user_password'] != $_POST['confirm_user_password'] && $_POST['user_password'] ) {
|
|
$ultimatemember->form->add_error('user_password', __('Your new password does not match','ultimate-member') );
|
|
$ultimatemember->account->current_tab = 'password';
|
|
}
|
|
|
|
if ( um_get_option('account_require_strongpass') ) {
|
|
|
|
if ( strlen( utf8_decode( $_POST['user_password'] ) ) < 8 ) {
|
|
$ultimatemember->form->add_error('user_password', __('Your password must contain at least 8 characters','ultimate-member') );
|
|
}
|
|
|
|
if ( strlen( utf8_decode( $_POST['user_password'] ) ) > 30 ) {
|
|
$ultimatemember->form->add_error('user_password', __('Your password must contain less than 30 characters','ultimate-member') );
|
|
}
|
|
|
|
if ( !$ultimatemember->validation->strong_pass( $_POST['user_password'] ) ) {
|
|
$ultimatemember->form->add_error('user_password', __('Your password must contain at least one lowercase letter, one capital letter and one number','ultimate-member') );
|
|
$ultimatemember->account->current_tab = 'password';
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! empty( $_POST['user_login'] ) && ! validate_username( $_POST['user_login'] ) ) {
|
|
$ultimatemember->form->add_error('user_login', __('Your username is invalid','ultimate-member') );
|
|
return;
|
|
}
|
|
}
|
|
// delete account
|
|
if ( isset( $_POST['um_account_submit'] ) && $_POST['_um_account_tab'] == "delete" ) {
|
|
if ( strlen(trim( $_POST['single_user_password'] ) ) == 0 ) {
|
|
$ultimatemember->form->add_error('single_user_password', __('You must enter your password','ultimate-member') );
|
|
} else {
|
|
if ( ! wp_check_password( $_POST['single_user_password'], $user->data->user_pass, $user->data->ID ) ) {
|
|
$ultimatemember->form->add_error('single_user_password', __('This is not your password','ultimate-member') );
|
|
}
|
|
}
|
|
|
|
$ultimatemember->account->current_tab = 'delete';
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Hidden inputs for account form
|
|
*/
|
|
add_action('um_account_page_hidden_fields','um_account_page_hidden_fields');
|
|
function um_account_page_hidden_fields( $args ) {
|
|
global $ultimatemember;
|
|
?>
|
|
|
|
<input type="hidden" name="_um_account" id="_um_account" value="1" />
|
|
|
|
<?php $current_tab = $ultimatemember->account->current_tab; ?>
|
|
|
|
<input type="hidden" name="_um_account_tab" id="_um_account_tab" value="<?php echo $current_tab;?>" />
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
/**
|
|
* Display "Delete" tab
|
|
*/
|
|
add_action('um_account_tab__delete', 'um_account_tab__delete');
|
|
function um_account_tab__delete( $info ) {
|
|
global $ultimatemember;
|
|
extract( $info );
|
|
|
|
$output = $ultimatemember->account->get_tab_output('delete');
|
|
|
|
if ( $output ) { ?>
|
|
|
|
<div class="um-account-heading uimob340-hide uimob500-hide"><i class="<?php echo $icon; ?>"></i><?php echo $title; ?></div>
|
|
|
|
<?php echo wpautop( um_get_option('delete_account_text') ); ?>
|
|
|
|
<?php echo $output; ?>
|
|
|
|
<?php do_action('um_after_account_delete'); ?>
|
|
|
|
<div class="um-col-alt um-col-alt-b">
|
|
<div class="um-left"><input type="submit" name="um_account_submit" id="um_account_submit" value="<?php _e('Delete Account','ultimate-member'); ?>" class="um-button" /></div>
|
|
<?php do_action('um_after_account_delete_button'); ?>
|
|
<div class="um-clear"></div>
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Display "Privacy" tab
|
|
*/
|
|
add_action('um_account_tab__privacy', 'um_account_tab__privacy');
|
|
function um_account_tab__privacy( $info ) {
|
|
global $ultimatemember;
|
|
extract( $info );
|
|
|
|
$output = $ultimatemember->account->get_tab_output('privacy');
|
|
|
|
if ( $output ) { ?>
|
|
|
|
<div class="um-account-heading uimob340-hide uimob500-hide"><i class="<?php echo $icon; ?>"></i><?php echo $title; ?></div>
|
|
|
|
<?php echo $output; ?>
|
|
|
|
<?php do_action('um_after_account_privacy'); ?>
|
|
|
|
<div class="um-col-alt um-col-alt-b">
|
|
<div class="um-left"><input type="submit" name="um_account_submit" id="um_account_submit" value="<?php _e('Update Privacy','ultimate-member'); ?>" class="um-button" /></div>
|
|
<?php do_action('um_after_account_privacy_button'); ?>
|
|
<div class="um-clear"></div>
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Display "General" tab
|
|
*/
|
|
add_action('um_account_tab__general', 'um_account_tab__general');
|
|
function um_account_tab__general( $info ) {
|
|
global $ultimatemember;
|
|
extract( $info );
|
|
|
|
$output = $ultimatemember->account->get_tab_output('general');
|
|
|
|
if ( $output ) { ?>
|
|
|
|
<div class="um-account-heading uimob340-hide uimob500-hide"><i class="<?php echo $icon; ?>"></i><?php echo $title; ?></div>
|
|
|
|
<?php echo $output; ?>
|
|
|
|
<?php do_action('um_after_account_general'); ?>
|
|
|
|
<div class="um-col-alt um-col-alt-b">
|
|
<div class="um-left"><input type="submit" name="um_account_submit" id="um_account_submit" value="<?php _e('Update Account','ultimate-member'); ?>" class="um-button" /></div>
|
|
<?php do_action('um_after_account_general_button'); ?>
|
|
<div class="um-clear"></div>
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Display "Password" tab
|
|
*/
|
|
add_action('um_account_tab__password', 'um_account_tab__password');
|
|
function um_account_tab__password( $info ) {
|
|
global $ultimatemember;
|
|
extract( $info );
|
|
|
|
$output = $ultimatemember->account->get_tab_output('password');
|
|
|
|
if ( $output ) { ?>
|
|
|
|
<div class="um-account-heading uimob340-hide uimob500-hide"><i class="<?php echo $icon; ?>"></i><?php echo $title; ?></div>
|
|
|
|
<?php echo $output; ?>
|
|
|
|
<?php do_action('um_after_account_password'); ?>
|
|
|
|
<div class="um-col-alt um-col-alt-b">
|
|
<div class="um-left"><input type="submit" name="um_account_submit" id="um_account_submit" value="<?php _e('Update Password','ultimate-member'); ?>" class="um-button" /></div>
|
|
<?php do_action('um_after_account_password_button'); ?>
|
|
<div class="um-clear"></div>
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Display "Notifications" tab
|
|
*/
|
|
add_action('um_account_tab__notifications', 'um_account_tab__notifications');
|
|
function um_account_tab__notifications( $info ) {
|
|
global $ultimatemember;
|
|
extract( $info );
|
|
|
|
$output = $ultimatemember->account->get_tab_output('notifications');
|
|
|
|
if ( $output ) { ?>
|
|
|
|
<div class="um-account-heading uimob340-hide uimob500-hide"><i class="<?php echo $icon; ?>"></i><?php echo $title; ?></div>
|
|
|
|
<?php if ( class_exists('UM_Messaging_API') || class_exists('UM_Followers_API') ) { ?>
|
|
<div class="um-field">
|
|
<div class="um-field-label"><label for=""><?php _e('Email me when','ultimate-member'); ?></label><div class="um-clear"></div></div>
|
|
</div>
|
|
<?php } ?>
|
|
|
|
<?php echo $output; ?>
|
|
|
|
<?php do_action('um_after_account_notifications'); ?>
|
|
|
|
<div class="um-col-alt um-col-alt-b">
|
|
<div class="um-left"><input type="submit" name="um_account_submit" id="um_account_submit" value="<?php _e('Update Notifications','ultimate-member'); ?>" class="um-button" /></div>
|
|
<?php do_action('um_after_account_notifications_button'); ?>
|
|
<div class="um-clear"></div>
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Display account photo and username in mobile
|
|
*/
|
|
add_action('um_account_user_photo_hook__mobile', 'um_account_user_photo_hook__mobile');
|
|
function um_account_user_photo_hook__mobile( $args ) {
|
|
global $ultimatemember;
|
|
extract( $args );
|
|
|
|
?>
|
|
|
|
<div class="um-account-meta radius-<?php echo um_get_option('profile_photocorner'); ?> uimob340-show uimob500-show">
|
|
|
|
<div class="um-account-meta-img"><a href="<?php echo um_user_profile_url(); ?>"><?php echo get_avatar( um_user('ID'), 120); ?></a></div>
|
|
|
|
<div class="um-account-name">
|
|
<a href="<?php echo um_user_profile_url(); ?>"><?php echo um_user('display_name'); ?></a>
|
|
<div class="um-account-profile-link"><a href="<?php echo um_user_profile_url(); ?>" class="um-link"><?php _e('View profile','ultimate-member'); ?></a></div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
/**
|
|
* Display account photo and username
|
|
*/
|
|
add_action('um_account_user_photo_hook', 'um_account_user_photo_hook');
|
|
function um_account_user_photo_hook( $args ) {
|
|
global $ultimatemember;
|
|
extract( $args );
|
|
|
|
?>
|
|
|
|
<div class="um-account-meta radius-<?php echo um_get_option('profile_photocorner'); ?>">
|
|
|
|
<div class="um-account-meta-img uimob800-hide"><a href="<?php echo um_user_profile_url(); ?>"><?php echo get_avatar( um_user('ID'), 120); ?></a></div>
|
|
|
|
<?php if ( $ultimatemember->mobile->isMobile() ) { ?>
|
|
|
|
<div class="um-account-meta-img-b uimob800-show" title="<?php echo um_user('display_name'); ?>"><a href="<?php echo um_user_profile_url(); ?>"><?php echo get_avatar( um_user('ID'), 120); ?></a></div>
|
|
|
|
<?php } else { ?>
|
|
|
|
<div class="um-account-meta-img-b uimob800-show um-tip-w" title="<?php echo um_user('display_name'); ?>"><a href="<?php echo um_user_profile_url(); ?>"><?php echo get_avatar( um_user('ID'), 120); ?></a></div>
|
|
|
|
<?php } ?>
|
|
|
|
<div class="um-account-name uimob800-hide">
|
|
<a href="<?php echo um_user_profile_url(); ?>"><?php echo um_user('display_name', 'html'); ?></a>
|
|
<div class="um-account-profile-link"><a href="<?php echo um_user_profile_url(); ?>" class="um-link"><?php _e('View profile','ultimate-member'); ?></a></div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
/**
|
|
* Display account page tabs
|
|
*/
|
|
add_action('um_account_display_tabs_hook', 'um_account_display_tabs_hook');
|
|
function um_account_display_tabs_hook( $args ) {
|
|
global $ultimatemember;
|
|
extract( $args );
|
|
|
|
$ultimatemember->account->tabs = apply_filters('um_account_page_default_tabs_hook', $tabs=array() );
|
|
|
|
ksort( $ultimatemember->account->tabs );
|
|
|
|
?>
|
|
|
|
<ul>
|
|
|
|
<?php
|
|
|
|
foreach( $ultimatemember->account->tabs as $k => $arr ) {
|
|
foreach( $arr as $id => $info ) { extract( $info );
|
|
|
|
$current_tab = $ultimatemember->account->current_tab;
|
|
|
|
if ( isset($info['custom']) || um_get_option('account_tab_'.$id ) == 1 || $id == 'general' ) { ?>
|
|
|
|
<li>
|
|
<a data-tab="<?php echo $id; ?>" href="<?php echo $ultimatemember->account->tab_link($id); ?>" class="um-account-link <?php if ( $id == $current_tab ) echo 'current'; ?>">
|
|
|
|
<?php if ( $ultimatemember->mobile->isMobile() ) { ?>
|
|
<span class="um-account-icontip uimob800-show" title="<?php echo $title; ?>"><i class="<?php echo $icon; ?>"></i></span>
|
|
<?php } else { ?>
|
|
<span class="um-account-icontip uimob800-show um-tip-w" title="<?php echo $title; ?>"><i class="<?php echo $icon; ?>"></i></span>
|
|
<?php } ?>
|
|
|
|
<span class="um-account-icon uimob800-hide"><i class="<?php echo $icon; ?>"></i></span>
|
|
<span class="um-account-title uimob800-hide"><?php echo $title; ?></span>
|
|
<span class="um-account-arrow uimob800-hide"><?php echo ( is_rtl() ) ? '<i class="um-faicon-angle-left"></i>' : '<i class="um-faicon-angle-right"></i>'; ?></span>
|
|
</a>
|
|
</li>
|
|
|
|
<?php
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
?>
|
|
|
|
</ul>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
/**
|
|
* Update account fields to secure the account submission
|
|
*/
|
|
add_action('wp_footer','um_account_secure_registered_fields');
|
|
function um_account_secure_registered_fields(){
|
|
global $ultimatemember;
|
|
|
|
$secure_fields = $ultimatemember->account->register_fields;
|
|
update_user_meta( um_user('ID'), 'um_account_secure_fields', $secure_fields );
|
|
|
|
}
|