/** * 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); } }