diff --git a/src/router/BaseRouter.php b/src/router/BaseRouter.php index ea8e955..02ac008 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 BaseRouterOptions $options = shape('use_get_responder_for_head' => true) + ) {} + abstract protected function getRoutes( ): KeyedContainer>; @@ -33,7 +37,7 @@ final public function routeMethodAndPath( } if ( - $method === HttpMethod::HEAD && $allowed === keyset[HttpMethod::GET] + $this->options['use_get_responder_for_head'] && $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/BaseRouterOptions.php b/src/router/BaseRouterOptions.php new file mode 100644 index 0000000..de0281f --- /dev/null +++ b/src/router/BaseRouterOptions.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>>