diff --git a/src/router/BaseRouter.php b/src/router/BaseRouter.php index 650bab8..b12e1e7 100644 --- a/src/router/BaseRouter.php +++ b/src/router/BaseRouter.php @@ -14,6 +14,10 @@ use function Facebook\AutoloadMap\Generated\is_dev; abstract class BaseRouter<+TResponder> { + public function __construct( + private RouterOptions $options = shape('head_rewrite' => true) + ) {} + abstract protected function getRoutes( ): ImmMap>; @@ -33,7 +37,7 @@ final public function routeMethodAndPath( } if ( - $method === HttpMethod::HEAD && $allowed === keyset[HttpMethod::GET] + $this->options['head_rewrite'] && $method === HttpMethod::HEAD && $allowed === keyset[HttpMethod::GET] ) { list($responder, $data) = $resolver->resolve(HttpMethod::GET, $path); $data = Dict\map($data, $value ==> \urldecode($value)); diff --git a/src/router/RouterOptions.php b/src/router/RouterOptions.php new file mode 100644 index 0000000..d9007ac --- /dev/null +++ b/src/router/RouterOptions.php @@ -0,0 +1,16 @@ + bool, +); diff --git a/tests/lib/TestRouter.php b/tests/lib/TestRouter.php index 53cdbd0..1ac6e26 100644 --- a/tests/lib/TestRouter.php +++ b/tests/lib/TestRouter.php @@ -21,6 +21,7 @@ public function __construct( private dict $routes, private ?IResolver $resolver = null, ) { + parent::__construct(); } <<__Override>>