|
@@ 205-231 (lines=27) @@
|
| 202 |
|
* @param object|Oledrion_parameters $parameters Les paramètres à passer à chaque plugin |
| 203 |
|
* @return object L'objet lui même pour chaîner |
| 204 |
|
*/ |
| 205 |
|
public function fireAction($eventToFire, Oledrion_parameters $parameters = null) |
| 206 |
|
{ |
| 207 |
|
if (!isset($this->events[self::PLUGIN_ACTION][$eventToFire])) { |
| 208 |
|
trigger_error(sprintf(_OLEDRION_PLUGINS_ERROR_1, $eventToFire)); |
| 209 |
|
|
| 210 |
|
return $this; |
| 211 |
|
} |
| 212 |
|
ksort($this->events[self::PLUGIN_ACTION][$eventToFire]); // Tri par priorité |
| 213 |
|
foreach ($this->events[self::PLUGIN_ACTION][$eventToFire] as $priority => $events) { |
| 214 |
|
foreach ($events as $event) { |
| 215 |
|
if ($this->isUnplug(self::PLUGIN_ACTION, $eventToFire, $event['fullPathName'], $event['className'], $event['method'])) { |
| 216 |
|
continue; |
| 217 |
|
} |
| 218 |
|
require_once $event['fullPathName']; |
| 219 |
|
if (!class_exists($event['className'])) { |
| 220 |
|
$class = new $event['className']; |
| 221 |
|
} |
| 222 |
|
if (!method_exists($event['className'], $event['method'])) { |
| 223 |
|
continue; |
| 224 |
|
} |
| 225 |
|
call_user_func(array($event['className'], $event['method']), $parameters); |
| 226 |
|
unset($class); |
| 227 |
|
} |
| 228 |
|
} |
| 229 |
|
|
| 230 |
|
return $this; |
| 231 |
|
} |
| 232 |
|
|
| 233 |
|
/** |
| 234 |
|
* Déclenchement d'un filtre et appel des plugins liés |
|
@@ 240-268 (lines=29) @@
|
| 237 |
|
* @param object|Oledrion_parameters $parameters Les paramètres à passer à chaque plugin |
| 238 |
|
* @return object Le contenu de l'objet passé en paramètre |
| 239 |
|
*/ |
| 240 |
|
public function fireFilter($eventToFire, Oledrion_parameters $parameters) |
| 241 |
|
{ |
| 242 |
|
if (!isset($this->events[self::PLUGIN_FILTER][$eventToFire])) { |
| 243 |
|
trigger_error(sprintf(_OLEDRION_PLUGINS_ERROR_1, $eventToFire)); |
| 244 |
|
|
| 245 |
|
return $this; |
| 246 |
|
} |
| 247 |
|
ksort($this->events[self::PLUGIN_FILTER][$eventToFire]); // Tri par priorité |
| 248 |
|
foreach ($this->events[self::PLUGIN_FILTER][$eventToFire] as $priority => $events) { |
| 249 |
|
foreach ($events as $event) { |
| 250 |
|
if ($this->isUnplug(self::PLUGIN_FILTER, $eventToFire, $event['fullPathName'], $event['className'], $event['method'])) { |
| 251 |
|
continue; |
| 252 |
|
} |
| 253 |
|
require_once $event['fullPathName']; |
| 254 |
|
if (!class_exists($event['className'])) { |
| 255 |
|
$class = new $event['className']; |
| 256 |
|
} |
| 257 |
|
if (!method_exists($event['className'], $event['method'])) { |
| 258 |
|
continue; |
| 259 |
|
} |
| 260 |
|
call_user_func(array($event['className'], $event['method']), $parameters); |
| 261 |
|
unset($class); |
| 262 |
|
} |
| 263 |
|
} |
| 264 |
|
|
| 265 |
|
if (null !== $parameters) { |
| 266 |
|
return $parameters; |
| 267 |
|
} |
| 268 |
|
} |
| 269 |
|
|
| 270 |
|
/** |
| 271 |
|
* Indique si un plugin s'est détaché d'un évènement particulier |