定制 bbim/query-scoper 二次开发

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

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

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 request
  • validator(): Validate the data
  • prepareBuilder(): 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

  1. Separation of Concerns: Each scope handles one specific filtering logic
  2. Reusability: Scopes can be used across different controllers
  3. Validation: Built-in validation for scope parameters
  4. Flexibility: Easy to add/remove scopes
  5. Type Safety: Strong typing with interfaces
  6. Simple API: Clean and straightforward usage

统计信息

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

GitHub 信息

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

其他信息

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