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

0.0.2 2025-05-29 10:19 UTC

This package is auto-updated.

Last update: 2025-11-01 19:11:52 UTC


README

English | 中文

PHP Version License Build Status Coverage

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

  1. Register the bundle in your config/bundles.php:
return [
    // ...
    Tourze\ConditionSystemBundle\ConditionSystemBundle::class => ['all' => true],
];
  1. 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']);
    }
}
  1. 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 entities
  • tourze/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