1 | <?php |
||
16 | trait Controller { |
||
17 | /** |
||
18 | * Call methods necessary for module page rendering |
||
19 | * |
||
20 | * @param \cs\Request $Request |
||
21 | * |
||
22 | * @throws \cs\ExitException |
||
23 | */ |
||
24 | 8 | protected function controller_router ($Request) { |
|
48 | /** |
||
49 | * Call methods that corresponds for specific paths in URL |
||
50 | * |
||
51 | * @param \cs\Request $Request |
||
52 | * @param string $controller_class |
||
53 | * @param string $method_name |
||
54 | * @param bool $required |
||
55 | * |
||
56 | * @throws \cs\ExitException |
||
57 | */ |
||
58 | 8 | protected function controller_router_handler ($Request, $controller_class, $method_name, $required = true) { |
|
62 | /** |
||
63 | * @param \cs\Request $Request |
||
64 | * @param string $controller_class |
||
65 | * @param string $method_name |
||
66 | * @param bool $required |
||
67 | * |
||
68 | * @throws \cs\ExitException |
||
69 | */ |
||
70 | 8 | protected function controller_router_handler_internal ($Request, $controller_class, $method_name, $required) { |
|
71 | 8 | $Response = Response::instance(); |
|
72 | 8 | $found = $this->controller_router_handler_internal_execute($controller_class, $method_name, $Request, $Response); |
|
73 | 8 | if (!$Request->cli_path && !$Request->api_path) { |
|
74 | 4 | return; |
|
75 | } |
||
76 | 6 | $request_method = strtolower($Request->method); |
|
77 | 6 | $found = $this->controller_router_handler_internal_execute($controller_class, $method_name.'_'.$request_method, $Request, $Response) || $found; |
|
78 | 6 | if ($found || !$required) { |
|
79 | 6 | return; |
|
80 | } |
||
81 | 2 | $unknown_method_handler = $Request->api_path ? 'options' : 'cli'; |
|
82 | 2 | if (method_exists($controller_class, "{$method_name}_$unknown_method_handler")) { |
|
83 | 2 | $controller_class::{"{$method_name}_$unknown_method_handler"}($Request, $Response); |
|
84 | 2 | return; |
|
85 | } |
||
86 | 2 | $this->handler_not_found( |
|
87 | 2 | $this->controller_router_available_methods($this->working_directory, $controller_class, $method_name), |
|
88 | $request_method, |
||
89 | $Request |
||
90 | ); |
||
91 | 2 | } |
|
92 | /** |
||
93 | * @param string $working_directory |
||
94 | * @param string $controller_class |
||
95 | * @param string $method_name |
||
96 | * |
||
97 | * @return string[] |
||
98 | */ |
||
99 | 4 | protected function controller_router_available_methods ($working_directory, $controller_class, $method_name) { |
|
120 | /** |
||
121 | * @param array $structure |
||
122 | * @param string $prefix |
||
123 | * |
||
124 | * @return string[] |
||
125 | */ |
||
126 | 4 | protected function controller_router_available_methods_to_flat_structure ($structure, $prefix = '') { |
|
139 | /** |
||
140 | * @param string $controller_class |
||
141 | * @param string $method_name |
||
142 | * @param \cs\Request $Request |
||
143 | * @param Response $Response |
||
144 | * |
||
145 | * @return bool |
||
146 | */ |
||
147 | 8 | protected function controller_router_handler_internal_execute ($controller_class, $method_name, $Request, $Response) { |
|
157 | } |
||
158 |