graphql-php/CHANGELOG.md

7.6 KiB

Changelog

dev-master

This release brings several breaking changes. Please refer to UPGRADE document for details.

New features and notable changes:

  • New experimental executor with improved performance (#314).
    It is a one-line switch: GraphQL::useExperimentalExecutor().

    Please try it and post your feedback at https://github.com/webonyx/graphql-php/issues/397 (as it may become the default one in future)

  • Spec compliance: error category and extensions are displayed under extensions key when using default formatting (#389)
  • AbstractValidationRule renamed to ValidationRule (NS GraphQL\Validator\Rules)
  • AbstractQuerySecurity renamed to QuerySecurityRule (NS GraphQL\Validator\Rules)
  • FindBreakingChanges renamed to BreakingChangesFinder (NS GraphQL\Utils)
  • Added ability to override standard types via GraphQL::overrideStandardTypes(array $types) (#401)

v0.12.5

  • Execution performance optimization for lists

v0.12.4

  • Allow stringeable objects to be serialized by StringType (#303)

v0.12.3

  • StandardServer: add support for the multipart/form-data content type (#300)

v0.12.2

  • SchemaPrinter: Use multi-line block for trailing quote (#294)

v0.12.1

  • Fixed bug in validation rule OverlappingFieldsCanBeMerged (#292)
  • Added one more breaking change note in UPGRADE.md (#291)
  • Spec compliance: remove data entry from response on top-level error (#281)

v0.12.0

  • RFC: Block String (multi-line strings via triple-quote """string""")
  • GraphQL Schema SDL: Descriptions as strings (including multi-line)
  • Changed minimum required PHP version to 5.6

Improvements:

  • Allow extending GraphQL errors with additional properties
  • Fixed parsing of default values in Schema SDL
  • Handling several more cases in findBreakingChanges
  • StandardServer: expect operationName (instead of operation) in input

v0.11.5

  • Allow objects with __toString in IDType

v0.11.4

  • findBreakingChanges utility (see #199)

v0.11.3

  • StandardServer: Support non pre-parsed PSR-7 request body (see #202)

v0.11.2

  • Bugfix: provide descriptions to custom scalars (see #181)

v0.11.1

  • Ability to override internal types via types option of the schema (see #174).

v0.11.0

This release brings little changes but there are two reasons why it is released as major version:

  1. To follow reference implementation versions (it matches 0.11.x series of graphql-js)
  2. It may break existing applications because scalar input coercion rules are stricter now:
    In previous versions sloppy client input could leak through with unexpected results. For example string "false" accidentally sent in variables was converted to boolean true and passed to field arguments. In the new version, such input will produce an error (which is a spec-compliant behavior).

Improvements:

  • Stricter input coercion (see #171)
  • Types built with BuildSchema now have reference to AST node with corresponding AST definition (in $astNode property)
  • Account for query offset for error locations (e.g. when query is stored in .graphql file)

v0.10.2

  • StandardServer improvement: do not raise an error when variables are passed as empty string (see #156)

v0.10.1

  • Fixed infinite loop in the server (see #153)

v0.10.0

This release brings several breaking changes. Please refer to UPGRADE document for details.

New features and notable changes:

  • Changed minimum PHP version from 5.4 to 5.5
  • Lazy loading of types without separate build step (see #69, see docs)
  • PSR-7 compliant Standard Server (see docs)
  • New default error formatting, which does not expose sensitive data (see docs)
  • Ability to define custom error handler to filter/log/re-throw exceptions after execution (see docs)
  • Allow defining schema configuration using objects with fluent setters vs array (see docs)
  • Allow serializing AST to array and re-creating AST from array lazily (see docs)
  • Apollo-style query batching support via server (see docs)
  • Schema validation, including validation of interface implementations (see docs)
  • Ability to pass custom config formatter when defining schema using GraphQL type language (see docs)

Improvements:

  • Significantly improved parser performance (see #137 and #128)
  • Support for PHP7 exceptions everywhere (see #127)
  • Improved documentation and docblock comments

Deprecations and breaking changes - see UPGRADE document.

v0.9.14

  • Minor change to assist DataLoader project in fixing #150

v0.9.13

  • Fixed PHP notice and invalid conversion when non-scalar value is passed as ID or String type (see #121)

v0.9.12

  • Fixed bug occurring when enum value is bool, null or float (see #141)

v0.9.11

  • Ability to disable introspection (see #131)

v0.9.10

  • Fixed issue with query complexity throwing on invalid queries (see #125)
  • Fixed "Out of memory" error when resolveType returns unexpected result (see #119)

v0.9.9

  • Bugfix: throw UserError vs InvariantViolationError for errors caused by client (see #123)

v0.9.8

  • Bugfix: use directives when calculating query complexity (see #113)
  • Bugfix: AST\Node::__toString() will convert node to array recursively to encode to json without errors

v0.9.7

  • Bugfix: ResolveInfo::getFieldSelection() now correctly merges fragment selections (see #98)

v0.9.6

  • Bugfix: ResolveInfo::getFieldSelection() now respects inline fragments

v0.9.5

  • Fixed SyncPromiseAdapter::all() to not change the order of arrays (see #92)

v0.9.4

  • Tools to help building schema out of Schema definition language as well as printing existing schema in Schema definition language (see #91)

v0.9.3

  • Fixed Utils::assign() bug related to detecting missing required keys (see #89)

v0.9.2

  • Schema Definition Language: element descriptions can be set through comments (see #88)

v0.9.1

  • Fixed: GraphQL\Server now properly sets promise adapter before executing query

v0.9.0

  • Deferred resolvers (see #66, see docs)
  • New Facade class with fluid interface: GraphQL\Server (see #82)
  • Experimental: ability to load types in Schema lazily via custom TypeResolutionStrategy (see #69)

v0.8.0

This release brings several minor breaking changes. Please refer to UPGRADE document for details.

New features:

  • Support for null value (as required by latest GraphQL spec)
  • Shorthand definitions for field and argument types (see #47)
  • path entry in errors produced by resolvers for better debugging
  • resolveType for interface/union is now allowed to return string name of type
  • Ability to omit name when extending type class (vs defining inline)

Improvements:

  • Spec compliance improvements
  • New docs and examples

Older versions

Look at GitHub Releases Page.