*/ class AAM_Backend_View { /** * Instance of itself * * @var AAM_Backend_View * * @access private */ private static $_instance = null; /** * Current Subject * * @var AAM_Core_Subject * * @access private */ private static $_subject = null; /** * Construct the view object * * @return void * * @access protected */ protected function __construct() { $classname = 'AAM_Core_Subject_' . ucfirst( AAM_Core_Request::request('subject') ); if (class_exists($classname)) { $this->setSubject(new $classname( stripslashes(AAM_Core_Request::request('subjectId')) )); } //register default features AAM_Backend_Feature_Menu::register(); AAM_Backend_Feature_Metabox::register(); AAM_Backend_Feature_Capability::register(); AAM_Backend_Feature_Post::register(); AAM_Backend_Feature_Redirect::register(); AAM_Backend_Feature_Teaser::register(); AAM_Backend_Feature_LoginRedirect::register(); AAM_Backend_Feature_Extension::register(); AAM_Backend_Feature_Security::register(); AAM_Backend_Feature_Utility::register(); AAM_Backend_Feature_Contact::register(); AAM_Backend_Feature_404Redirect::register(); //feature registration hook do_action('aam-feature-registration'); } /** * 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 renderMetabox() { global $post; if (is_a($post, 'WP_Post')) { $url = admin_url('admin.php?page=aam&oid=' . $post->ID . '&otype=post#post'); ob_start(); require_once(dirname(__FILE__) . '/phtml/metabox.phtml'); $content = ob_get_contents(); ob_end_clean(); } else { $content = null; } 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, $this->getSubject(), $action ); } /** * Render the Main Control Area * * @return void * * @access public */ public function renderContent() { ob_start(); 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_var( AAM_Core_Request::post('value'), FILTER_VALIDATE_BOOLEAN ); $result = $this->getSubject()->save($param, $value, $object, $objectId); return json_encode(array('status' => ($result ? 'success' : 'failure'))); } /** * * @return type */ public function switchToUser() { $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() ); wp_clear_auth_cookie(); wp_set_auth_cookie( $user->ID, true ); wp_set_current_user( $user->ID ); $response = array('status' => 'success', 'redirect' => admin_url()); } else { $response = array( 'status' => 'failure', 'reason' => 'You are not allowed to switch to this user' ); } return json_encode($response); } /** * Get Subject * * @return AAM_Core_Subject * * @access public */ public static function getSubject() { return self::$_subject; } /** * Set Subject * * @param AAM_Core_Subject $subject * * @return void * * @access public */ protected function setSubject(AAM_Core_Subject $subject) { self::$_subject = $subject; } /** * 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; } }