-
Notifications
You must be signed in to change notification settings - Fork 49
/
actionhandler.php
121 lines (108 loc) · 2.81 KB
/
actionhandler.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<?php
/**
* @package Habari
*
*/
namespace Habari;
/**
* A base class handler for URL-based actions. All ActionHandlers must
* extend this class for the Controller to call their actions.
*
*/
class ActionHandler
{
/**
* Name of action to trigger
*
* @var string
* @see act()
*/
public $action = '';
/**
* Internal array of handler variables (state info)
*
* @var SuperGlobal
*/
public $handler_vars = null;
/**
* Storage for the theme used, if created
*
* @var Theme $theme
*/
public $theme = null;
/**
* All handlers must implement act() to conform to handler API.
* This is the default implementation of act(), which attempts
* to call a class member method of $this->act_$action(). Any
* subclass is welcome to override this default implementation.
*
* @param string $action the action that was in the URL rule
*/
public function act( $action )
{
if ( null === $this->handler_vars ) {
$this->handler_vars = new SuperGlobal( array() );
}
$this->action = $action;
$action_method = 'act_' . $action;
$before_action_method = 'before_' . $action_method;
$after_action_method = 'after_' . $action_method;
if ( method_exists( $this, $action_method ) ) {
if ( method_exists( $this, $before_action_method ) ) {
$this->$before_action_method();
}
/**
* Plugin action to allow plugins to execute before a certain
* action is triggered
*
* @see ActionHandler::$action
* @action before_act_{$action}
*/
Plugins::act( $before_action_method, $this );
$this->$action_method();
/**
* Plugin action to allow plugins to execute after a certain
* action is triggered
*
* @see ActionHandler::$action
* @action before_act_{$action}
*/
Plugins::act( $after_action_method );
if ( method_exists( $this, $after_action_method ) ) {
$this->$after_action_method();
}
}
}
/**
* Helper method to convert calls to $handler->my_action()
* to $handler->act('my_action');
*
* @param string $function function name
* @param array $args function arguments
*/
public function __call( $function, $args )
{
return $this->act( $function );
}
/**
* Helper method to allow RewriteRules to send a redirect. The method will
* redirect to the build_str of the RewriteRule if matched.
*/
public function act_redirect()
{
$vars = isset( $_SERVER['QUERY_STRING'] ) ? Utils::get_params( $_SERVER['QUERY_STRING'] ) : array();
Utils::redirect( URL::get( null, $vars ) );
}
/**
* Load the active theme and create a new Theme instance.
* Also, assign the request variables.
*/
public function setup_theme()
{
$this->theme = Themes::create();
$this->theme->assign( 'matched_rule', URL::get_matched_rule() );
$request = Controller::get_request_obj();
$this->theme->assign( 'request', $request );
}
}
?>