Skip to content

Latest commit

 

History

History
497 lines (292 loc) · 9.77 KB

CHANGELOG.md

File metadata and controls

497 lines (292 loc) · 9.77 KB

Changelog

All notable changes to this project will be documented in this file, in reverse chronological order by release.

Versions prior to 0.4.0 were released as the package "weierophinney/hal".

0.6.2 - 2018-01-03

Added

  • Nothing.

Changed

  • #27 modifies the XmlRenderer to raise an exception when attempting to render objects that are not serializable to strings.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • #27 adds handling for DateTime and string serializable objects to the XmlRenderer, allowing them to be rendered.

0.6.1 - 2017-12-12

Added

  • #26 adds support for the zend-expressive-helpers 5.0 series of releases.

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.6.0 - 2017-11-07

Added

  • Nothing.

Changed

  • #23 modifies how the resource generator factory adds strategies and maps metadata to strategies. It now adds the following factories under the Zend\Expressive\Hal\Metadata namespace:

    • RouteBasedCollectionMetadataFactory
    • RouteBasedResourceMetadataFactory
    • UrlBasedCollectionMetadataFactory
    • UrlBasedResourceMetadataFactory

    Each implements a new MetadataFactoryInterface under that same namespace that accepts the requested metadata type name and associated metadata in order to create an AbstractMetadata instance. Metadata types are mapped to their factories under the zend-expressive-hal.metadata-factories key.

    Strategies are now configured as metadata => strategy class pairings under the zend-expressive-hal.resource-generator.strategies key.

    In both cases, defaults that mimic previous behavior are provided via the ConfigProvider.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.5.1 - 2017-11-07

Added

  • Nothing.

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • #21 fixes the LinkGeneratorFactory to properly use the Zend\Expressive\Hal\LinkGenerator\UrlGeneratorInterface service when creating and returning the LinkGenerator instance. (0.5.0 was incorrectly attempting to use the UrlGenerator service, which does not exist.)

0.5.0 - 2017-10-30

Added

  • Nothing.

Changed

  • #20 renames the following interfaces and traits to have Interface and Trait suffixes, respectively; this was done for consistency with existing ZF packages. (Values after the : retain the namespace, which is omitted for brevity.)

    • Zend\Expressive\Hal\LinkGenerator\UrlGenerator: UrlGeneratorInterface
    • Zend\Expressive\Hal\Renderer\Renderer: RendererInterface
    • Zend\Expressive\Hal\ResourceGenerator\Strategy: StrategyInterface
    • Zend\Expressive\Hal\ResourceGenerator\ExtractCollection: ExtractCollectionTrait
    • Zend\Expressive\Hal\ResourceGenerator\ExtractInstance: ExtractInstanceTrait
  • #16 renames the various Exception interfaces to ExceptionInterface, in order to be consistent with other ZF packages.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.4.3 - 2017-10-30

Added

  • Nothing.

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • #19 fixes the behavior of ResourceGenerator when nesting a collection inside another resource to properly nest it as an array of items, rather than a collection resource.

  • #18 fixes the return type hint of RouteBasedResourceMetadata::setRouteParams() to correctly be void.

  • #13 updates ExtractCollection::extractPaginator() to validate that the pagination parameter is within the range of pages represented by the paginator instance; if not, an OutOfBoundsException is raised.

  • #12 fixes how pagination metadata (_page, _page_count, _total_items) is represented in generated resources, ensuring values are cast to integers.

0.4.2 - 2017-09-20

Added

  • Nothing.

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • #7 fixes a number of issues in the various exception implementations due to failure to import classes referenced in typehints.

  • #6 fixes a number of docblock annotations to reference HalResource vs Resource (which is a reserved word).

0.4.1 - 2017-08-08

Added

  • Nothing.

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • #6 fixes an issue with the XML renderer when creating resource elements that represent an array.

0.4.0 - 2017-08-08

Added

  • Nothing.

Changed

  • The package name was changed to "zendframework/zend-expressive-hal".
  • The namespace was changed from Hal to Zend\Expressive\Hal.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.3.0 - 2017-08-07

Added

  • #4 adds the ability to force both links and embedded resources to be rendered as collections, even if the given relation only contains one item.

    To force a link to be rendered as a collection, pass the attribute __FORCE__COLLECTION__ with a boolean value of true (or use the constant Link::AS_COLLECTION to refer to the attribute name).

    To force an embedded resource to be rendered as a collection, pass a boolean true as the third argument to embed(). Alternately, pass an array containing the single resource to any of the constructor, withElement(), or embed().

Changed

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.2.0 - 2017-07-13

Added

  • #1 adds a Hal\Renderer subcomponent with the following:
    • Renderer interface
    • JsonRenderer, for creating JSON representations of HalResource instances.
    • XmlRenderer, for creating XML representations of HalResource instances.

Changed

  • #1 changes Hal\HalResponseFactory to compose a JsonRenderer and XmlRenderer, instead of composing $jsonFlags and creating representations itself.

    It also makes the response prototype and the stream factory the first arguments, as those will be the values most often injected.

    The constructor signature is now:

    public function __construct(
        Psr\Http\Message\ResponseInterface $responsePrototype = null,
        callable $streamFactory = null,
        Hal\Renderer\JsonRenderer $jsonRenderer = null,
        Hal\Renderer\XmlRenderer $xmlRenderer = null
    ) {
  • #1 changes Hal\HalResponseFactoryFactory to comply with the new constructor signature of Hal\HalResponseFactory. It also updates to check for Psr\Http\Message\ResponseInterface and Psr\Http\Message\StreamInterface services before attempting to use zend-diactoros classes.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.6 - 2017-07-12

Added

  • Adds keywords to the composer.json
  • Adds a "provides" section to the composer.json (provides PSR-13 implementation)
  • Adds composer.json suggestions for:
    • PSR-11 implementation
    • zend-paginator

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.5 - 2017-07-12

Added

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.4 - 2017-07-12

Added

  • Adds the method templatedFromRoute() to the LinkGenerator class. Acts exactly like fromRoute(), but the generated Link instance will have the isTemplated property toggled true.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.3 - 2017-07-11

Added

  • Nothing.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Fixes registration of the MetadataMap in the ConfigProvider; it was previously using an incorrect namespace.

0.1.2 - 2017-07-11

Added

  • Adds HalResponseFactoryFactory, a factory for generating a HalResponseFactory instance.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.1 - 2017-07-11

Added

  • Adds the ability to inject route params and query string arguments at run-time to the route-based metadata instances.

    When dealing with route-based metadata, we may be dealing with sub-resources; in such cases, the route parameters may be derived from the request, and we will want to inject them at run-time.

    When dealing with collections, the query string arguments may indicate things such as searches, sort directions, sort columns, filters, limits, etc.; these will be derived from the request, and need to be injected at run-time.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.

0.1.0 - 2017-07-10

Initial Release.

Added

  • Everything.

Deprecated

  • Nothing.

Removed

  • Nothing.

Fixed

  • Nothing.