@shopify/webpack-persisted-graphql-plugin
Generates a GraphQL metadata file mapping hash identifiers to the original source
Last updated 3 months ago by shopify-dep .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ cnpm install @shopify/webpack-persisted-graphql-plugin 
SYNC missed versions from official npm registry.

webpack-persisted-graphql-plugin

Usage

This plugin hooks into emit stage of the Webpack compilation, finds all modules that were originally .graphql files, extracts some metadata, and writes it to a JSON file. The contents of this file are a map from unique identifier to the "resolved" GraphQL document. In order for this process to work, you must use the graphql-mini-transforms Webpack loader to transform GraphQL documents, as this plugin depends on the shape of that loader's output.

With this file, it is easy to implement persisted queries:

  • Send the unique identifier from the GraphQL document instead of its contents (for example, using the graphql-persisted Apollo link)
  • On the server, read the manifest file produced by this plugin
  • Take the identifier from the GraphQL request, and look that value up in the manifest file
  • If a value is found, use that as the GraphQL document (otherwise, send a response that forces the client to send the full GraphQL document)

The JSON file produced by this plugin is written in the outputPath of the compilation, with the filename set when constructing this plugin.

import {PersistedGraphQLPlugin} from '@shopify/webpack-persisted-graphql-plugin';

const webpackConfig = {
  //
  // Rest of the config...
  //
  plugins: [
    new PersistedGraphQLPlugin({
      filename: 'graphql.json', // default is 'persisted-graphql.json'
    }),
  ],
};

Current Tags

  • 1.0.2                                ...           latest (3 months ago)
  • 1.0.2-remove-babel-beta.1                                ...           next (4 days ago)

4 Versions

  • 1.0.2-remove-babel-beta.1                                ...           4 days ago
  • 1.0.2                                ...           3 months ago
  • 1.0.1                                ...           5 months ago
  • 1.0.0                                ...           7 months ago

Copyright 2014 - 2017 © taobao.org |