bigfork/silverstripe-graphql-batching

Adds support for HTTP-based batching of GraphQL operations in Silverstripe

Installs: 1 231

Dependents: 0

Suggesters: 0

Security: 0

Stars: 4

Watchers: 5

Forks: 1

Open Issues: 0

Type:silverstripe-vendormodule

1.1.0 2024-12-09 11:29 UTC

This package is auto-updated.

Last update: 2025-01-09 11:36:48 UTC


README

Adds basic support for using Apollo’s BatchHTTPLink to send multiple GraphQL operations in a single HTTP request.

Note that this approach does not run operations in parallel - they are executed in order, one at a time. Because of this, and the fact that all operations have to be complete before any can be returned, there’s no guarantee this will improve the performance of your app - do your own research and testing!

Install

composer require bigfork/silverstripe-graphql-batching

Usage

Register a new Injector service for your schema (in the example below, we’re using the schema name default) and then point your GraphQL route to it:

SilverStripe\Core\Injector\Injector:
  Bigfork\SilverstripeGraphQLBatching\Controller.default:
    class: Bigfork\SilverstripeGraphQLBatching\Controller
    constructor:
      schema: default
      handler: '%$SilverStripe\GraphQL\QueryHandler\QueryHandlerInterface.default'
      batchMax: 10
SilverStripe\Control\Director:
  rules:
    'graphql': '%$Bigfork\SilverstripeGraphQLBatching\Controller.default'

Please note: batchMax is the maximum number of operations that can be included in a single HTTP request. It should match the batchMax value you set when creating the BatchHttpLink in your client-side code (default 10) and should be kept as low as possible. The higher this value is, the more likely it is to become a DDoS attack vector: if you allow someone to run dozens of GraphQL operations in a single HTTP request, it becomes trivial to overload your server.