2015-01-07 08:37:25 +02:00
|
|
|
<?php
|
|
|
|
|
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
/***
|
2016-06-24 17:01:48 +08:00
|
|
|
*** @Global Access Settings
|
2015-01-07 08:37:25 +02:00
|
|
|
***/
|
|
|
|
|
add_action('um_access_global_settings','um_access_global_settings');
|
|
|
|
|
function um_access_global_settings() {
|
|
|
|
|
global $post, $ultimatemember;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
$access = um_get_option('accessible');
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-06-22 16:02:22 +08:00
|
|
|
if ( $access == 2 && ! is_user_logged_in() ) {
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
$redirect = um_get_option('access_redirect');
|
2016-06-24 17:01:48 +08:00
|
|
|
if ( !$redirect ){
|
2015-04-07 20:10:23 +02:00
|
|
|
$redirect = um_get_core_page('login');
|
2016-06-24 17:01:48 +08:00
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-02-11 00:50:38 +02:00
|
|
|
$redirects[] = untrailingslashit( um_get_core_page('login') );
|
|
|
|
|
$redirects[] = untrailingslashit( um_get_option('access_redirect') );
|
|
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
$exclude_uris = um_get_option('access_exclude_uris');
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
if ( $exclude_uris ) {
|
|
|
|
|
$redirects = array_merge( $redirects, $exclude_uris );
|
|
|
|
|
}
|
2015-04-07 20:10:23 +02:00
|
|
|
|
2015-02-24 18:30:11 +02:00
|
|
|
$redirects = array_unique( $redirects );
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-28 17:16:04 +02:00
|
|
|
$current_url = $ultimatemember->permalinks->get_current_url( get_option('permalink_structure') );
|
2015-02-11 00:50:38 +02:00
|
|
|
$current_url = untrailingslashit( $current_url );
|
2015-02-24 18:30:11 +02:00
|
|
|
$current_url_slash = trailingslashit( $current_url );
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
if ( ( isset( $post->ID ) ) && ( in_array( $current_url, $redirects ) || in_array( $current_url_slash, $redirects ) ) ) {
|
2015-02-24 18:30:11 +02:00
|
|
|
// allow
|
2016-06-24 17:01:48 +08:00
|
|
|
}else {
|
2015-01-07 08:37:25 +02:00
|
|
|
$ultimatemember->access->redirect_handler = $redirect;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-06-21 23:03:41 +08:00
|
|
|
|
2016-06-22 16:02:22 +08:00
|
|
|
$current_page_type = um_get_current_page_type();
|
|
|
|
|
|
|
|
|
|
do_action("um_access_post_type",$current_page_type);
|
|
|
|
|
do_action("um_access_post_type_{$current_page_type}");
|
|
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
|
2016-08-16 21:28:29 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/***
|
|
|
|
|
*** @Custom User homepage redirection
|
|
|
|
|
***/
|
|
|
|
|
add_action("um_access_user_custom_homepage","um_access_user_custom_homepage");
|
|
|
|
|
function um_access_user_custom_homepage(){
|
|
|
|
|
global $ultimatemember;
|
|
|
|
|
|
|
|
|
|
if( ! is_user_logged_in() ) return;
|
|
|
|
|
if( ! is_front_page() ) return;
|
|
|
|
|
|
|
|
|
|
$role_meta = $ultimatemember->query->role_data( um_user('role') );
|
|
|
|
|
|
|
|
|
|
if( isset( $role_meta['default_homepage'] ) && $role_meta['default_homepage'] == 0 ){
|
|
|
|
|
|
|
|
|
|
if( ! empty( $role_meta['redirect_homepage'] ) ){
|
|
|
|
|
wp_redirect( $role_meta['redirect_homepage'] ); exit;
|
|
|
|
|
}else{
|
|
|
|
|
wp_redirect( um_get_core_page('user') ); exit;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/***
|
|
|
|
|
*** @Front page access settings
|
|
|
|
|
***/
|
|
|
|
|
add_action('um_access_frontpage_per_role','um_access_frontpage_per_role');
|
|
|
|
|
function um_access_frontpage_per_role() {
|
|
|
|
|
global $ultimatemember, $post;
|
|
|
|
|
|
|
|
|
|
if ( is_admin() ) return;
|
|
|
|
|
if ( ! is_front_page() ) return;
|
2016-08-16 21:00:10 +08:00
|
|
|
if( is_404() ) return;
|
2016-07-04 00:21:23 +08:00
|
|
|
|
2016-07-04 15:36:43 +08:00
|
|
|
if ( ! isset( $um_post_id ) && isset( $post->ID ) ){
|
2016-07-04 00:21:23 +08:00
|
|
|
$um_post_id = $post->ID;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-04 15:36:43 +08:00
|
|
|
if( ! isset( $um_post_id ) ){
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
|
|
|
|
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
|
|
|
|
|
|
|
|
|
$um_post_id = apply_filters('um_access_control_for_parent_posts', $um_post_id );
|
|
|
|
|
|
|
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
|
|
|
|
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$redirect_to = null;
|
|
|
|
|
|
|
|
|
|
if ( !isset( $accessible ) ) return;
|
|
|
|
|
|
|
|
|
|
switch( $accessible ) {
|
|
|
|
|
|
|
|
|
|
case 0:
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = false; // open to everyone
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
|
|
$redirect_to = esc_url( $access_redirect2 );
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( ! empty( $redirect_to ) ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
|
|
|
|
}else{
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("login");
|
|
|
|
|
}else{
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("user");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
|
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
|
|
|
|
|
if ( empty( $access_redirect ) ) {
|
|
|
|
|
$access_redirect = um_get_core_page('login');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$redirect_to = esc_url( $access_redirect );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() && isset( $access_roles ) && !empty( $access_roles ) ){
|
|
|
|
|
$access_roles = unserialize( $access_roles );
|
|
|
|
|
$access_roles = array_filter($access_roles);
|
|
|
|
|
|
|
|
|
|
if ( !empty( $access_roles ) && !in_array( um_user('role'), $access_roles ) ) {
|
2016-08-16 21:00:10 +08:00
|
|
|
if ( empty( $access_redirect ) ) {
|
2016-07-04 00:21:23 +08:00
|
|
|
if ( is_user_logged_in() ) {
|
|
|
|
|
$access_redirect = esc_url( site_url() );
|
|
|
|
|
} else {
|
|
|
|
|
$access_redirect = esc_url( um_get_core_page('login') );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$redirect_to = esc_url( $access_redirect );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/***
|
|
|
|
|
*** @Posts page access settings
|
|
|
|
|
***/
|
|
|
|
|
add_action('um_access_homepage_per_role','um_access_homepage_per_role');
|
|
|
|
|
function um_access_homepage_per_role() {
|
|
|
|
|
global $ultimatemember, $post;
|
|
|
|
|
|
|
|
|
|
if ( is_admin() ) return;
|
2016-08-16 21:00:10 +08:00
|
|
|
if ( ! is_home() ) return;
|
|
|
|
|
if ( is_404() ) return;
|
2016-07-04 00:21:23 +08:00
|
|
|
|
2016-07-04 15:36:43 +08:00
|
|
|
$access = um_get_option('accessible');
|
|
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
$show_on_front = get_option( 'show_on_front' );
|
2016-07-04 15:36:43 +08:00
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
if( $show_on_front == "page" ){
|
2016-07-04 15:36:43 +08:00
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
$um_post_id = get_option( 'page_for_posts' );
|
2016-07-04 15:36:43 +08:00
|
|
|
|
|
|
|
|
if ( $access == 2 && ! is_user_logged_in() ) {
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
}else{
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}else if( $show_on_front == "posts" ){
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
2016-07-04 00:21:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ( isset( $um_post_id ) ){
|
|
|
|
|
|
|
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
|
|
|
|
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
|
|
|
|
|
|
|
|
|
$um_post_id = apply_filters('um_access_control_for_parent_posts', $um_post_id );
|
|
|
|
|
|
|
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
|
|
|
|
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$redirect_to = null;
|
|
|
|
|
|
|
|
|
|
if ( !isset( $accessible ) ) return;
|
|
|
|
|
|
|
|
|
|
switch( $accessible ) {
|
|
|
|
|
|
|
|
|
|
case 0:
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = false; // open to everyone
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
|
|
$redirect_to = esc_url( $access_redirect2 );
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( ! empty( $redirect_to ) ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
|
|
|
|
}else{
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("login");
|
|
|
|
|
}else{
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("user");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
|
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
|
|
|
|
|
if ( empty( $access_redirect ) ) {
|
|
|
|
|
$access_redirect = um_get_core_page('login');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$redirect_to = esc_url( $access_redirect );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() && isset( $access_roles ) && !empty( $access_roles ) ){
|
|
|
|
|
$access_roles = unserialize( $access_roles );
|
|
|
|
|
$access_roles = array_filter($access_roles);
|
|
|
|
|
|
|
|
|
|
if ( !empty( $access_roles ) && !in_array( um_user('role'), $access_roles ) ) {
|
|
|
|
|
if ( !$access_redirect ) {
|
|
|
|
|
if ( is_user_logged_in() ) {
|
|
|
|
|
$access_redirect = esc_url( site_url() );
|
|
|
|
|
} else {
|
|
|
|
|
$access_redirect = esc_url( um_get_core_page('login') );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$redirect_to = esc_url( $access_redirect );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-01-07 08:37:25 +02:00
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-07-04 00:21:23 +08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
/***
|
2016-06-24 17:01:48 +08:00
|
|
|
*** @Archieves/Taxonomies/Categories access settings
|
2015-11-05 19:51:31 +08:00
|
|
|
***/
|
|
|
|
|
add_action('um_access_category_settings','um_access_category_settings');
|
|
|
|
|
function um_access_category_settings() {
|
|
|
|
|
global $post, $wp_query, $ultimatemember;
|
2015-12-16 16:37:27 +08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
if ( is_front_page() ||
|
|
|
|
|
is_home() ||
|
|
|
|
|
is_feed() ||
|
2016-08-16 21:00:10 +08:00
|
|
|
is_page() ||
|
|
|
|
|
is_404()
|
2016-06-24 17:01:48 +08:00
|
|
|
) {
|
|
|
|
|
|
2015-12-16 16:37:27 +08:00
|
|
|
return;
|
2016-06-24 17:01:48 +08:00
|
|
|
|
2015-12-16 16:37:27 +08:00
|
|
|
}
|
2016-01-07 10:41:49 +08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
$access = um_get_option('accessible');
|
|
|
|
|
$current_page_type = um_get_current_page_type();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( is_category() && ! in_array( $current_page_type , array( 'day','month','year','author','archive' ) ) ){
|
2016-06-22 16:02:22 +08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
$um_category = get_the_category();
|
|
|
|
|
$um_category = current( $um_category );
|
|
|
|
|
$term_id = $um_category->term_id;
|
|
|
|
|
|
|
|
|
|
if( isset( $term_id ) ){
|
|
|
|
|
|
|
|
|
|
$opt = get_option("category_$term_id");
|
|
|
|
|
|
|
|
|
|
if ( isset( $opt['_um_accessible'] ) ) {
|
2016-06-22 16:02:22 +08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
$redirect = false;
|
|
|
|
|
|
|
|
|
|
switch( $opt['_um_accessible'] ) {
|
|
|
|
|
|
|
|
|
|
case 0:
|
|
|
|
|
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = ''; // open to everyone
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
|
2016-08-16 17:10:57 +08:00
|
|
|
if( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ) {
|
2016-06-24 17:01:48 +08:00
|
|
|
$redirect = esc_url( $opt['_um_redirect'] );
|
|
|
|
|
}else{
|
|
|
|
|
$redirect = site_url();
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-06-24 21:20:15 +08:00
|
|
|
$ultimatemember->access->allow_access = false;
|
2016-06-24 17:01:48 +08:00
|
|
|
$ultimatemember->access->redirect_handler = $redirect;
|
|
|
|
|
|
2016-06-24 21:20:15 +08:00
|
|
|
if ( ! is_user_logged_in() && ! empty( $redirect ) ){
|
2016-06-24 17:01:48 +08:00
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
|
|
|
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
|
|
|
|
|
if( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ){
|
|
|
|
|
$redirect = esc_url( $opt['_um_redirect'] );
|
|
|
|
|
}else{
|
|
|
|
|
$redirect = um_get_core_page('login');
|
|
|
|
|
}
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
$ultimatemember->access->redirect_handler = $redirect;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() && isset( $opt['_um_roles'] ) && !empty( $opt['_um_roles'] ) ){
|
|
|
|
|
if ( ! in_array( um_user('role'), $opt['_um_roles'] ) ) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( isset( $opt['_um_redirect'] ) ){
|
|
|
|
|
$redirect = esc_url( $opt['_um_redirect'] );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$ultimatemember->access->redirect_handler = $redirect;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-06-22 16:02:22 +08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
} else if ( $access == 2 && ! is_user_logged_in() && is_archive() ) {
|
|
|
|
|
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
$redirect = um_get_core_page('login');
|
|
|
|
|
$ultimatemember->access->redirect_handler = $redirect;
|
|
|
|
|
|
|
|
|
|
} else if ( is_tax() && get_post_taxonomies( $post ) ) {
|
2015-11-25 20:37:42 +08:00
|
|
|
|
2016-01-07 10:41:49 +08:00
|
|
|
$taxonomies = get_post_taxonomies( $post );
|
|
|
|
|
$categories_ids = array();
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-01-07 10:41:49 +08:00
|
|
|
foreach ($taxonomies as $key => $value) {
|
|
|
|
|
$term_list = wp_get_post_terms($post->ID, $value, array("fields" => "ids"));
|
|
|
|
|
foreach( $term_list as $term_id ){
|
|
|
|
|
array_push( $categories_ids , $term_id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach( $categories_ids as $term => $term_id ) {
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
$opt = get_option("category_$term_id");
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( isset( $opt['_um_accessible'] ) ) {
|
|
|
|
|
switch( $opt['_um_accessible'] ) {
|
2016-02-20 18:10:09 -08:00
|
|
|
|
|
|
|
|
case 0:
|
2015-11-05 19:51:31 +08:00
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = false; // open to everyone
|
|
|
|
|
break;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
case 1:
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( is_user_logged_in() )
|
2016-08-16 17:10:57 +08:00
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) && !empty( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : site_url();
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( !is_user_logged_in() )
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
break;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
case 2:
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-25 20:37:42 +08:00
|
|
|
if ( ! is_user_logged_in() )
|
|
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : um_get_core_page('login');
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( is_user_logged_in() && isset( $opt['_um_roles'] ) && !empty( $opt['_um_roles'] ) ){
|
|
|
|
|
if ( !in_array( um_user('role'), $opt['_um_roles'] ) ) {
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( is_user_logged_in() )
|
2015-12-22 17:45:12 +08:00
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : site_url();
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
if ( !is_user_logged_in() )
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page('login');
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
}
|
|
|
|
|
}
|
2015-12-16 18:15:40 +08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
}
|
|
|
|
|
}
|
2016-06-24 17:01:48 +08:00
|
|
|
|
2015-11-05 19:51:31 +08:00
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-07 08:37:25 +02:00
|
|
|
/***
|
2016-06-24 17:01:48 +08:00
|
|
|
*** @Posts/Page access settings
|
2015-01-07 08:37:25 +02:00
|
|
|
***/
|
|
|
|
|
add_action('um_access_post_settings','um_access_post_settings');
|
|
|
|
|
function um_access_post_settings() {
|
|
|
|
|
global $post, $ultimatemember;
|
2016-06-22 16:02:22 +08:00
|
|
|
|
2015-01-24 23:39:43 +02:00
|
|
|
// woo commerce shop ID
|
|
|
|
|
if( function_exists('is_shop') && is_shop() ) {
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
$um_post_id = get_option('woocommerce_shop_page_id');
|
|
|
|
|
|
|
|
|
|
} else if (
|
2016-07-03 15:34:11 +08:00
|
|
|
is_category() ||
|
|
|
|
|
is_archive() ||
|
|
|
|
|
is_search() ||
|
|
|
|
|
in_the_loop() ||
|
|
|
|
|
is_feed() ||
|
|
|
|
|
is_tax() ||
|
|
|
|
|
! get_post_type() ||
|
|
|
|
|
! isset( $post->ID ) ||
|
2016-07-04 00:21:23 +08:00
|
|
|
is_home() ||
|
2016-08-16 21:00:10 +08:00
|
|
|
is_front_page() ||
|
|
|
|
|
is_404()
|
2016-06-24 17:01:48 +08:00
|
|
|
) {
|
2016-04-16 16:40:14 +08:00
|
|
|
|
2015-01-26 16:58:31 +02:00
|
|
|
return;
|
|
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
}
|
2015-01-24 23:39:43 +02:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
if ( !isset( $um_post_id ) ){
|
|
|
|
|
$um_post_id = $post->ID;
|
2015-01-24 23:39:43 +02:00
|
|
|
}
|
2015-01-26 16:58:31 +02:00
|
|
|
|
2016-06-24 17:01:48 +08:00
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
2015-01-24 23:39:43 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
// Check for parent page's custom access settings
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$um_post_id = apply_filters('um_access_control_for_parent_posts', $um_post_id );
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$args = $ultimatemember->access->get_meta( $um_post_id );
|
|
|
|
|
extract( $args );
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// post's category restriction
|
|
|
|
|
if ( !isset( $args['custom_access_settings'] ) || $args['custom_access_settings'] == 0 ) {
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$categories = get_the_category( $post->ID );
|
2016-08-16 17:10:57 +08:00
|
|
|
foreach( $categories as $cat ){
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$opt = get_option("category_{$cat->term_id}");
|
2016-08-16 17:10:57 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( isset( $opt['_um_accessible'] ) ) {
|
|
|
|
|
switch( $opt['_um_accessible'] ) {
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 0: // Open to everyone
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = false; // open to everyone
|
|
|
|
|
break;
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 1: // Logged out users only
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 17:10:57 +08:00
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : site_url();
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
}
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( !is_user_logged_in() )
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
break;
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 2: // Logged in users only
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : um_get_core_page('login');
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
2016-07-27 20:43:05 +08:00
|
|
|
}
|
|
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
|
|
|
|
|
if( isset( $opt['_um_roles'] ) && !empty( $opt['_um_roles'] ) ){
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( in_array( um_user('role'), $opt['_um_roles'] ) ) {
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
|
|
|
|
|
}else{
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$ultimatemember->access->redirect_handler = ( isset( $opt['_um_redirect'] ) && ! empty( $opt['_um_redirect'] ) ) ? $opt['_um_redirect'] : site_url();
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
|
|
|
|
|
}
|
2016-07-27 20:43:05 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
}else{ // if allowed all roles
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2015-01-26 16:58:31 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
} // end if isset( $opt['_um_accessible'] )
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
// if one of the categories has enabled restriction, apply its settings to the current post
|
|
|
|
|
if( $ultimatemember->access->allow_access == false ){
|
|
|
|
|
return;
|
|
|
|
|
}
|
2015-01-07 08:37:25 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
} // end foreach
|
|
|
|
|
}
|
2015-01-07 08:37:25 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
// post restriction
|
2016-08-17 12:10:53 +08:00
|
|
|
if ( isset( $args['custom_access_settings'] ) && $args['custom_access_settings'] == 1 ) {
|
2016-08-16 16:46:22 +08:00
|
|
|
|
|
|
|
|
$redirect_to = null;
|
2015-01-07 08:37:25 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( !isset( $accessible ) ) return;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
switch( $accessible ) {
|
2016-01-07 10:41:49 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 0:
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
$ultimatemember->access->redirect_handler = false; // open to everyone
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
break;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 1:
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
$redirect_to = esc_url( $access_redirect2 );
|
|
|
|
|
|
|
|
|
|
if ( is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( ! empty( $redirect_to ) ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
2016-06-26 20:12:37 +08:00
|
|
|
}else{
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("login");
|
|
|
|
|
}else{
|
|
|
|
|
$ultimatemember->access->redirect_handler = um_get_core_page("user");
|
|
|
|
|
}
|
2016-06-26 20:12:37 +08:00
|
|
|
}
|
2016-06-26 16:35:08 +08:00
|
|
|
|
|
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
break;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
case 2:
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( ! is_user_logged_in() ){
|
2016-06-15 15:58:13 +08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( empty( $access_redirect ) ) {
|
|
|
|
|
$access_redirect = um_get_core_page('login');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$redirect_to = esc_url( $access_redirect );
|
2016-06-15 15:58:13 +08:00
|
|
|
}
|
2015-02-21 01:39:02 +02:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( is_user_logged_in() && isset( $access_roles ) && !empty( $access_roles ) ){
|
|
|
|
|
$access_roles = unserialize( $access_roles );
|
|
|
|
|
$access_roles = array_filter($access_roles);
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
if ( !empty( $access_roles ) && !in_array( um_user('role'), $access_roles ) ) {
|
|
|
|
|
if ( !$access_redirect ) {
|
|
|
|
|
if ( is_user_logged_in() ) {
|
|
|
|
|
$access_redirect = esc_url( site_url() );
|
|
|
|
|
} else {
|
|
|
|
|
$access_redirect = esc_url( um_get_core_page('login') );
|
|
|
|
|
}
|
2015-11-05 19:51:31 +08:00
|
|
|
}
|
2016-08-16 16:46:22 +08:00
|
|
|
$redirect_to = esc_url( $access_redirect );
|
2015-11-05 19:51:31 +08:00
|
|
|
}
|
2015-01-07 08:37:25 +02:00
|
|
|
}
|
2016-08-16 16:46:22 +08:00
|
|
|
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $redirect_to );
|
|
|
|
|
|
|
|
|
|
break;
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-08-16 16:46:22 +08:00
|
|
|
}
|
2015-01-07 08:37:25 +02:00
|
|
|
}
|
2016-02-20 18:10:09 -08:00
|
|
|
|
2016-06-21 23:03:41 +08:00
|
|
|
if( um_is_core_page('user') && ! is_user_logged_in() ){
|
|
|
|
|
$ultimatemember->access->allow_access = false;
|
|
|
|
|
$ultimatemember->access->redirect_handler = esc_url( $access_redirect );
|
|
|
|
|
wp_redirect( $ultimatemember->access->redirect_handler );
|
|
|
|
|
exit;
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-20 18:10:09 -08:00
|
|
|
}
|
2016-06-28 16:55:38 +08:00
|
|
|
|
|
|
|
|
/***
|
|
|
|
|
*** @Profile Access
|
|
|
|
|
***/
|
|
|
|
|
add_action('um_access_profile','um_access_profile');
|
|
|
|
|
function um_access_profile( $user_id ){
|
|
|
|
|
|
|
|
|
|
if( ! um_is_myprofile() && um_is_core_page('user') && ! current_user_can('edit_users') ){
|
|
|
|
|
|
|
|
|
|
um_fetch_user( $user_id );
|
|
|
|
|
|
|
|
|
|
if( ! in_array( um_user('account_status'), array('approved') ) ){
|
|
|
|
|
um_redirect_home();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
um_reset_user();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|