cakephp2-php8/libs/object.php
phpnut 59af4d3258 Merging changes from:
[905]
Refactoring renderMethod() moving to object class to make it available to whole system

[908]
Bug fixes to ticket #219.
Added bug fixes I found in code.
Fixed Router::parse(); which only checked lower case strings
Refactored renderAction method. Moved to object class to allow all classes to access the method now.
This will allow a User object to make a request to a Permsissions object checking.
For example: You have a User object that needs to check its permission to access
User object would make are request to Permission object.
$accces = $this->renderAction('/permission/allow/userid/');

You would then be able to use the results of $access in your controller.
To check this in the view
$accces = $html->renderAction('/permission/allow/userid/');

Simple as that.

[906]
Added sortable() to AjaxHelper as a method of creating sortables,
and refactored a fair amount of the code.

[907]
Coding standard corrections.

removed blank line at end of paths.php file

git-svn-id: https://svn.cakephp.org/repo/trunk/cake@910 3807eeeb-6ff5-0310-8944-8be069107fe0
2005-09-19 17:20:24 +00:00

162 lines
No EOL
3.9 KiB
PHP

<?php
/* SVN FILE: $Id$ */
/**
* Short description for file.
*
* Long description for file
*
* PHP versions 4 and 5
*
* CakePHP : Rapid Development Framework <http://www.cakephp.org/>
* Copyright (c) 2005, CakePHP Authors/Developers
*
* Author(s): Michal Tatarynowicz aka Pies <tatarynowicz@gmail.com>
* Larry E. Masters aka PhpNut <nut@phpnut.com>
* Kamil Dzielinski aka Brego <brego.dk@gmail.com>
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice.
*
* @filesource
* @author CakePHP Authors/Developers
* @copyright Copyright (c) 2005, CakePHP Authors/Developers
* @link https://trac.cakephp.org/wiki/Authors Authors/Developers
* @package cake
* @subpackage cake.libs
* @since CakePHP v 0.2.9
* @version $Revision$
* @modifiedby $LastChangedBy$
* @lastmodified $Date$
* @license http://www.opensource.org/licenses/mit-license.php The MIT License
*/
/**
* Enter description here...
*/
uses('log');
/**
* Object class, allowing __construct and __destruct in PHP4.
*
* Long description for class
*
* @package cake
* @subpackage cake.libs
* @since CakePHP v 0.2.9
*/
class Object
{
/**
* Log object
*
* @var object
*/
var $_log = null;
/**
* A hack to support __construct() on PHP 4
* Hint: descendant classes have no PHP4 class_name() constructors,
* so this constructor gets called first and calls the top-layer __construct()
* which (if present) should call parent::__construct()
*
* @return Object
*/
function Object()
{
$args = func_get_args();
register_shutdown_function(array(&$this, '__destruct'));
call_user_func_array(array(&$this, '__construct'), $args);
}
/**
* Class constructor, overridden in descendant classes.
*/
function __construct()
{
}
/**
* Class destructor, overridden in descendant classes.
*/
function __destruct()
{
}
/**
* Object-to-string conversion.
* Each class can override it as necessary.
*
* @return string This name of this class
*/
function toString()
{
return get_class($this);
}
/**
*
* Allow calling a controllers method from any location
*
*
* @param unknown_type $url
* @param unknown_type $extra
* @return unknown
*/
function renderMethod ($url, $extra = array())
{
$extra = array_merge($extra, array('bare'=>1));
$dispatcher =& new Dispatcher();
$params = array_merge($dispatcher->parseParams($url), $extra);
$ctrlName = Inflector::camelize($params['controller']);
$ctrlClass = $ctrlName.'Controller';
if (!loadController($ctrlName) || !class_exists($ctrlClass))
{
$ctrlClass = 'AppController';
$controller =& new $ctrlClass();
$params['action'] = 'missingController';
$controller->missingController = $params['controller'];
}
else
{
$controller =& new $ctrlClass();
$classMethods = get_class_methods($controller);
if(!in_array($params['action'], $classMethods))
{
$controller->missingAction = $params['action'];
$params['action'] = 'missingAction';
}
}
$return = call_user_func_array(array(&$controller, $params['action']), empty($params['pass'])? null: $params['pass']);
return $return;
}
/**
* API for logging events.
*
* @param string $msg Log message
* @param int $type Error type constant. Defined in /libs/log.php.
*/
function log ($msg, $type=LOG_ERROR)
{
if (is_null($this->_log))
{
$this->_log = new Log ();
}
switch ($type)
{
case LOG_DEBUG:
return $this->_log->write('debug', $msg);
default:
return $this->_log->write('error', $msg);
}
}
}
?>