tourze / condition-system-bundle
A flexible condition system bundle for Symfony applications that provides condition evaluation, management and trigger mechanisms
Installs: 364
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/tourze/condition-system-bundle
Requires
- php: ^8.1
- doctrine/collections: ^2.3
- doctrine/dbal: ^4.0
- doctrine/doctrine-bundle: ^2.13
- doctrine/orm: ^3.0
- doctrine/persistence: ^3.1 || ^4
- psr/log: ^3|^2|^1
- symfony/config: ^6.4
- symfony/dependency-injection: ^6.4
- symfony/doctrine-bridge: ^6.4
- symfony/framework-bundle: ^6.4
- symfony/http-kernel: ^6.4
- symfony/yaml: ^6.4 || ^7.1
- tourze/doctrine-timestamp-bundle: 0.0.*
- tourze/enum-extra: 0.1.*
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0
- symfony/phpunit-bridge: ^6.4
This package is auto-updated.
Last update: 2025-11-01 19:11:52 UTC
README
A flexible condition evaluation system for Symfony applications, providing a framework for defining, managing, and evaluating various types of conditions.
Features
- Flexible Condition System: Create and manage various types of conditions with custom handlers
- Evaluation Engine: Evaluate conditions against specific contexts and actors
- Extensible Architecture: Easy to add new condition types by implementing handlers
- Trigger Support: Built-in support for different condition triggers
- Validation: Comprehensive configuration validation for conditions
- Batch Evaluation: Evaluate multiple conditions at once
Installation
You can install this bundle via Composer:
composer require tourze/condition-system-bundle
Requirements
- PHP 8.1 or higher
- Symfony 6.4 or higher
- Doctrine ORM 3.0 or higher
Quick Start
- Register the bundle in your
config/bundles.php:
return [ // ... Tourze\ConditionSystemBundle\ConditionSystemBundle::class => ['all' => true], ];
- Create a custom condition handler:
use Tourze\ConditionSystemBundle\Handler\AbstractConditionHandler; use Tourze\ConditionSystemBundle\Interface\ConditionInterface; use Tourze\ConditionSystemBundle\ValueObject\EvaluationContext; use Tourze\ConditionSystemBundle\ValueObject\EvaluationResult; class MyCustomConditionHandler extends AbstractConditionHandler { public function getType(): string { return 'my_custom_condition'; } public function evaluate(ConditionInterface $condition, EvaluationContext $context): EvaluationResult { // Your evaluation logic here $passed = true; // Determine based on your logic return $passed ? EvaluationResult::pass() : EvaluationResult::fail(['Condition not met']); } }
- Use the condition manager:
use Tourze\ConditionSystemBundle\Service\ConditionManagerService; // Create a condition $condition = $conditionManager->createCondition($subject, 'my_custom_condition', [ 'threshold' => 100, 'operator' => '>=' ]); // Evaluate a condition $context = new EvaluationContext($actor, ['value' => 150]); $result = $conditionManager->evaluateCondition($condition, $context); if ($result->isPassed()) { // Condition passed } else { // Condition failed $errors = $result->getMessages(); }
Configuration
Dependencies
This bundle depends on:
tourze/doctrine-timestamp-bundle: Provides timestamp functionality for entitiestourze/enum-extra: Enhanced enum support
Advanced Usage
Condition Triggers
The bundle supports different condition triggers through the ConditionTrigger enum.
You can filter available condition types by trigger:
$availableTypes = $conditionManager->getAvailableConditionTypes(ConditionTrigger::BEFORE_ACTION);
Batch Evaluation
Evaluate multiple conditions at once:
$results = $conditionManager->evaluateConditions($conditions, $context);
Testing
Run the test suite:
./vendor/bin/phpunit packages/condition-system-bundle/tests
Contributing
Please see CONTRIBUTING.md for details on how to contribute to this project.
License
This bundle is under the MIT license. See the complete license in the bundle: LICENSE