Title: Request::fromPsrRequest
Published: May 20, 2026

---

# Request::fromPsrRequest( WordPressAiClientDependenciesPsrHttpMessageRequestInterface $psrRequest ): self

## In this article

 * [Parameters](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#parameters)
 * [Return](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#return)
 * [Source](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#source)
 * [Related](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#related)
 * [Changelog](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#changelog)

[ Back to top](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#wp--skip-link--target)

Creates a Request instance from a PSR-7 RequestInterface.

## 󠀁[Parameters](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#parameters)󠁿

 `$psrRequest`WordPressAiClientDependenciesPsrHttpMessageRequestInterfacerequired

The PSR-7 request to convert.

## 󠀁[Return](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#return)󠁿

 self A new Request instance.

## 󠀁[Source](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#source)󠁿

    ```php
    public static function fromPsrRequest(RequestInterface $psrRequest): self
    {
        $method = HttpMethodEnum::from($psrRequest->getMethod());
        $uri = (string) $psrRequest->getUri();
        // Convert PSR-7 headers to array format expected by our constructor
        /** @var array<string, list<string>> $headers */
        $headers = $psrRequest->getHeaders();
        // Get body content
        $body = $psrRequest->getBody()->getContents();
        $bodyOrData = !empty($body) ? $body : null;
        return new self($method, $uri, $headers, $bodyOrData);
    }
    ```

[View all references](https://developer.wordpress.org/reference/files/wp-includes/php-ai-client/src/providers/http/dto/request.php/)
[View on Trac](https://core.trac.wordpress.org/browser/tags/7.0/src/wp-includes/php-ai-client/src/Providers/Http/DTO/Request.php#L365)
[View on GitHub](https://github.com/WordPress/wordpress-develop/blob/7.0/src/wp-includes/php-ai-client/src/Providers/Http/DTO/Request.php#L365-L376)

## 󠀁[Related](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#related)󠁿

| Uses | Description | 
| [Request::__construct()](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/__construct/)`wp-includes/php-ai-client/src/Providers/Http/DTO/Request.php` |

Constructor.

  |

| Used by | Description | 
| [NetworkException::fromPsr18NetworkException()](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-exception-networkexception/frompsr18networkexception/)`wp-includes/php-ai-client/src/Providers/Http/Exception/NetworkException.php` |

Creates a NetworkException from a PSR-18 network exception.

  |

## 󠀁[Changelog](https://developer.wordpress.org/reference/classes/wordpress-aiclient-providers-http-dto-request/frompsrrequest/?output_format=md#changelog)󠁿

| Version | Description | 
| [0.2.0](https://developer.wordpress.org/reference/since/0.2.0/) | Introduced. |

## User Contributed Notes

You must [log in](https://login.wordpress.org/?redirect_to=https%3A%2F%2Fdeveloper.wordpress.org%2Freference%2Fclasses%2Fwordpress-aiclient-providers-http-dto-request%2Ffrompsrrequest%2F)
before being able to contribute a note or feedback.