|
|
@@ -7,13 +7,21 @@ class RouteCollection{
|
|
|
private static $_route_collection;
|
|
|
|
|
|
public $_uri = '/';
|
|
|
+
|
|
|
public $_routes = Array();
|
|
|
+
|
|
|
private $_verb = '';
|
|
|
|
|
|
private $_loaded_files = Array();
|
|
|
|
|
|
private $_errors = Array();
|
|
|
|
|
|
+ private $_default_middlewares = Array();
|
|
|
+
|
|
|
+ private static $_verbs_whitelist = Array('*', 'GET','POST','PUT','PATCH','DELETE', 'CLI');
|
|
|
+
|
|
|
+ private static $_verbs_web = Array('GET','POST','PUT','PATCH','DELETE');
|
|
|
+
|
|
|
|
|
|
//SINGLETON==============================================
|
|
|
|
|
|
@@ -57,7 +65,6 @@ class RouteCollection{
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
return $instance;
|
|
|
}
|
|
|
|
|
|
@@ -74,26 +81,25 @@ class RouteCollection{
|
|
|
}
|
|
|
|
|
|
/*
|
|
|
- * GET | POST | PUT | PATCH | DELETE
|
|
|
+ * GET | POST | PUT | PATCH | DELETE | CLI
|
|
|
*
|
|
|
*/
|
|
|
private function define_verb(){
|
|
|
|
|
|
- $verbs_whitelist = Array('*', 'GET','POST','PUT','PATCH','DELETE', 'CLI');
|
|
|
$verb = '';
|
|
|
|
|
|
if(isset($_POST['_method'])){
|
|
|
- $verb = $_POST['_method'];
|
|
|
+ $verb = strtoupper( $_POST['_method'] );
|
|
|
}else if(php_sapi_name() == "cli"){
|
|
|
$verb = "CLI";
|
|
|
}else{
|
|
|
- $verb = $_SERVER['REQUEST_METHOD'];
|
|
|
+ $verb = strtoupper( $_SERVER['REQUEST_METHOD'] );
|
|
|
}
|
|
|
|
|
|
- if(in_array($verb, $verbs_whitelist)){
|
|
|
+ if(in_array($verb, $this->_verbs_whitelist)){
|
|
|
$this->_verb = $verb;
|
|
|
}else{
|
|
|
- echo 'Invalid HTTP Verb';
|
|
|
+ echo 'Invalid Verb';
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -133,6 +139,9 @@ class RouteCollection{
|
|
|
//Yup. Execute the route
|
|
|
|
|
|
$ROUTE = $route;
|
|
|
+
|
|
|
+ $route->_before($this->_default_middlewares);
|
|
|
+
|
|
|
$route->execute();
|
|
|
|
|
|
if(!$route->_ignore){
|
|
|
@@ -242,10 +251,13 @@ class RouteCollection{
|
|
|
$route = new Route();
|
|
|
|
|
|
if(is_array( $verb ) ){
|
|
|
- $route->_verb = $verb;
|
|
|
+ $route->_verb = array_map('strtoupper', $verb);
|
|
|
+ }else if( strtoupper($verb) == 'WEB' ){
|
|
|
+ $route->_verb[] = self::_verbs_web;
|
|
|
}else{
|
|
|
- $route->_verb[] = $verb;
|
|
|
+ $route->_verb[] = strtoupper( $verb );
|
|
|
}
|
|
|
+
|
|
|
$route->_uri = $uri;
|
|
|
$route->_callback[] = $callback;
|
|
|
$route->_weight = $weight;
|
|
|
@@ -263,6 +275,13 @@ class RouteCollection{
|
|
|
$this->_routes[] = $route;
|
|
|
}
|
|
|
|
|
|
+ function addMiddleware($name = '', $function){
|
|
|
+ $this->_default_middlewares[$name] = $function;
|
|
|
+ }
|
|
|
+
|
|
|
+ /*
|
|
|
+ *
|
|
|
+ */
|
|
|
static function on_http_error($function){
|
|
|
$instance = self::getInstance();
|
|
|
$instance->_errors[] = $function;
|