scuttlebyte/laravel-request-context 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

scuttlebyte/laravel-request-context

最新稳定版本:v1.0.0

Composer 安装命令:

composer require scuttlebyte/laravel-request-context

包简介

Store and access contextual request data with ease

README 文档

README

Latest Version on Packagist Build Status Quality Score Total Downloads License

This package makes managing contextual data about a request a breeze. It might be helpful to think of Request Contexts as an alternative to session data, the difference being Request Contexts only persist for the lifespan of the request.

For example, you can retrieve the authenticated User's active Team like so:

$currentTeam = Request::context()->get('currentTeam');

Installation

You can install the package via composer:

composer require scuttlebyte/laravel-request-context

Note: Laravel 5.4+ is required.

Usage

Register context for later use in the request

Request::context()->put('currentTeam', Request::user()->teams->first());

Access Request Context by key

$currentTeam = Request::context()->get('currentTeam');

Request Contexts don't have to be Eloquent models:

<?php
Request::context()->put('currentTeamTaskCount', Request::user()->teams->first()->tasks->count());

$count = Request::context()->get('currentTeamTaskCount');
// int(10)
<?php
Request::context()->put('teamOwner', Request::user()->teams->first()->owner->name);

$owner = Request::context()->get('teamOwner');
// string(14) "Martha Stewart"
<?php
Request::context()->put('teamProperties', Request::user()->teams->first()->properties);

$properties = Request::context()->get('teamProperties');
// array(1) {
//   'foo' =>
//   string(3) "bar"
// }

The sky is pretty much the limit. You can even pass an array of contexts in:

<?php
Request::context()->put([
    'currentTeamTaskCount' => Request::user()->teams->first()->tasks->count(),
    'teamOwner' => Request::user()->teams->first()->owner->name
]);

$count = Request::context()->get('currentTeamTaskCount');
// int(10)

$owner = Request::context()->get('teamOwner');
// string(14) "Martha Stewart"

Facade & helper

Go ahead, there's no judgement here.

Facade Context:

// store it
Context::put('currentTeam', Request::user()->teams->first());

// get it
$currentTeam = Context::get('currentTeam');

Helper method context():

// store it
context('currentTeam', request()->user()->teams->first());

// get it
$currentTeam = context('currentTeam');

Where to bind Contexts?

A Middleware is the perfect candidate:

<?php

namespace App\Http\Middleware;

use Closure;

class StoreTeamRequestContext
{
    public function handle($request, Closure $next)
    {
        $request->context()->put('currentTeam', $request->user()->teams()->first());
        return $next($request);
    }
}

But why?

Accessing contextual data through chained Eloquent relationships and helpers leaks implementation details throughout your application, and often leads to a lot of similar and repeated lines of code.

This package does its best to aid you in the following ways:

  • Explicitly binds contextual data in a single location
  • Makes refactoring contextual relationships much easier and less risky
  • Context values are easily retrieved anywhere you have access to a Request object without memorizing chained eloquent relationships

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email jake@scuttlebyte.com instead of using the issue tracker.

Credits

Spatie for their commitment to open source and the Laravel community (and for the skeleton used to create this package!)

License

The MIT License (MIT). Please see License File for more information.

统计信息

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

GitHub 信息

  • Stars: 15
  • Watchers: 1
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-08-31