evyex/symfony-extender
最新稳定版本:8.0.3
Composer 安装命令:
composer require evyex/symfony-extender
包简介
Symfony bundle to must have features
README 文档
README
A Symfony bundle that provides commonly used features and utilities to enhance your development workflow.
Installation
Install the bundle using Composer:
composer require evyex/symfony-extender
The bundle should be automatically registered by Symfony Flex. If not, add it to your config/bundles.php:
return [ // ... Evyex\SymfonyExtender\SymfonyExtenderBundle::class => ['all' => true], ];
Configuration
You can configure the bundle in config/packages/symfony_extender.yaml:
symfony_extender: entity_collection: default_limit: 20 # Default paginator limit when no explicit limit is provided (min: 1) is_granted_listener: enabled: true # Set to false to disable grant execution after Map** resolving phone_number: clean_string: true # Strip spaces, hyphens, and parentheses before validation pattern: '/^\+?[1-9][0-9]{9,14}$/' # Regex used to validate the phone number
Features
1. Phone Number Validator
A simple validator for international phone numbers. It allows digits, spaces, hyphens, and parentheses, but ensures the underlying value follows a valid international format (e.g., +1234567890).
Usage:
use Evyex\SymfonyExtender\Validator\PhoneNumber; class UserDTO { #[PhoneNumber(message: 'Please provide a valid phone number.')] public string $phone; }
The default regex accepts international numbers with an optional + prefix, 10–15 digits total, and allows formatting characters (spaces, hyphens, parentheses) that are stripped before matching. All defaults can be changed globally via bundle configuration or per-field via the attribute:
// Override pattern for this field only, keeping global clean_string setting #[PhoneNumber(pattern: '/^\+380[0-9]{9}$/')] public string $ukrainianPhone;
2. MapEntityCollection Value Resolver
Automatically resolves a collection of entities from request query parameters. This is highly useful for list endpoints with filtering, ordering, and pagination support.
Detailed documentation: MapEntityCollection.md.
Usage in Controller:
use Evyex\SymfonyExtender\ValueResolver\MapEntityCollection\MapEntityCollection; use App\Entity\Product; use Doctrine\ORM\Tools\Pagination\Paginator; #[Route('/products', methods: ['GET'])] public function list( #[MapEntityCollection( class: Product::class, defaultOrdering: ['createdAt' => 'DESC'] )] Paginator $products ): Response { // ... }
3. IsGranted Attribute Decorator
Decorates the default Symfony controller.is_granted_attribute_listener to ensure it runs at the correct priority when used with other argument resolvers.
This works transparently in the background, ensuring that #[IsGranted] attributes on controller arguments are handled correctly before the value resolvers are called.
Can be disabled via configuration if the decorator conflicts with your setup (see Configuration).
Quality Assurance
The project maintains high code quality standards:
- Static Analysis: PHPStan
- Coding Style: PHP-CS-Fixer
- Testing: PHPUnit
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 49
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-01-16