PHP 8 is packed with new interesting features, such as union types, match expressions and constructor property promotion. However, the most sought-after new feature is built-in attributes (also called annotations).
Symfony 5.2 will include support for PHP 8 attributes to define routes and required dependencies. If you already use annotations, the transition will be seamless:
1 2 3 4 5 6 7 8 9 10 11 12 13
// BEFORE: annotations defined with Doctrine Annotations library
use Symfony\Component\Routing\Annotation\Route;
class SomeController
{
/**
* @Route("/path", name="action")
*/
public function someAction()
{
// ...
}
}
1 2 3 4 5 6 7 8 9 10 11
// AFTER: annotations defined with PHP 8 attributes
use Symfony\Component\Routing\Annotation\Route;
class SomeController
{
#[Route('/path', name: 'action')]
public function someAction()
{
// ...
}
}
The same Route
class provides support for Doctrine annotations and PHP
attributes, so you don't need to change the class import. The only required
change is to update the annotation syntax, which now looks like this: #[ ... ]
That's all! Your application is now using native PHP attributes and you can
uninstall dependencies like doctrine/annotations
if you don't use them elsewhere.
We also added a #[Required]
attribute to replace @Required
annotation
and tell Symfony that a property/method holds a required dependency:
1 2 3 4 5 6 7 8 9 10 11 12 13
use Symfony\Contracts\Service\Attribute\Required;
class SomeService
{
#[Required]
public Bar $bar;
#[Required]
public function setFoo(Foo $foo): void
{
// ...
}
}
PHP is entering a new golden era with the release of PHP 8 and Symfony will be fully-compatible since day one. These attributes are just the beginning and we'll add many more (e.g. for validation) in the coming weeks.
It's cool 😎
Rector can be used to upgrade from the @annotations to native
#[]
annotations. https://github.com/rectorphp/rector/blob/master/docs/rector_rules_overview.md#annotationtoattributerector The example shows the interim<<...>>
, but it does convert to the updated#[...]
.@Alister nice to know! Thanks for sharing this reference.
Great!
@Alister Thanks for sharing! I've re-generated the Rector docs, so it's correct now.
What about the configuration ? Still the same ?
@Alister Thanks for the tip !
Very interesting, thank you @Alister