*/ class AAM_Backend_View { /** * Instance of itself * * @var AAM_Backend_View * * @access private */ private static $_instance = null; /** * Construct the view object * * @return void * * @access protected */ protected function __construct() { //register default features AAM_Backend_Feature_Main_GetStarted::register(); AAM_Backend_Feature_Main_Policy::register(); AAM_Backend_Feature_Main_Menu::register(); AAM_Backend_Feature_Main_Toolbar::register(); AAM_Backend_Feature_Main_Metabox::register(); AAM_Backend_Feature_Main_Capability::register(); AAM_Backend_Feature_Main_Route::register(); AAM_Backend_Feature_Main_Post::register(); AAM_Backend_Feature_Main_Redirect::register(); AAM_Backend_Feature_Main_LoginRedirect::register(); AAM_Backend_Feature_Main_LogoutRedirect::register(); AAM_Backend_Feature_Main_404Redirect::register(); AAM_Backend_Feature_Main_Uri::register(); AAM_Backend_Feature_Settings_Core::register(); AAM_Backend_Feature_Settings_Content::register(); AAM_Backend_Feature_Settings_Security::register(); AAM_Backend_Feature_Settings_ConfigPress::register(); //feature registration hook do_action('aam-feature-registration-action'); } /** * Clear all AAM settings * * @global wpdb $wpdb * * @return string * * @access public */ public function clearSettings() { AAM_Core_API::clearSettings(); return wp_json_encode(array('status' => 'success')); } /** * * @return type */ public function clearCache() { AAM_Core_API::clearCache(); return wp_json_encode(array('status' => 'success')); } /** * Run the Manager * * @return string * * @access public */ public function renderPage() { ob_start(); require_once dirname(__FILE__) . '/phtml/index.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * Run the Manager * * @return string * * @access public */ public function renderAccessFrame() { ob_start(); require_once dirname(__FILE__) . '/phtml/metabox/metabox-content.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * * @param type $post * @return type */ public function renderPostMetabox($post) { ob_start(); require_once dirname(__FILE__) . '/phtml/metabox/post-metabox.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * * @param type $post * @return type */ public function renderPolicyMetabox($post) { ob_start(); require_once dirname(__FILE__) . '/phtml/metabox/policy-metabox.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * * @param type $post * @return type */ public function renderPolicyPrincipalMetabox($post) { ob_start(); require_once dirname(__FILE__) . '/phtml/metabox/policy-principal-metabox.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * * @param type $term * @return type */ public function renderTermMetabox($term) { ob_start(); require_once dirname(__FILE__) . '/phtml/metabox/term-metabox.phtml'; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * Process the ajax call * * @return string * * @access public */ public function processAjax() { $response = null; $action = AAM_Core_Request::request('sub_action'); $parts = explode('.', $action); if (method_exists($this, $parts[0])) { $response = call_user_func(array($this, $parts[0])); } elseif (count($parts) === 2) { //cover the Model.method pattern try { $classname = 'AAM_Backend_Feature_' . $parts[0]; if (class_exists($classname)) { $response = call_user_func(array(new $classname, $parts[1])); } } catch (Exception $e) { $response = $e->getMessage(); } } return apply_filters( 'aam-ajax-filter', $response, AAM_Backend_Subject::getInstance()->get(), $action ); } /** * Render the Main Control Area * * @param string $type * * @return void * * @access public */ public function renderContent($type = 'main') { $content = apply_filters('aam-ui-content-filter', null, $type); if (is_null($content)) { ob_start(); if ($type === 'extensions') { AAM_Backend_Feature_Extension_Manager::getInstance()->render(); } elseif ($type === 'postform') { echo AAM_Backend_Feature_Main_Post::renderAccessForm(); } else { require_once dirname(__FILE__) . '/phtml/main-panel.phtml'; } $content = ob_get_contents(); ob_end_clean(); } return $content; } /** * * @param type $partial * @return type */ public function loadPartial($partial) { ob_start(); require_once dirname(__FILE__) . '/phtml/partial/' . $partial; $content = ob_get_contents(); ob_end_clean(); return $content; } /** * Save AAM options * * Important notice! This function excepts "value" to be only boolean value * * @return string * * @access public */ public function save() { $object = trim(AAM_Core_Request::post('object')); $objectId = intval(AAM_Core_Request::post('objectId', 0)); $param = AAM_Core_Request::post('param'); $value = filter_input(INPUT_POST, 'value'); $result = AAM_Backend_Subject::getInstance()->save( $param, $value, $object, $objectId ); return wp_json_encode(array('status' => ($result ? 'success' : 'failure'))); } /** * * @return type */ public function reset() { return AAM_Backend_Subject::getInstance()->resetObject( AAM_Core_Request::post('object') ); } /** * * @return type */ public function switchToUser() { $response = array( 'status' => 'failure', 'reason' => 'You are not allowed to switch to this user' ); if (current_user_can('aam_switch_users')) { $user = new WP_User(AAM_Core_Request::post('user')); $max = AAM_Core_API::maxLevel(wp_get_current_user()->allcaps); if ($max >= AAM_Core_API::maxLevel($user->allcaps)) { AAM_Core_API::updateOption( 'aam-user-switch-' . $user->ID, get_current_user_id() ); // Making sure that user that we are switching too is not logged in // already. Reported by https://github.com/KenAer $sessions = WP_Session_Tokens::get_instance($user->ID); if (count($sessions->get_all()) > 1) { $sessions->destroy_all(); } // If there is jwt token in cookie, make sure it is deleted otherwise // user technically will never be switched if (AAM_Core_Request::cookie('aam-jwt')) { setcookie( 'aam-jwt', '', time() - YEAR_IN_SECONDS, '/', parse_url(get_bloginfo('url'), PHP_URL_HOST), is_ssl() ); } wp_clear_auth_cookie(); wp_set_auth_cookie( $user->ID, true ); wp_set_current_user( $user->ID ); $response = array('status' => 'success', 'redirect' => admin_url()); } } return wp_json_encode($response); } /** * Get instance of itself * * @return AAM_Backend_View * * @access public */ public static function getInstance() { if (is_null(self::$_instance)) { self::$_instance = new self; } return self::$_instance; } }