wp-access-area.php 1.9 KB
<?php

if ( ! defined( 'ABSPATH' ) ) exit; 

if( !is_plugin_active( 'wp-access-areas/wp-access-areas.php' ) ){
	return;
}

class ACUI_WP_Access_Area{
	function __construct(){
    }

    function hooks(){
        add_filter( 'acui_restricted_fields', array( $this, 'restricted_fields' ), 10, 1 );
        add_action( 'post_acui_import_single_user', array( $this, 'import' ), 10, 3 );
    }

    function restricted_fields( $acui_restricted_fields ){
		return array_merge( $acui_restricted_fields, array( 'wp-access-areas' ) );
    }
    
    function import( $headers, $row, $user_id ){
		$pos = array_search( 'wp-access-areas', $headers );

		if( $pos === FALSE )
			return;

        $wpaa_labels = WPAA_AccessArea::get_available_userlabels(); 
        $active_labels = array_map( 'trim', explode( "#", $row[ $pos ] ) );

        foreach( $wpaa_labels as $wpa_label ){
            if( in_array( $wpa_label->cap_title , $active_labels )){
                $this->set_cap_for_user( $wpa_label->capability , $user_object , true );
            }
            else{
                $this->set_cap_for_user( $wpa_label->capability , $user_object , false );
            }
        }
    }
    
    function set_cap_for_user( $capability , &$user , $add ) {
        $has_cap = $user->has_cap( $capability );
        $is_change = ($add && ! $has_cap) || (!$add && $has_cap);
        if ( $is_change ) {
            if ( $add ) {
                $user->add_cap( $capability , true );
                do_action( 'wpaa_grant_access' , $user , $capability );
                do_action( "wpaa_grant_{$capability}" , $user );
            } else if ( ! $add ) {
                $user->remove_cap( $capability );
                do_action( 'wpaa_revoke_access' , $user , $capability );
                do_action( "wpaa_revoke_{$capability}" , $user );
            }
        }
    }
}

$acui_wp_access_area = new ACUI_WP_Access_Area();
$acui_wp_access_area->hooks();