src/graphql/lib
andsrc/graphql/scripts
are human-editable.src/graphql/data/**
are generated by scripts.
src/graphql/lib/validator.json
- JSON schema used in
tests/graphql.js
.
- JSON schema used in
src/graphql/lib/non-schema-scalars.json
- An array of scalar types that live in
graphql-ruby
only. These are not part of the core GraphQL spec.
- An array of scalar types that live in
src/graphql/lib/types.json
- High-level GraphQL types and kinds.
Generated by src/graphql/scripts/update-files.js
:
src/graphql/data/schema-VERSION.json
(separate files per version)src/graphql/data/previews.json
src/graphql/data/upcoming-changes.json
src/graphql/data/changelog.json
When the server starts, middleware/graphql.js
accesses the static JSON files, fetches the data for the current version, and adds it to the context
object. The added properties are:
context.graphql.schemaForCurrentVersion
context.graphql.previewsForCurrentVersion
context.graphql.upcomingChangesForCurrentVersion
context.graphql.changelog
Markdown files in content/graphql
use Liquid to loop over these context properties. The Liquid calls HTML files in the includes
directory to do most of the rendering.
Note that Markdown files exist in content/graphql
for every URL available in our GraphQL
documentation. Writers can add content to the Markdown files alongside the Liquid.