400 lines
8.0 KiB
PHP
400 lines
8.0 KiB
PHP
<?php
|
|
/**
|
|
* MiniMVC
|
|
*
|
|
* Convention-based micro-framework for PHP
|
|
*
|
|
* @package miniMVC
|
|
* @author Timothy J. Warren
|
|
* @copyright Copyright (c) 2011 - 2012
|
|
* @link https://github.com/timw4mail/miniMVC
|
|
* @license http://philsturgeon.co.uk/code/dbad-license
|
|
*/
|
|
|
|
// --------------------------------------------------------------------------
|
|
// ! JSObject Trait
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Parent trait of base class, contains much of the magic
|
|
*
|
|
* @package miniMVC
|
|
* @subpackage System
|
|
*/
|
|
trait JSObject {
|
|
|
|
/**
|
|
* Constructor for creating the objects
|
|
*
|
|
* @param array $members
|
|
* @return void
|
|
*/
|
|
public function __construct($members = [])
|
|
{
|
|
// Add the passed parameters to the object
|
|
foreach($members as $name => &$value)
|
|
{
|
|
$this->$name = $value;
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* PHP magic method to facilitate dynamic methods
|
|
*
|
|
* @param string $name
|
|
* @param array $params
|
|
*/
|
|
public function __call($name, $params = [])
|
|
{
|
|
if(is_callable($this->$name))
|
|
{
|
|
//Call the dynamic function
|
|
return call_user_func_array($this->$name, $params);
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Prints out the contents of the object when used as a string
|
|
*
|
|
* @return string
|
|
*/
|
|
public function __toString()
|
|
{
|
|
if(ENVIRONMENT == 'DEVELOPMENT')
|
|
{
|
|
$args = func_get_args();
|
|
$method = ( ! empty($args)) ? $args[0] : "print_r";
|
|
$data = (isset($args[1])) ? $args[1] : [];
|
|
|
|
if(empty($data))
|
|
{
|
|
$data =& $this;
|
|
}
|
|
|
|
$output = '<pre>';
|
|
|
|
if($method == "var_dump")
|
|
{
|
|
ob_start();
|
|
var_dump($data);
|
|
$output .= ob_get_contents();
|
|
ob_end_clean();
|
|
}
|
|
else if($method == "var_export")
|
|
{
|
|
ob_start();
|
|
var_export($data);
|
|
$output .= ob_get_contents();
|
|
ob_end_clean();
|
|
}
|
|
else
|
|
{
|
|
$output .= print_r($data, TRUE);
|
|
}
|
|
|
|
return $output . '</pre>';
|
|
}
|
|
else
|
|
{
|
|
return '';
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* PHP magic method that is called when an object is treated as a function
|
|
*
|
|
* @param array $args
|
|
*/
|
|
public static function __invoke($args = [])
|
|
{
|
|
$class = __CLASS__;
|
|
return new $class($args);
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
// ! Singleton Trait
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Singleton pattern
|
|
*
|
|
* @package miniMVC
|
|
* @subpackage System
|
|
*/
|
|
trait Singleton {
|
|
|
|
/**
|
|
* Singleton object
|
|
*
|
|
* @var self
|
|
*/
|
|
protected static $instance;
|
|
|
|
/**
|
|
* Protected constructor for creating the one instance
|
|
*/
|
|
abstract protected function __construct();
|
|
|
|
/**
|
|
* PHP magic method that is called when an object is treated as a function
|
|
*
|
|
* @param array $params
|
|
* @return self
|
|
*/
|
|
public static function __invoke($params = [])
|
|
{
|
|
return self::get_instance($params);
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Singleton getter function
|
|
*
|
|
* @return self
|
|
*/
|
|
public static function &get_instance()
|
|
{
|
|
if ( ! isset(self::$instance))
|
|
{
|
|
$class = __CLASS__;
|
|
|
|
self::$instance = new $class;
|
|
}
|
|
|
|
return self::$instance;
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Magic function called when cloning an object
|
|
*/
|
|
public function __clone()
|
|
{
|
|
trigger_error('Clone is not allowed.', E_USER_ERROR);
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
// ! Base Classes
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Class for standalone JSObject objects
|
|
*
|
|
* @package miniMVC
|
|
* @subpackage System
|
|
*/
|
|
class MM extends ArrayObject {
|
|
|
|
use JSObject;
|
|
|
|
/**
|
|
* Create the ArrayObject/JSObject hybrid object
|
|
*
|
|
* @param array
|
|
*/
|
|
public function __construct($members = [])
|
|
{
|
|
parent::__construct($members);
|
|
|
|
// Add the passed parameters to the object
|
|
foreach($members as $name => &$value)
|
|
{
|
|
$this->$name = $value;
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Allow calling of array methods on the object and
|
|
* dynamic methods
|
|
*
|
|
* @param string $name
|
|
* @param array $params
|
|
* @return mixed
|
|
*/
|
|
public function __call($name, $params = [])
|
|
{
|
|
// Allow array operations on the object
|
|
if (substr($name, 0, 6) === 'array_' && is_callable($name))
|
|
{
|
|
$args = array_merge($this->getArrayCopy(), $args);
|
|
return call_user_func_array($name, $args);
|
|
}
|
|
|
|
// Allow dynamic method calls
|
|
if(is_callable($this->$name))
|
|
{
|
|
//Call the dynamic function
|
|
return call_user_func_array($this->$name, $params);
|
|
}
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Base class for the framework
|
|
*
|
|
* @package miniMVC
|
|
* @subpackage System
|
|
*/
|
|
class miniMVC extends MM {
|
|
|
|
use Singleton;
|
|
|
|
/**
|
|
* Reference to output class
|
|
*
|
|
* @var MM_Output
|
|
*/
|
|
public $output;
|
|
|
|
/**
|
|
* Constructor - Any classes loaded here become subclasses of miniMVC
|
|
*
|
|
* @param array $members
|
|
*/
|
|
public function __construct($members = [])
|
|
{
|
|
// Allow the class to be used like an array
|
|
parent::__construct($members);
|
|
|
|
$this->output = new MM_Output();
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* PHP magic method to facilitate dynamic methods
|
|
*
|
|
* @param string $name
|
|
* @param array $args
|
|
*/
|
|
public function __call($name, $args = [])
|
|
{
|
|
// Allow array operations on the object
|
|
if (substr($name, 0, 6) === 'array_' && is_callable($name))
|
|
{
|
|
$args = array_merge($this->getArrayCopy(), $args);
|
|
return call_user_func_array($name, $args);
|
|
}
|
|
|
|
// Call dynamic methods
|
|
if (is_callable(self::$instance->$name))
|
|
{
|
|
// Add $this object to args
|
|
array_push($args, $this);
|
|
|
|
// Call the dynamic function
|
|
return call_user_func_array(self::$instance->$name, $args);
|
|
}
|
|
|
|
// Indirectly call output methods
|
|
if (is_callable(self::$instance->output->$name))
|
|
{
|
|
return call_user_func_array(self::$instance->output->$name, $args);
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Method to load classes into the singleton
|
|
*
|
|
* @param string $name
|
|
* @return object
|
|
*/
|
|
public function load_class($name)
|
|
{
|
|
// In a subdirectory? No problem
|
|
if (strpos("/", $name) !== FALSE)
|
|
{
|
|
$n = explode("/", $name);
|
|
$name = $n[count($n) -1];
|
|
}
|
|
|
|
// Try system library first, then app library
|
|
$path = MM_SYS_PATH . "libraries/{$name}.php";
|
|
$name = "MM_{$name}";
|
|
|
|
if ( ! is_file($path))
|
|
{
|
|
$path = MM_APP_PATH . "classes/{$name}.php";
|
|
$name = str_replace('MM_', '', $name);
|
|
}
|
|
|
|
$class = "{$name}";
|
|
|
|
// Load the class file if need be
|
|
if ( ! class_exists($class, FALSE))
|
|
{
|
|
if (is_file($path))
|
|
{
|
|
require_once($path);
|
|
}
|
|
}
|
|
|
|
// Create the object, and add it to the current miniMVC object
|
|
if (class_exists($class, FALSE))
|
|
{
|
|
// Remove MM_ prefix from name
|
|
$name = str_replace('MM_', '', $name);
|
|
|
|
if ( ! isset($this->$name))
|
|
{
|
|
// Call a singleton, if the get_instance method exists
|
|
if (method_exists($class, 'get_instance'))
|
|
{
|
|
return $this->$name =& $class::get_instance();
|
|
}
|
|
|
|
return $this->$name = new $class;
|
|
}
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Convenience function to remove an object from the singleton
|
|
*
|
|
* @param string $name
|
|
*/
|
|
public function unload($name)
|
|
{
|
|
if (isset($this->$name))
|
|
{
|
|
unset($this->$name);
|
|
}
|
|
}
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
/**
|
|
* Convenience function to load config files
|
|
*
|
|
* @param string $name
|
|
*/
|
|
public function load_config($name)
|
|
{
|
|
$path = MM_APP_PATH . "config/{$name}.php";
|
|
|
|
if (is_file($path))
|
|
{
|
|
require_once($path);
|
|
}
|
|
}
|
|
}
|
|
|
|
// End of miniMVC.php
|