定制 vaibhavpandeyvpz/vidyut 二次开发

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

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

vaibhavpandeyvpz/vidyut

最新稳定版本:3.0.0

Composer 安装命令:

composer require vaibhavpandeyvpz/vidyut

包简介

No frills PSR-7 request handler based on PSR-15 specification.

README 文档

README

Latest Version Downloads PHP Version License Build Status

No frills PSR-7 request handler based on PSR-15 specification.

Vidyut (विद्युत्) - Sanskrit for "Electricity", representing the flow of requests through the middleware pipeline.

Features

  • PSR-15 Compliant - Full implementation of the PSR-15 middleware specification
  • PSR-7 Compatible - Works with any PSR-7 HTTP message implementation
  • Flexible Middleware - Supports both MiddlewareInterface instances and callables
  • Fluent Interface - Chain middleware using the pipe() method
  • Zero Dependencies - Only requires PSR interfaces (PSR-7, PSR-15)
  • Modern PHP - Built for PHP 8.2+ with modern language features
  • 100% Test Coverage - Fully tested with comprehensive test suite

Installation

Install via Composer:

composer require vaibhavpandeyvpz/vidyut

Note: You'll also need a PSR-7 implementation. We recommend sandesh:

composer require vaibhavpandeyvpz/sandesh

Quick Start

<?php

use Vidyut\Pipeline;
use Sandesh\ServerRequestFactory;
use Sandesh\ResponseFactory;

// Create a new pipeline
$pipeline = new Pipeline();

// Add middleware using callables
$pipeline->pipe(function ($request, $delegate) {
    if ($request->getUri()->getPath() === '/login') {
        $response = (new ResponseFactory())->createResponse();
        $response->getBody()->write('Login Page');
        return $response;
    }
    return $delegate->handle($request);
});

// Add a final handler (404)
$pipeline->pipe(function () {
    $response = (new ResponseFactory())->createResponse();
    $response->getBody()->write('Page not found');
    return $response->withStatus(404);
});

// Handle a request
$request = (new ServerRequestFactory())
    ->createServerRequest($_SERVER['REQUEST_METHOD'], $_SERVER['REQUEST_URI'], $_SERVER);
$response = $pipeline->handle($request);

Usage

Basic Pipeline

The Pipeline class implements the PSR-15 RequestHandlerInterface and allows you to chain middleware:

use Vidyut\Pipeline;

$pipeline = new Pipeline();

// Middleware can be callables
$pipeline->pipe(function ($request, $delegate) {
    // Process request
    $response = $delegate->handle($request);
    // Modify response
    return $response->withHeader('X-Custom', 'value');
});

// Or MiddlewareInterface instances
$pipeline->pipe(new MyMiddleware());

// Handle requests
$response = $pipeline->handle($request);

Constructor Injection

You can also pass middleware directly to the constructor:

$pipeline = new Pipeline([
    function ($request, $delegate) {
        // First middleware
        return $delegate->handle($request);
    },
    function ($request, $delegate) {
        // Second middleware
        return $delegate->handle($request);
    },
    function () {
        // Final handler
        return (new ResponseFactory())->createResponse(200);
    },
]);

Middleware Types

Callable Middleware

Callables must accept two parameters:

  • ServerRequestInterface $request
  • RequestHandlerInterface $delegate

And return a ResponseInterface:

$pipeline->pipe(function (ServerRequestInterface $request, RequestHandlerInterface $delegate): ResponseInterface {
    // Your middleware logic
    return $delegate->handle($request);
});

MiddlewareInterface Instances

You can use any class implementing Psr\Http\Server\MiddlewareInterface:

class AuthenticationMiddleware implements MiddlewareInterface
{
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
    {
        // Check authentication
        if (!$this->isAuthenticated($request)) {
            return (new ResponseFactory())->createResponse(401);
        }
        return $handler->handle($request);
    }
}

$pipeline->pipe(new AuthenticationMiddleware());

Array Callables

You can also use array callables:

$middleware = new class {
    public function handle(ServerRequestInterface $request, RequestHandlerInterface $delegate): ResponseInterface
    {
        return $delegate->handle($request);
    }
};

$pipeline->pipe([$middleware, 'handle']);

Request Modification

Middleware can modify the request before passing it to the next handler:

$pipeline->pipe(function ($request, $delegate) {
    // Add custom attribute
    $modifiedRequest = $request->withAttribute('user', $this->getUser($request));
    return $delegate->handle($modifiedRequest);
});

Response Modification

Middleware can modify the response after receiving it from the next handler:

$pipeline->pipe(function ($request, $delegate) {
    $response = $delegate->handle($request);
    // Add custom header
    return $response->withHeader('X-Processed-By', 'MyMiddleware');
});

Early Termination

Middleware can stop the pipeline by returning a response without calling the delegate:

$pipeline->pipe(function () {
    // Return immediately, next middleware won't be called
    return (new ResponseFactory())->createResponse(403, 'Forbidden');
});

Fluent Interface

The pipe() method returns the pipeline instance, allowing method chaining:

$pipeline = new Pipeline()
    ->pipe($middleware1)
    ->pipe($middleware2)
    ->pipe($middleware3);

Requirements

  • PHP 8.2 or higher
  • A PSR-7 implementation (e.g., sandesh)

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Support

For issues, questions, or contributions, please visit the GitHub repository.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2016-11-17