From c3210814aa02b256d3f18fb3603ea96e840c2030 Mon Sep 17 00:00:00 2001 From: Matthias Pigulla Date: Thu, 28 Mar 2024 17:01:44 +0100 Subject: [PATCH] Add a PHP 8 attribute to support configuration (#39) This PR adds a `\Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified` attribute to replace the `\Webfactory\Bundle\WfdMetaBundle\Caching\Annotation\Send304IfNotModified` annotation class. --- .../Annotation/Send304IfNotModified.php | 31 ++----------- .../Annotation/ValidUntilLastTouched.php | 10 ++-- .../Attribute/Send304IfNotModified.php | 46 +++++++++++++++++++ src/Caching/EventListener.php | 38 +++++++++------ 4 files changed, 78 insertions(+), 47 deletions(-) create mode 100644 src/Caching/Attribute/Send304IfNotModified.php diff --git a/src/Caching/Annotation/Send304IfNotModified.php b/src/Caching/Annotation/Send304IfNotModified.php index 7f1b3dc..a29aa25 100644 --- a/src/Caching/Annotation/Send304IfNotModified.php +++ b/src/Caching/Annotation/Send304IfNotModified.php @@ -8,39 +8,16 @@ namespace Webfactory\Bundle\WfdMetaBundle\Caching\Annotation; -use Exception; -use Webfactory\Bundle\WfdMetaBundle\Helper\LastmodHelper; -use Webfactory\Bundle\WfdMetaBundle\MetaQueryFactory; - -@trigger_error( - 'The Send304IfNotModified annotation is deprecated. Use WebfactoryHttpCachingBundle and its LastModifiedDeterminators instead. If in a hurry, @see \Webfactory\Bundle\WfdMetaBundle\Caching\WfdMetaQueries for a quick conversion.', - \E_USER_DEPRECATED -); - /** * @Annotation * - * @deprecated Use WebfactoryHttpCachingBundle and its LastModifiedDeterminators instead. If in a hurry, @see \Webfactory\Bundle\WfdMetaBundle\Caching\WfdMetaQueries for a quick conversion. + * @deprecated Use the \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified attribute instead */ -class Send304IfNotModified +class Send304IfNotModified extends \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified { - protected $lastmodHelper; - public function __construct($values) { - $this->lastmodHelper = new LastmodHelper(); - - foreach ($values as $key => $value) { - if (method_exists($this->lastmodHelper, $name = 'set'.ucfirst($key))) { - $this->lastmodHelper->$name($value); - } else { - throw new Exception('Die Annotation '.static::class.' kann die Eigentschaft "'.$key.'" nicht setzen.'); - } - } - } - - public function calculateLastModified(MetaQueryFactory $metaQueryFactory) - { - return $this->lastmodHelper->calculateLastModified($metaQueryFactory); + @trigger_error(sprintf('The %s annotation is deprecated, use the %s attribute instead', __CLASS__, \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified::class), \E_USER_DEPRECATED); + parent::__construct(...$values); } } diff --git a/src/Caching/Annotation/ValidUntilLastTouched.php b/src/Caching/Annotation/ValidUntilLastTouched.php index 4fa7d81..f898f44 100644 --- a/src/Caching/Annotation/ValidUntilLastTouched.php +++ b/src/Caching/Annotation/ValidUntilLastTouched.php @@ -11,17 +11,13 @@ /** * @Annotation * - * @Deprecated + * @deprecated Use the \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified attribute instead */ class ValidUntilLastTouched extends Send304IfNotModified { public function __construct($values) { - @trigger_error( - 'The ValidUntilLastTouched annotation is deprecated. Use Send304IfNotModified instead.', - \E_USER_DEPRECATED - ); - - parent::__construct($values); + @trigger_error(sprintf('The %s annotation is deprecated, use the %s attribute instead', __CLASS__, \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified::class), \E_USER_DEPRECATED); + \Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified::__construct(...$values); } } diff --git a/src/Caching/Attribute/Send304IfNotModified.php b/src/Caching/Attribute/Send304IfNotModified.php new file mode 100644 index 0000000..4c4c21e --- /dev/null +++ b/src/Caching/Attribute/Send304IfNotModified.php @@ -0,0 +1,46 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Webfactory\Bundle\WfdMetaBundle\Caching\Attribute; + +use Attribute; +use Exception; +use Webfactory\Bundle\WfdMetaBundle\Helper\LastmodHelper; +use Webfactory\Bundle\WfdMetaBundle\MetaQueryFactory; + +/** + * @deprecated Use WebfactoryHttpCachingBundle and its LastModifiedDeterminators instead. If in a hurry, @see \Webfactory\Bundle\WfdMetaBundle\Caching\WfdMetaQueries for a quick conversion. + */ +#[Attribute] +class Send304IfNotModified +{ + protected $lastmodHelper; + + public function __construct(...$values) + { + @trigger_error( + 'The Send304IfNotModified attribute is deprecated. Use WebfactoryHttpCachingBundle and its LastModifiedDeterminators instead. If in a hurry, @see \Webfactory\Bundle\WfdMetaBundle\Caching\WfdMetaQueries for a quick conversion.', + \E_USER_DEPRECATED + ); + + $this->lastmodHelper = new LastmodHelper(); + + foreach ($values as $key => $value) { + if (method_exists($this->lastmodHelper, $name = 'set'.ucfirst($key))) { + $this->lastmodHelper->$name($value); + } else { + throw new Exception('Die Annotation '.static::class.' kann die Eigentschaft "'.$key.'" nicht setzen.'); + } + } + } + + public function calculateLastModified(MetaQueryFactory $metaQueryFactory) + { + return $this->lastmodHelper->calculateLastModified($metaQueryFactory); + } +} diff --git a/src/Caching/EventListener.php b/src/Caching/EventListener.php index 0666483..d06f907 100644 --- a/src/Caching/EventListener.php +++ b/src/Caching/EventListener.php @@ -45,13 +45,13 @@ public function onKernelController(ControllerEvent $event) $controller = $event->getController(); $request = $event->getRequest(); - $annotation = $this->findAnnotation($controller); + $attribute = $this->findAttribute($controller); - if (!$annotation) { + if (!$attribute) { return; } - $lastTouched = $annotation->calculateLastModified($this->metaQueryFactory); + $lastTouched = $attribute->calculateLastModified($this->metaQueryFactory); if (!$lastTouched) { return; @@ -94,18 +94,30 @@ public function onKernelResponse(ResponseEvent $event) /** * @param $callback array A PHP callback (array) pointing to the method to reflect on. * - * @return Send304IfNotModified|null The annotation, if found. Null otherwise. + * @return Send304IfNotModified|null The attribute, if found. Null otherwise. */ - protected function findAnnotation($callback) + protected function findAttribute($callback): ?Attribute\Send304IfNotModified { - if (\is_array($callback)) { - $object = new ReflectionObject($callback[0]); - $method = $object->getMethod($callback[1]); - - foreach ($this->reader->getMethodAnnotations($method) as $configuration) { - if ($configuration instanceof Send304IfNotModified) { - return $configuration; - } + if (!\is_array($callback)) { + return null; + } + + $object = new ReflectionObject($callback[0]); + $method = $object->getMethod($callback[1]); + + if (\PHP_MAJOR_VERSION >= 8) { + $attributes = $method->getAttributes(\Webfactory\Bundle\WfdMetaBundle\Caching\Attribute\Send304IfNotModified::class); + + if ($attributes) { + return $attributes[0]; + } + } + + foreach ($this->reader->getMethodAnnotations($method) as $configuration) { + if ($configuration instanceof Send304IfNotModified) { + @trigger_error(sprintf('Using annotations to configure wfd_meta based caching on %s::%s is deprecated, use attribute-based configuration instead.', $method->class, $method->name), \E_USER_DEPRECATED); + + return $configuration; } }