定制 aegisora/boolean-rule 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

aegisora/boolean-rule

最新稳定版本:v1.0.0

Composer 安装命令:

composer require aegisora/boolean-rule

包简介

Rule-based boolean value equality validation in Aegisora ecosystem

README 文档

README

Code Coverage Badge Software License PHPStan Badge

Boolean Rule provides a simple and strict boolean value equality validation for the Aegisora ecosystem.

The package is built on top of aegisora/rule-contract and follows its validation architecture, ensuring predictable and safe behavior.

✨ Features

  • 🔹 Minimalistic implementation with no extra dependencies
  • 🔹 Strict type validation (bool only)
  • 🔹 Comparison using ===
  • 🔹 Supports validation for both true and false
  • 🔹 Fully compatible with Aegisora validation pipeline
  • 🔹 Clear Context → Result flow
  • 🔹 No raw booleans — only structured Result
  • 🔹 Safe execution via base Rule abstraction
  • 🔹 Convenient factory methods (createTruthy, createFalsy)
  • 🔹 Built-in input validation

📦 Installation

composer require aegisora/boolean-rule

🚀 Core Concept

This package performs boolean validation:

  • accepts a value via Context
  • ensures the value is of type bool
  • compares it with the expected value
  • returns a standardized Result

Supported values:

  • true
  • false

Any other value will result in an exception.

🏗️ Basic Usage

✅ Validate true

use Aegisora\Rules\BooleanRule;
use Aegisora\RuleContract\Models\Context;

$result = BooleanRule::createTruthy()->validate(Context::create(true));

if ($result->isValid()) {
    // value is true (as expected)
} else {
    // value is not true
}

❌ Validate false

use Aegisora\Rules\BooleanRule;
use Aegisora\RuleContract\Models\Context;

$result = BooleanRule::createFalsy()->validate(Context::create(false));

if ($result->isValid()) {
    // value is false (as expected)
} else {
    // value is not false
}

🧩 Factory Methods

BooleanRule::createTruthy();
BooleanRule::createFalsy();
  • createTruthy() — expects true
  • createFalsy() — expects false

⚠️ Validation Rules

The input value must strictly be a boolean:

  • true
  • false

Any other type (int, string, null, etc.) will throw an exception:

Aegisora\RuleContract\Exceptions\InvalidRuleContextException

🏛️ Architecture

This package relies on aegisora/rule-contract.

Validation flow:

  1. validate() is called
  2. Context is passed
  3. executeValidate() is executed
  4. Value type is validated (bool only)
  5. Strict comparison (===) is performed
  6. A Result is returned

All logic is encapsulated within the base Rule abstraction.

⚖️ License

This package is open-source and licensed under the MIT License. See the LICENSE for details.

🌱 Contributing

Contributions are welcome and greatly appreciated!. See the CONTRIBUTING for details.

🌟 Support

If you find this project useful, please consider giving it a star on GitHub!

It helps the project grow and motivates further development.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-06

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固