2012-06-13 13:49:10 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* MiniMVC
|
|
|
|
*
|
|
|
|
* Convention-based micro-framework for PHP
|
|
|
|
*
|
|
|
|
* @package miniMVC
|
|
|
|
* @author Timothy J. Warren
|
|
|
|
* @copyright Copyright (c) 2011 - 2012
|
|
|
|
* @link https://github.com/aviat4ion/miniMVC
|
|
|
|
* @license http://philsturgeon.co.uk/code/dbad-license
|
|
|
|
*/
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* File including common framework-wide functions
|
|
|
|
*
|
|
|
|
* @package miniMVC
|
|
|
|
* @subpackage System
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace miniMVC;
|
2015-06-04 14:30:42 -04:00
|
|
|
use \Aura\Router\RouterFactory;
|
2012-06-13 13:49:10 -04:00
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
// ! Autoloading
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to autoload system libraries
|
|
|
|
*
|
|
|
|
* @param string
|
|
|
|
*/
|
2012-08-09 20:36:27 +00:00
|
|
|
function autoload($name)
|
2012-06-13 13:49:10 -04:00
|
|
|
{
|
|
|
|
if ($name == '') return;
|
|
|
|
|
|
|
|
// strip off namespaces - they all go to the same folder
|
|
|
|
$names = explode('\\', trim($name));
|
|
|
|
$name = end($names);
|
|
|
|
|
|
|
|
// Paths to load from
|
|
|
|
$sys_path = MM_SYS_PATH . "core/{$name}.php";
|
|
|
|
$lib_path = MM_SYS_PATH . "libraries/{$name}.php";
|
|
|
|
$class_path = MM_APP_PATH . "classes/{$name}.php";
|
|
|
|
|
|
|
|
if (is_file($sys_path))
|
|
|
|
{
|
|
|
|
require_once($sys_path);
|
|
|
|
}
|
|
|
|
elseif (is_file($lib_path))
|
|
|
|
{
|
|
|
|
require_once($lib_path);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (is_file($class_path))
|
|
|
|
{
|
|
|
|
require_once($class_path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
2015-06-04 15:46:30 -04:00
|
|
|
// ! Messages
|
2012-06-13 13:49:10 -04:00
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* General 404 function
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
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';
|
|
|
|
|
|
|
|
include(MM_APP_PATH . '/views/errors/error_404.php');
|
|
|
|
|
|
|
|
$buffer = ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
die($buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fatal Error page function
|
|
|
|
*
|
|
|
|
* @param string $message
|
|
|
|
* @param int $status_code
|
|
|
|
*/
|
|
|
|
function show_error($message, $status_code=null)
|
|
|
|
{
|
|
|
|
if ( ! is_null($status_code))
|
|
|
|
{
|
|
|
|
@header("HTTP/1.1 {$status_code}", TRUE, (int) $status_code);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Contain the content for buffering
|
|
|
|
ob_start();
|
|
|
|
|
|
|
|
include(MM_APP_PATH . '/views/errors/error_general.php');
|
|
|
|
|
|
|
|
$buffer = ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
die($buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
// ! Utility Functions
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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)
|
|
|
|
{
|
|
|
|
if ( ! isset($var))
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (is_array($var) OR is_object($var)) && ( ! empty($var));
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns routable methods for the specified controller class
|
|
|
|
*
|
|
|
|
* @param string $controller
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function controller_methods($controller)
|
|
|
|
{
|
|
|
|
$methods = \get_class_methods($controller);
|
|
|
|
|
|
|
|
// Eliminate methods from Controller and Model classes
|
|
|
|
$skip_methods = array_merge(\get_class_methods('miniMVC\Controller'), \get_class_methods('miniMVC\Model'));
|
|
|
|
$methods = array_diff($methods, $skip_methods);
|
|
|
|
|
|
|
|
return $methods;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a full url from a url segment
|
|
|
|
*
|
|
|
|
* @param string $segment
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-09-12 14:36:43 +00:00
|
|
|
function site_url($segment='')
|
2012-06-13 13:49:10 -04:00
|
|
|
{
|
|
|
|
return $url = BASE_URL . URL_INDEX_FILE . $segment;
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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>';
|
|
|
|
|
|
|
|
if ($method == "var_dump")
|
|
|
|
{
|
|
|
|
ob_start();
|
|
|
|
var_dump($data);
|
|
|
|
$output .= ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
}
|
|
|
|
elseif ($method == "var_export")
|
|
|
|
{
|
|
|
|
ob_start();
|
|
|
|
var_export($data);
|
|
|
|
$output .= ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$output .= print_r($data, TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $output . '</pre>';
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if ( ! function_exists('do_include'))
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Array_map callback to load a folder of classes at once
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function do_include($path)
|
|
|
|
{
|
|
|
|
require_once($path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
// ! Bootstrap functions
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load required classes for bootstraping
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function init()
|
|
|
|
{
|
|
|
|
// Map to the appropriate module/controller/function
|
|
|
|
route();
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the last segment of the current url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function get_last_segment()
|
|
|
|
{
|
|
|
|
$array = get_segments();
|
|
|
|
return end($array);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets an array of the segments of the current url
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function get_segments()
|
|
|
|
{
|
|
|
|
$sn = $_SERVER['SCRIPT_NAME'];
|
|
|
|
$ru = $_SERVER['REQUEST_URI'];
|
|
|
|
|
|
|
|
// Get the equivalent to path info
|
|
|
|
$pi = (isset($_SERVER['PATH_INFO']))
|
|
|
|
? str_replace($sn, '', $ru)
|
|
|
|
: '/';
|
|
|
|
|
|
|
|
// Correct for being in a sub-directory
|
|
|
|
if (strlen($sn) > strlen($ru))
|
|
|
|
{
|
|
|
|
$pi = '/';
|
|
|
|
}
|
|
|
|
|
|
|
|
return explode('/', $pi);
|
|
|
|
}
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls the appropriate module/controller/function based on the url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function route()
|
|
|
|
{
|
2015-06-04 14:30:42 -04:00
|
|
|
$router_factory = new RouterFactory;
|
|
|
|
$router = $router_factory->newInstance();
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// Load the routes config file to add additional routes
|
|
|
|
$routes = [];
|
|
|
|
require_once(MM_APP_PATH . 'config/routes.php');
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// get the incoming request URL path
|
|
|
|
$path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
|
2015-06-04 19:31:36 -04:00
|
|
|
$path = str_replace(URL_INDEX_FILE, '', $path);
|
|
|
|
$path = str_replace(BASE_PATH, '', $path);
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// get the route based on the path and server
|
|
|
|
$route = $router->match($path, $_SERVER);
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// Set default controller/function
|
2012-06-13 13:49:10 -04:00
|
|
|
$controller = $routes['default_controller'];
|
2015-06-04 14:30:42 -04:00
|
|
|
$action = 'index';
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// 404 Condition
|
|
|
|
if (empty($route))
|
2012-06-13 13:49:10 -04:00
|
|
|
{
|
2015-06-04 16:25:47 -04:00
|
|
|
throw new \Exception("404: Page not found.");
|
|
|
|
//show_404();
|
2015-06-04 14:30:42 -04:00
|
|
|
return;
|
|
|
|
}
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// Home
|
|
|
|
if (isset($route->name) && $route->name === 'home')
|
|
|
|
{
|
|
|
|
run($controller, $action);
|
|
|
|
return;
|
|
|
|
}
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// Gather route parts
|
|
|
|
foreach(array('controller', 'action', 'id') as $param)
|
|
|
|
{
|
|
|
|
if (isset($route->params[$param]))
|
2012-06-13 13:49:10 -04:00
|
|
|
{
|
2015-06-04 14:30:42 -04:00
|
|
|
$$param = $route->params[$param];
|
2012-06-13 13:49:10 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
if ( ! isset($id)) $id = array();
|
2012-09-12 14:36:43 +00:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
// Dispatch to the appropriate controller
|
|
|
|
run($controller, $action, array($id));
|
2012-06-13 13:49:10 -04:00
|
|
|
}
|
|
|
|
|
2012-06-14 16:33:16 -04:00
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
2012-06-13 13:49:10 -04:00
|
|
|
/**
|
|
|
|
* Instantiate the appropriate controller
|
|
|
|
*
|
2015-06-04 14:30:42 -04:00
|
|
|
* @param string $controller
|
|
|
|
* @param string $func
|
|
|
|
* @param array $args
|
|
|
|
* @return void
|
2012-06-13 13:49:10 -04:00
|
|
|
*/
|
2015-06-04 14:30:42 -04:00
|
|
|
function run($controller, $func, $args = array())
|
2012-06-13 13:49:10 -04:00
|
|
|
{
|
2015-06-04 15:46:30 -04:00
|
|
|
$path = MM_APP_PATH . "controllers/{$controller}.php";
|
2012-06-13 13:49:10 -04:00
|
|
|
|
|
|
|
if (is_file($path))
|
|
|
|
{
|
|
|
|
require_once($path);
|
2012-09-12 14:36:43 +00:00
|
|
|
|
2012-06-13 13:49:10 -04:00
|
|
|
// Get the list of valid methods for that controller
|
|
|
|
$methods = controller_methods($controller);
|
|
|
|
|
|
|
|
if (in_array($func, $methods))
|
|
|
|
{
|
2012-09-12 14:36:43 +00:00
|
|
|
|
2012-06-13 13:49:10 -04:00
|
|
|
// Define the name of the current module for file loading
|
2012-06-14 16:33:16 -04:00
|
|
|
if ( ! defined('MM_MOD'))
|
|
|
|
{
|
2015-06-04 14:30:42 -04:00
|
|
|
define('MM_MOD', 'meta');
|
2012-06-14 16:33:16 -04:00
|
|
|
}
|
2012-09-12 14:36:43 +00:00
|
|
|
|
2012-08-09 20:36:27 +00:00
|
|
|
if (class_exists($controller))
|
|
|
|
{
|
|
|
|
$class = new $controller();
|
|
|
|
}
|
2012-06-13 13:49:10 -04:00
|
|
|
|
2015-06-04 14:30:42 -04:00
|
|
|
call_user_func_array(array($class, $func), $args);
|
|
|
|
return;
|
2012-06-13 13:49:10 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Function doesn't exist...404
|
|
|
|
show_404();
|
|
|
|
}
|
|
|
|
|
|
|
|
// End of common.php
|