I'm playing with relay-starter-kit. I've also used sangria to create a graphql server. Now I'm trying to wire the two together.
In relay-starter-kit, every time you alter the schema, you need to run a script to regenerate the schema.json file. But since graphql supports schema introspection I'm wondering if there's a way to configure my relay app to introspect the schema from the server when it starts up.
Does anyone know if this is possible or worked out how to do this?
Define a babelRelayPlugin.js (which is run by webpack when validating the client graphql queries) as such:
var babelRelayPlugin   = require('babel-relay-plugin');
var introspectionQuery = require('graphql/utilities').introspectionQuery;
var request            = require('sync-request');
var url = 'http://localhost:3000/graphql';
var response = request('POST', url, {
   qs: {
      query: introspectionQuery
   }
});
var schema = JSON.parse(response.body.toString('utf-8'));
module.exports = babelRelayPlugin(schema.data, {
   abortOnError: true,
});
Of course, change the url variable to whatever server url you use for development. In webpack, include the following in your loaders definition:
query: {stage: 0, plugins: ['./babelRelayPlugin']}
and point to the location of the above babelRelayPlugin.js file.
Looks like we need something like this (from https://github.com/facebook/relay/blob/master/scripts/jest/updateSchema.js#L25):
import { buildASTSchema, introspectionQuery } from 'graphql/utilities';
var body = fs.readFileSync(inFile, 'utf8');
var ast = parseSchemaIntoAST(body);
var astSchema = buildASTSchema(ast, 'Root', 'Mutation');
graphql(astSchema, introspectionQuery).then(
    function(result) {
      var out = JSON.stringify(result, null, 2);
      fs.writeFileSync(outFile, out);
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With