bbim/query-scoper
Composer 安装命令:
composer require bbim/query-scoper
包简介
Laravel query scoping library for dynamic filtering
README 文档
README
A powerful Laravel package for dynamic query filtering and scoping with multiple drivers support.
Features
- 🔍 Dynamic query filtering
- 🎯 Multiple scope drivers
- 📊 Eloquent and Query Builder support
- 🔧 Flexible configuration
- 🧪 Easy testing integration
- 🚀 High performance
Installation
composer require bbim/query-scoper
Configuration
Publish the configuration file:
php artisan vendor:publish --provider="Bbim\QueryScoper\Providers\QueryScoperServiceProvider"
Architecture
Drivers
- EloquentDriver: Manages scopes for Eloquent queries
- QueryBuilderDriver: Manages scopes for Query Builder queries
Scopes
Each scope is a class that extends QueryScoper and implements:
prepareData(): Extract data from requestvalidator(): Validate the dataprepareBuilder(): Apply conditions to the query
Usage
1. Creating a Scope
<?php namespace App\Scopes; use Bbim\QueryScoper\QueryScoper; use Illuminate\Support\Facades\Validator; class UserStatusScope extends QueryScoper { protected function prepareData(): array { return request()->only(['status']); } protected function validator($data): \Illuminate\Contracts\Validation\Validator { return Validator::make($data, [ 'status' => 'sometimes|in:active,inactive' ]); } protected function prepareBuilder($builder, $data) { if (isset($data['status'])) { $builder->where('status', $data['status']); } return $builder; } }
2. Using with Facade
use Bbim\QueryScoper\Facades\QueryScoper; // Apply specific scopes $users = QueryScoper::scope(User::query(), [ UserStatusScope::class, DateRangeScope::class ])->get();
3. Using with Trait
use Bbim\QueryScoper\HasScopes; class UserController extends Controller { use HasScopes; public function index() { $users = $this->scopeToScopes(User::query(), [ UserStatusScope::class, DateRangeScope::class ])->get(); return response()->json($users); } }
4. Configuration
Configure your preferred driver in config/query-scoper.php:
'default' => env('QUERY_SCOPER_DRIVER', 'eloquent'),
Examples
ActiveScope
Filters records by status (active/inactive/all)
DateRangeScope
Filters records by date range using from_date and to_date parameters
Benefits
- Separation of Concerns: Each scope handles one specific filtering logic
- Reusability: Scopes can be used across different controllers
- Validation: Built-in validation for scope parameters
- Flexibility: Easy to add/remove scopes
- Type Safety: Strong typing with interfaces
- Simple API: Clean and straightforward usage
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-09-09