承接 tourze/condition-system-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tourze/condition-system-bundle

最新稳定版本:0.1.1

Composer 安装命令:

composer require tourze/condition-system-bundle

包简介

A flexible condition system bundle for Symfony applications that provides condition evaluation, management and trigger mechanisms

README 文档

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

统计信息

  • 总下载量: 533
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-28