yiisoft/request-provider

PSR-7 request provider

1.2.0 2025-01-08 18:09 UTC

This package is auto-updated.

Last update: 2025-01-08 18:11:13 UTC


README

Yii

Yii Request Provider


Latest Stable Version Total Downloads Build status Code Coverage Mutation testing badge static analysis type-coverage psalm-level

The package provides the current PSR-7 request as a dependency.

Requirements

  • PHP 8.1 or higher.

Installation

The package can be installed with Composer:

composer require yiisoft/request-provider

General usage

First, add the Yiisoft\RequestProvider\RequestCatcherMiddleware to your application middleware stack.

Then, when you need the current request, get the RequestProviderInterface as a dependency and obtain the request from it:

use Yiisoft\RequestProvider\RequestProviderInterface;

final class MyService
{
    public function __construct(
        private readonly RequestProviderInterface $requestProvider
    )
    {    
    }
    
    public function doIt()
    {
        $request = $this->requestProvider->get();
        // ...
    }
}

Request cookies provider

You can work with cookies as follows:

class MyClass
{
  public function __construct(
    private \Yiisoft\RequestProvider\RequestCookieProvider $cookies
  ) {}
  
  public function go(): void
  {
    $this->cookies->has('foo');
    $this->cookies->get('bar');
  }
}

Request headers provider

You can work with headers as follows:

class MyClass
{
  public function __construct(
    private \Yiisoft\RequestProvider\RequestHeaderProvider $headers
  ) {}
  
  public function go(): void
  {
    $this->headers->has('X-Foo');
    $this->headers->get('X-Foo');
    $this->headers->getLine('X-Foo');
    $this->headers->getAll();
    $this->headers->getFirstHeaders();
  }
}

Documentation

If you need help or have a question, the Yii Forum is a helpful resource. You may also check out other resources at Yii Community Resources.

License

The Yii Request Provider is free software. It is released under the terms of the BSD License. Please see LICENSE for more information.

Maintained by Yii Software.

Support the project

Open Collective

Follow updates

Official website Twitter Telegram Facebook Slack