In the past we used to have a file updateSchema.js
```
#!/usr/bin/env babel-node
import fs from 'fs';
import path from 'path';
import { schema } from '../data/schema';
import { graphql } from 'graphql';
import { introspectionQuery, printSchema } from 'graphql/utilities';
// Save JSON of full schema introspection for Babel Relay Plugin to use
(async () => {
const result = await (graphql(schema, introspectionQuery));
if (result.errors) {
console.error(
'ERROR introspecting schema: ',
JSON.stringify(result.errors, null, 2)
);
} else {
fs.writeFileSync(
path.join(__dirname, '../data/schema.json'),
JSON.stringify(result, null, 2)
);
}
})();
// Save user readable type system shorthand of schema
fs.writeFileSync(
path.join(__dirname, '../data/schema.graphql'),
printSchema(schema)
);
```
That generated the schema.json
and schema.graphql
files, now in the v14 of graphql-js
theres a deprecation notice that instead of using introspectionQuery
we should use getIntrospectionQuery
v14 changelog.
Now updateSchema.js
looks like this relay-examples:
```
import fs from 'fs';
import path from 'path';
import {schema} from '../data/schema';
import {printSchema} from 'graphql';
const schemaPath = path.resolve(__dirname, '../data/schema.graphql');
fs.writeFileSync(schemaPath, printSchema(schema));
console.log('Wrote ' + schemaPath);
```
How are we suppose to generate the schema.json
file now?
const fs = require('fs');
const path = require('path');
const fetch = require('node-fetch');
const {
buildClientSchema,
getIntrospectionQuery,
printSchema,
} = require('graphql/utilities');
fetch('url.to.your.server', {
method: 'POST',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},
body: JSON.stringify({
query: getIntrospectionQuery(),
}),
})
.then(res => res.json())
.then(schemaJSON => printSchema(buildClientSchema(schemaJSON.data)))
.then(clientSchema =>
fs.writeFileSync(
path.join(__dirname, '..', 'schema.graphql'),
clientSchema,
),
);
should do the trick