All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Adjust phpdoc to avoid warnings about return types.
- Remove direct dependency on
php-http/message-factory
as it is only needed for the deprecated Httplug factories. Upgrade to PSR-17 message factories provided by your HTTP client implementation. If you need the Httplug factories for the time being, you cancomposer require php-http/message-factory
in your application.
If you use the decorator classes, you might need to adjust your code to the parameter and return type declarations added in PSR-7
- Actually make compatible with PSR-7 1.1 and 2.0
- Drop support for PHP 7.1
This release is not actually compatible with PSR-7 1.1 or 2.0
- Allow installation with http-message (PSR-7) version 2 in addition to version 1.
- Support for PHP 8.2
- Added
Formatter::formatResponseForRequest()
to allow the formatter to get context from the request to decide what of the response to output. - Deprecated
Formatter::formatResponse()
in favor of the newformatResponseForRequest
method.
- Added support for adjusting binary detection regex in FullHttpMessageFormatter.
- Support GuzzleHttp/Psr7 version 2.0 in the (deprecated) GuzzleStreamFactory.
- Support GuzzleHttp/Psr7 version 2.0 in the (deprecated) GuzzleUriFactory.
-
Migrated from
zendframework/zend-diactoros
tolaminas/laminas-diactoros
. Users are encouraged to update their dependencies by simply replacing the Zend package with the Laminas package. Due to the laminas-zendframework-brige, BC changes are not expected and legacy code does not need to be refactored (though it is recommended and simple). -
The diactoros factories of
php-http/message
will return objects from theLaminas\Diactoros\
namespace, if the respective classes are available via autoloading, but continue to return objects fromZend\Diactoros\
namespace otherwise. -
Allow to specify the hashing algorithm for WSSE authentication.
1.10.0 - 2020-11-11
- Added support for PHP 8.0.
1.9.1 - 2020-10-13
- Improved detection of binary stream to not consider newlines, carriage return or tabs as binary.
1.9.0 - 2020-08-17
- Omitted binary body in FullHttpMessageFormatter and CurlCommandFormatter.
[binary stream omitted]
will be shown instead.
- New Header authentication method for arbitrary header authentication.
1.8.0 - 2019-08-05
- Raised minimum PHP version to 7.1
- Fatal error on
CurlCommandFormatter
when body is larger thanescapeshellarg
allowed length. - Do not read stream in message formatter if stream is not seekable.
1.7.2 - 2018-10-30
- FilteredStream uses
@trigger_error
instead of throwing exceptions to not break careless users. You still need to fix your stream code to respectisSeekable
. Seeking does not work as expected, and we will add exceptions in version 2.
1.7.1 - 2018-10-29
- FilteredStream is not actually seekable
1.7.0 - 2018-08-15
- Fix CurlCommandFormatter for binary request payloads
- Fix QueryParam authentication to assemble proper URL regardless of PHP
arg_separator.output
directive - Do not pass
null
parameters toClue\StreamFilter\fun
- Dropped tests on HHVM
1.6.0 - 2017-07-05
- CookieUtil::parseDate to create a date from cookie date string
- Fix curl command of CurlFormatter when there is an user-agent header
1.5.0 - 2017-02-14
- Check for empty string in Stream factories
- Cookie::createWithoutValidation Static constructor to create a cookie. Will not perform any attribute validation during instantiation.
- Cookie::isValid Method to check if cookie attributes are valid.
- FilteredStream::getSize returns null because the contents size is unknown.
- Stream factories does not rewinds streams. The previous behavior was not coherent between factories and inputs.
- FilteredStream::getReadFilter The read filter is internal and should never be used by consuming code.
- FilteredStream::getWriteFilter We did not implement writing to the streams at all. And if we do, the filter is an internal information and should not be used by consuming code.
1.4.1 - 2016-12-16
- Cookie::matchPath Cookie with root path (
/
) will not match sub path (e.g./cookie
).
1.4.0 - 2016-10-20
- Message, stream and URI factories for Slim Framework
- BufferedStream that allow you to decorate a non-seekable stream with a seekable one.
- cUrlFormatter to be able to redo the request with a cURL command
1.3.1 - 2016-07-15
- FullHttpMessageFormatter will not read from streams that you cannot rewind (non-seekable)
- FullHttpMessageFormatter will not read from the stream if $maxBodyLength is zero
- FullHttpMessageFormatter rewinds streams after they are read
1.3.0 - 2016-07-14
- FullHttpMessageFormatter to include headers and body in the formatted message
- #41: Response builder broke header value
1.2.0 - 2016-03-29
- The RequestMatcher is built after the Symfony RequestMatcher and separates scheme, host and path expressions and provides an option to filter on the method
- New RequestConditional authentication method using request matchers
- Add automatic basic auth info detection based on the URL
- Improved ResponseBuilder
- RegexRequestMatcher, use RequestMatcher instead
- Matching authenitcation method, use RequestConditional instead
1.1.0 - 2016-02-25
- Add a request matcher interface and regex implementation
- Add a callback request matcher implementation
- Add a ResponseBuilder, to create PSR7 Response from a string
- Fix casting string on a FilteredStream not filtering the output
1.0.0 - 2016-01-27
0.2.0 - 2015-12-29
- Autoregistration of stream filters using Composer autoload
- Cookie
- Apigen configuration
0.1.2 - 2015-12-26
- Request and response factory bindings
- Chunk filter namespace in Dechunk stream
0.1.1 - 2015-12-25
- Formatter
- Authentication
- Encoding
- Message decorator
- Message factory (Guzzle, Diactoros)