/**
  * Initialize Page Manager
  *
  * ## Overview
  *
  * @uses SatanBarbaraApp
  * @uses SessionManager
  * @uses ViewManager
  * @uses DebugManager
  * @uses RouteManager
  * @uses PageView
  *
  * @see RouteManager
  *
  * @param array An array of creds for SendGrid API.
  * @return true Always unless fatal error or exception is thrown.
  *
  * @version 2015-07-05.1
  * @since 0.5.1b
  * @author TronNet DevOps [Sean Murray] <*****@*****.**>
  */
 public static function Init($params)
 {
     DebugManager::Log("Initializing Page Manager", '@');
     DebugManager::Log($params);
     $appConfig = SatanBarbaraApp::GetConfig();
     /**
      * @todo have config in it's own 'config' position instead of array_merge
      */
     $data = array('app' => array_merge($appConfig[SATANBARBARA_CURRENT_ENVIRONMENT], array()), 'page' => $params);
     DebugManager::Log("checking if logged in...", null, 3);
     if (SessionManager::IsLoggedIn()) {
         $data['session'] = array('is_auth' => true, 'account' => SessionManager::GetAccount());
         DebugManager::Log("Got an account, checking for a saved program...", null, 3);
     }
     $Page = ucfirst($params['page']) . 'View';
     DebugManager::Log("Searching for view with class name: " . $Page);
     if ($Page::HasAccess(SessionManager::GetAccessLevel())) {
         $Page::Init($data);
         ViewManager::Render($Page);
     } else {
         DebugManager::Log("looks like this page requires auth but user isn't authenticated!");
         RouteManager::GoToPageURI('login');
     }
     return true;
 }
 public static function Init($requestParams)
 {
     $appConfig = SatanBarbaraApp::GetConfig();
     $data = $requestParams['params'];
     DebugManager::Log("Got a " . $requestParams['request']['action'] . " request!", '@');
     DebugManager::Log("Got some data");
     DebugManager::Log($data);
     $requestName = ucfirst($requestParams['request']['action']) . 'Request';
     DebugManager::Log("Searching for view with class name: " . $requestName);
     if ($requestName::HasAccess(SessionManager::GetAccessLevel())) {
         $response = $requestName::Init($data);
     } else {
         DebugManager::Log("looks like this page requires auth but user isn't authenticated!");
         RouteManager::GoToPageURI('login', array("message" => "That page requires authenticated access!"));
     }
     if (isset($data['_format']) && $data['_format'] == 'json') {
         self::AJAXResponse($response);
     } else {
         $format = isset($data['_format']) ? $data['_format'] : 'html';
         if (isset($data['_redirect'])) {
             $redirect = $data['_redirect'];
         } else {
             if (isset($requestName::$defaultRedirect)) {
                 $redirect = $requestName::$defaultRedirect;
             } else {
                 $redirect = 'home';
                 // $requestParams['uri']; <-- can't do this, it will cause circular loop because it's getting current URI and not last URI.
             }
         }
         $redirectURI = $redirect;
         $HTTPVars = array();
         if ($response->message != 'Success!') {
             if ($response->code) {
                 $HTTPVars['error'] = $response->message;
             } else {
                 $HTTPVars['success'] = $response->message;
             }
         }
         RouteManager::GoToPageURI($redirectURI, $HTTPVars);
     }
 }