miniMVC/sys/common.php

406 lines
8.2 KiB
PHP
Raw Normal View History

2012-01-13 11:58:06 -05:00
<?php
/**
* MiniMVC
*
* Convention-based micro-framework for PHP
*
* @package miniMVC
2012-01-13 11:58:06 -05:00
* @author Timothy J. Warren
* @copyright Copyright (c) 2011 - 2012
* @link https://github.com/timw4mail/miniMVC
* @license http://philsturgeon.co.uk/code/dbad-license
*/
// --------------------------------------------------------------------------
/**
* File including common framework-wide functions
*
* @package miniMVC
* @subpackage System
2012-01-13 11:58:06 -05:00
*/
// --------------------------------------------------------------------------
/**
* Function to run on script shutdown
* -used to catch most fatal errors, and
* display them cleanly
2012-05-01 15:22:29 -04:00
*
* @return void
2012-01-13 11:58:06 -05:00
*/
function shutdown()
{
// Catch the last error
$error = error_get_last();
// types of errors that are fatal
$fatal = array(E_ERROR, E_PARSE, E_RECOVERABLE_ERROR);
// Display pretty error page
2012-05-03 13:26:09 -04:00
if (in_array($error['type'], $fatal))
2012-01-13 11:58:06 -05:00
{
$file = str_replace(MM_BASE_PATH, "", $error['file']);
2012-01-13 11:58:06 -05:00
$err_msg = <<<TXT
<h2>Fatal Error: </h2>
{$error['message']}<br /><br />
<strong>File:</strong> {$file}<br /><br />
<strong>Line:</strong> {$error['line']}
TXT;
show_error($err_msg);
}
}
// --------------------------------------------------------------------------
/**
* Function to search through the tree to find the necessary file
*
* @param string $file
* @param string $curr_path
* @return void
*/
function load_file($file, $curr_path="")
{
$path = "";
2012-05-03 13:26:09 -04:00
if ($curr_path === "app")
2012-01-13 11:58:06 -05:00
{
$path = MM_APP_PATH."{$file}.php";
2012-01-13 11:58:06 -05:00
}
2012-05-03 13:26:09 -04:00
else if ($curr_path === "sys")
2012-01-13 11:58:06 -05:00
{
$path = MM_SYS_PATH."{$file}.php";
2012-01-13 11:58:06 -05:00
}
else
{
$path = MM_MOD_PATH."{$curr_path}/{$file}.php";
2012-01-13 11:58:06 -05:00
}
2012-05-03 13:26:09 -04:00
if (is_file($path))
2012-01-13 11:58:06 -05:00
{
require_once($path);
}
}
// --------------------------------------------------------------------------
/**
* Custom error handler
*
* @param int $severity
* @param string $message
* @param string $filepath
* @param int $line
2012-04-27 16:28:25 -04:00
* @return ErrorException
2012-01-13 11:58:06 -05:00
*/
2012-04-27 16:28:25 -04:00
function on_error($severity, $message, $filepath, $line)
2012-01-13 11:58:06 -05:00
{
2012-04-27 16:28:25 -04:00
throw new ErrorException($message, 0, $severity, $filepath, $line);
2012-01-13 11:58:06 -05:00
}
// --------------------------------------------------------------------------
/**
* Custom exception handlererror_get_last
*
* @param Exception $exception
* @return void
2012-01-13 11:58:06 -05:00
*/
function on_exception($exception)
{
// This is passed to the error template
2012-01-13 11:58:06 -05:00
$message = $exception->getMessage();
// Contain the content for buffering
ob_start();
2012-05-14 14:35:57 -04:00
include(MM_APP_PATH.'/views/errors/error_php_exception.php');
2012-01-13 11:58:06 -05:00
$buffer = ob_get_contents();
ob_end_clean();
echo $buffer;
}
// --------------------------------------------------------------------------
/**
* Utility function to check if a variable is set, and is an array or object
*
* @param mixed $var
* @return bool
*/
function is_like_array(&$var)
{
2012-05-03 13:26:09 -04:00
if ( ! isset($var))
2012-01-13 11:58:06 -05:00
{
return FALSE;
}
return (is_array($var) OR is_object($var)) && ( ! empty($var));
}
// --------------------------------------------------------------------------
/**
* General 404 function
2012-05-01 15:22:29 -04:00
*
* @return void
2012-01-13 11:58:06 -05:00
*/
function show_404()
{
@header('HTTP/1.1 404 Not Found', TRUE, 404);
// Contain the content for buffering
ob_start();
// This is passed to the error template
$message = '404 Not Found';
2012-05-14 14:35:57 -04:00
include(MM_APP_PATH.'/views/errors/error_404.php');
$buffer = ob_get_contents();
ob_end_clean();
die($buffer);
2012-01-13 11:58:06 -05:00
}
// --------------------------------------------------------------------------
/**
* Fatal Error page function
*
* @param string $message
* @param int $status_code
*/
function show_error($message, $status_code=null)
{
2012-05-03 13:26:09 -04:00
if ( ! is_null($status_code))
2012-01-13 11:58:06 -05:00
{
@header("HTTP/1.1 {$status_code}", TRUE, (int)$status_code);
}
// Contain the content for buffering
ob_start();
2012-05-14 14:35:57 -04:00
include(MM_APP_PATH.'/views/errors/error_general.php');
2012-01-13 11:58:06 -05:00
$buffer = ob_get_contents();
ob_end_clean();
die($buffer);
}
// --------------------------------------------------------------------------
/**
* Returns routable methods for the specified controller class
*
* @param string $controller
* @return array
*/
function controller_methods($controller)
{
$methods = get_class_methods($controller);
2012-05-01 15:22:29 -04:00
// Eliminate methods from Controller and Model classes
$skip_methods = array_merge(get_class_methods('MM_Controller'), get_class_methods('MM_Model'));
$methods = array_diff($methods, $skip_methods);
2012-01-13 11:58:06 -05:00
return $methods;
}
// --------------------------------------------------------------------------
/**
* Calls the appropriate module/controller/function based on the url
2012-05-01 15:22:29 -04:00
*
* @return void
2012-01-13 11:58:06 -05:00
*/
function route()
{
2012-05-01 15:22:29 -04:00
$sn = $_SERVER['SCRIPT_NAME'];
$ru = $_SERVER['REQUEST_URI'];
// Get the equivalent to path info
2012-05-01 09:39:49 -04:00
$pi = (isset($_SERVER['PATH_INFO']))
2012-05-01 15:22:29 -04:00
? str_replace($sn, '', $ru)
2012-05-01 09:39:49 -04:00
: '/';
2012-05-01 15:22:29 -04:00
// Make sure the home page works when in a sub_directory
if (strlen($sn) > strlen($ru))
{
$pi = '/';
}
2012-01-13 11:58:06 -05:00
// Load the routes config file
$routes = require_once(MM_APP_PATH.'config/routes.php');
2012-01-13 11:58:06 -05:00
// Set the default route
$module = $routes['default_module'];
$controller = $routes['default_controller'];
$func = "index";
$route_set = FALSE;
// If it isn't the index page
2012-05-03 13:26:09 -04:00
if ( ! empty($pi) && $pi !== "/")
2012-01-13 11:58:06 -05:00
{
//Remove trailing slash and begining slash
$pi = trim($pi, '/');
// URL matches the route exactly? Cool, that was easy
2012-05-03 13:26:09 -04:00
if (isset($routes[$pi]))
2012-01-13 11:58:06 -05:00
{
list($module, $controller, $func) = explode("/", $routes[$pi]);
$route_set = TRUE;
}
else
{
$custom_routes = $routes;
// Skip required routes
unset($custom_routes['default_module']);
unset($custom_routes['default_controller']);
unset($custom_routes['404_handler']);
2012-05-15 11:22:16 -04:00
foreach($custom_routes as $uri => &$map)
2012-01-13 11:58:06 -05:00
{
2012-05-03 13:26:09 -04:00
if (preg_match("`{$uri}`i", $pi))
2012-01-13 11:58:06 -05:00
{
list($module, $controller, $func) = explode("/", $map);
$route_set = TRUE;
break;
}
}
}
// Doesn't match a predefined route?
// Match on module/controller/method, controller/method, or method
2012-05-03 13:26:09 -04:00
if ( ! $route_set)
2012-01-13 11:58:06 -05:00
{
$num_segments = 0;
2012-05-03 13:26:09 -04:00
if (strpos($pi, '/') === FALSE && ! empty($pi))
2012-01-13 11:58:06 -05:00
{
$num_segments = 1;
}
else
{
$segments = explode('/', $pi);
$num_segments = count($segments);
}
2012-05-15 11:22:16 -04:00
// Determine route based on uri segments
2012-05-03 13:26:09 -04:00
if ($num_segments === 1)
2012-01-13 11:58:06 -05:00
{
$func = $pi;
}
2012-05-15 11:22:16 -04:00
elseif ($num_segments === 2)
2012-01-13 11:58:06 -05:00
{
2012-05-15 11:22:16 -04:00
list($module, $controller) = $segments;
// If it's just controller/function
if ($controller == 'index')
{
$controller = $module;
$module = $routes['default_module'];
$func = 'index';
}
2012-01-13 11:58:06 -05:00
}
2012-05-15 11:22:16 -04:00
elseif ($num_segments >= 3)
2012-01-13 11:58:06 -05:00
{
list($module, $controller, $func) = $segments;
}
}
}
$path = MM_MOD_PATH."{$module}/controllers/{$controller}.php";
2012-01-13 11:58:06 -05:00
2012-05-03 13:26:09 -04:00
if (is_file($path))
2012-01-13 11:58:06 -05:00
{
require_once($path);
// Get the list of valid methods for that controller
$methods = controller_methods($controller);
2012-05-03 13:26:09 -04:00
if (in_array($func, $methods))
2012-01-13 11:58:06 -05:00
{
// Define the name of the current module for file loading
2012-05-01 16:39:14 -04:00
define('MM_MOD', $module);
$class = new $controller();
return call_user_func_array([&$class, $func], []);
2012-01-13 11:58:06 -05:00
}
// Function doesn't exist...404
show_404();
die();
}
// If it gets here, it's still a 404
show_404();
}
// --------------------------------------------------------------------------
/**
* Returns a full url from a url segment
*
* @param string $segment
* @return string
*/
function site_url($segment)
{
return $url = BASEURL . URL_INDEX_FILE . $segment;
}
// --------------------------------------------------------------------------
2012-01-27 12:55:58 -05:00
/**
* Prints out the contents of the object
*
* @param object/array $data
* @param string $method
* @return string
*/
function to_string($data, $method='print_r')
{
$output = '<pre>';
2012-05-03 13:26:09 -04:00
if ($method == "var_dump")
2012-01-27 12:55:58 -05:00
{
ob_start();
var_dump($data);
$output .= ob_get_contents();
ob_end_clean();
}
2012-05-03 13:26:09 -04:00
else if ($method == "var_export")
2012-01-27 12:55:58 -05:00
{
ob_start();
var_export($data);
$output .= ob_get_contents();
ob_end_clean();
}
else
{
$output .= print_r($data, TRUE);
}
return $output . '</pre>';
}
// --------------------------------------------------------------------------
/**
* Array_map callback to load a folder of classes at once
*
* @param string $path
* @return void
*/
2012-01-27 12:55:58 -05:00
function do_include($path)
{
require_once($path);
}
2012-01-13 11:58:06 -05:00
// End of common.php