rosehill/public/index.php

41 lines
1.3 KiB
PHP
Raw Permalink Normal View History

2014-08-18 20:17:49 +00:00
<?php
/**
* @copyright 2012-2013 City of Bloomington, Indiana
* @license http://www.gnu.org/licenses/agpl.txt GNU/AGPL, see LICENSE.txt
* @author Cliff Ingham <inghamn@bloomington.in.gov>
*/
include '../configuration.inc';
use Blossom\Classes\Template;
use Blossom\Classes\Block;
// Check for routes
if (preg_match('|'.BASE_URI.'(/([a-zA-Z0-9]+))?(/([a-zA-Z0-9]+))?|',$_SERVER['REQUEST_URI'],$matches)) {
$resource = isset($matches[2]) ? $matches[2] : 'index';
$action = isset($matches[4]) ? $matches[4] : 'index';
}
// Create the default Template
$template = !empty($_REQUEST['format'])
? new Template('default',$_REQUEST['format'])
: new Template('default');
// Execute the Controller::action()
if (isset($resource) && isset($action) && $ZEND_ACL->hasResource($resource)) {
$USER_ROLE = isset($_SESSION['USER']) ? $_SESSION['USER']->getRole() : 'Anonymous';
if ($ZEND_ACL->isAllowed($USER_ROLE, $resource, $action)) {
$controller = 'Application\Controllers\\'.ucfirst($resource).'Controller';
$c = new $controller($template);
$c->$action();
}
else {
header('HTTP/1.1 403 Forbidden', true, 403);
$_SESSION['errorMessages'][] = new \Exception('noAccessAllowed');
}
}
else {
header('HTTP/1.1 404 Not Found', true, 404);
$template->blocks[] = new Block('404.inc');
}
echo $template->render();