Files
ultimatemember/includes/core/um-actions-core.php
T

88 lines
2.7 KiB
PHP
Raw Normal View History

2014-12-15 22:38:07 +02:00
<?php
2017-12-18 15:36:04 +02:00
// Exit if accessed directly
if ( ! defined( 'ABSPATH' ) ) exit;
2014-12-15 22:38:07 +02:00
2017-02-19 13:22:12 +08:00
/**
* Processes the requests of UM actions
*/
2015-01-05 01:33:17 +02:00
add_action('init','um_action_request_process', 10);
function um_action_request_process(){
if ( is_admin() ) return false;
2016-06-27 16:57:02 +08:00
if ( ! is_user_logged_in() ) return false;
if ( ! isset( $_REQUEST['um_action'] ) ) return false;
if ( isset( $_REQUEST['uid'] ) && ! UM()->user()->user_exists_by_id( $_REQUEST['uid'] ) ) return false;
2015-01-05 01:33:17 +02:00
if ( isset( $_REQUEST['uid'] ) ) {
if ( is_super_admin( $_REQUEST['uid'] ) )
wp_die( __( 'Super administrators can not be modified.','ultimate-member' ) );
2015-01-11 19:07:55 +02:00
}
2016-06-27 16:57:02 +08:00
2016-06-29 09:14:59 +08:00
if ( isset( $_REQUEST['um_action'] ) && $_REQUEST['um_action'] != "edit" && ! current_user_can( 'edit_users' ) ){
wp_die( __( 'You do not have enough permissions to do that.','ultimate-member') );
2016-06-27 16:57:02 +08:00
}
2015-01-11 19:07:55 +02:00
if ( isset($_REQUEST['uid'])){
2015-04-15 16:59:27 +02:00
$uid = $_REQUEST['uid'];
2015-01-05 01:33:17 +02:00
}
switch( $_REQUEST['um_action'] ) {
2015-04-07 20:10:23 +02:00
default:
$uid = ( isset( $_REQUEST['uid'] ) ) ? $_REQUEST['uid'] : 0;
do_action('um_action_user_request_hook', $_REQUEST['um_action'], $uid);
break;
2015-04-15 16:59:27 +02:00
2015-01-05 01:33:17 +02:00
case 'edit':
UM()->fields()->editing = true;
2015-01-05 01:33:17 +02:00
if ( !um_can_edit_my_profile() ) {
$url = um_edit_my_profile_cancel_uri();
exit( wp_redirect( $url ) );
}
break;
2015-04-15 16:59:27 +02:00
case 'um_switch_user':
if ( !current_user_can('delete_users') ) return;
UM()->user()->auto_login( $_REQUEST['uid'] );
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-04-15 16:59:27 +02:00
break;
2015-01-05 01:33:17 +02:00
case 'um_reject_membership':
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->reject();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
case 'um_approve_membership':
case 'um_reenable':
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->approve();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
case 'um_put_as_pending':
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->pending();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
case 'um_resend_activation':
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->email_pending();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
case 'um_deactivate':
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->deactivate();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
case 'um_delete':
if ( ! UM()->roles()->um_current_user_can( 'delete', $uid ) ) wp_die( __('You do not have permission to delete this user.','ultimate-member') );
2015-01-11 19:07:55 +02:00
um_fetch_user( $uid );
UM()->user()->delete();
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
2015-01-05 01:33:17 +02:00
break;
}
2014-12-15 22:38:07 +02:00
}