mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
b273f3b524
- Updated AspectProxyService to handle multiple handlers for each proxied object's methods. - Changed BeforeCallAspect to allow for providing a return value that should be returned to the caller instead of the proxied return value - Changed AfterCallAspect behaviour to allow for returning the value of the aspect to the caller instead of the proxied return value
30 lines
810 B
PHP
30 lines
810 B
PHP
<?php
|
|
|
|
/**
|
|
* An AfterCallAspect is run after a method is executed
|
|
*
|
|
* This is a declared interface, but isn't actually required
|
|
* as PHP doesn't really care about types...
|
|
*
|
|
* @author Marcus Nyeholt <marcus@silverstripe.com.au>
|
|
* @package framework
|
|
* @subpackage injector
|
|
* @license BSD http://silverstripe.org/BSD-license
|
|
*/
|
|
interface AfterCallAspect {
|
|
|
|
/**
|
|
* Call this aspect after a method is executed
|
|
*
|
|
* @param object $proxied
|
|
* The object having the method called upon it.
|
|
* @param string $method
|
|
* The name of the method being called
|
|
* @param string $args
|
|
* The arguments that were passed to the method call
|
|
* @param mixed $result
|
|
* The result of calling the method on the real object
|
|
*/
|
|
public function afterCall($proxied, $method, $args, $result);
|
|
}
|