Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/exogen/graphql-markdown

The easiest way to document your GraphQL schema.
https://github.com/exogen/graphql-markdown

docgen docs documentation-generator github graphql markdown

Last synced: 5 days ago
JSON representation

The easiest way to document your GraphQL schema.

Awesome Lists containing this project

README

        

# graphql-markdown

**The easiest way to document your GraphQL schema.**

[![npm version](https://img.shields.io/npm/v/graphql-markdown.svg)](https://www.npmjs.com/package/graphql-markdown)

---

This package will generate Markdown that beautifully renders your GraphQL schema
in an easily explorable document.

```console
$ yarn add graphql-markdown --dev
$ npm install graphql-markdown --save-dev
```

**[See an example][example]** generated from the [GraphBrainz][] schema.

## Support

Did this project bring you joy? Want to support updates? Check out
[my GitHub Sponsors page](https://github.com/sponsors/exogen).

Alternatively…

Buy Me A Coffee

## Usage

### Command Line API

Installing the package adds a `graphql-markdown` script via the standard package.json
[`bin`](https://docs.npmjs.com/cli/v10/configuring-npm/package-json#bin) field – see
npm’s [Executables](https://docs.npmjs.com/cli/v10/configuring-npm/folders#executables)
documentation to learn where this will be on your system. For local installs,
this is typically `node_modules/.bin`. When referencing the executable in
your package.json’s `scripts`, you may simply call `graphql-markdown`.

Point the `graphql-markdown` script at a schema and the output will be written
to stdout. You must install `graphql` alongside this package according to the
[compatible versions specified in `peerDependencies`](./package.json).

The schema may be retrieved from a GraphQL endpoint:

```console
$ graphql-markdown http://your-server.com/graphql > schema.md
```

…or a module exporting an instance of `GraphQLSchema`:

```console
$ graphql-markdown ./path/to/schema.js > schema.md
```

…or a file containing GraphQL syntax:

```console
$ graphql-markdown ./path/to/schema.graphql > schema.md
```

…or a file containing the JSON output of an introspection query:

```console
$ graphql-markdown ./path/to/schema.json > schema.md
```

If `--update-file` is given, the generated Markdown will be output to the given
file between the `` and
`` comment markers instead of printed to STDOUT. If
the file does not exist, it will be created (and will include the comment
markers for future updates). Use this if you’d like to embed the rendered
Markdown as just one part of a larger document (see also the `--heading-level`
option).

#### Options

```console
$ graphql-markdown --help

Usage: graphql-markdown [options]

Output a Markdown document with rendered descriptions and links between types.
The schema may be specified as:

- a URL to the GraphQL endpoint (the introspection query will be run)
- a GraphQL document containing the schema (.graphql or .gql)
- a JSON document containing the schema (as returned by the introspection query)
- an importable module with the schema as its default export (either an instance
of GraphQLSchema or a JSON object)

Options:

--title Change the top heading title (default: 'Schema Types')
--no-title Do not print a default title
--no-toc Do not print table of contents
--toc-fields Expand the table of contents for the listed types
(comma-separated) to link to fields within those types
(e.g. --toc-fields "Query,Mutation,Subscription") or use
the string "*" to link to fields for all types
--prologue Include custom Markdown after the title
--epilogue Include custom Markdown after everything else
--heading-level Heading level to begin at, useful if you are embedding the
output in a document with other sections (default: 1)
--update-file Markdown document to update (between comment markers) or
create (if the file does not exist)
--require If importing the schema from a module, require the specified
module first (useful for e.g. babel-register)
--header Additional header(s) to use in GraphQL request
e.g. --header "Authorization=Bearer ey..."
--version Print version and exit
```

### Node API

The following functions are exported from the `graphql-markdown` module for
programmatic use.

#### loadSchemaJSON(schemaPath: string, options: object)

Given a string pointing to a GraphQL schema (URL, module, or file path), get the
result of the introspection query, suitable for use as input to `renderSchema`.

#### renderSchema(schema: object, options: object)

Given a schema JSON object (the output of the introspection query, an object
with a `__schema` property), render the schema to the console or the provided
`printer` function.

##### Options

- **`title`**: The title of the document, defaults to “Schema Types”.
- **`prologue`**: Markdown content to include after the title.
- **`epilogue`**: Markdown content to include after everything else.
- **`printer`**: A function to handle each line of output, defaults to
`console.log`.
- **`skipTableOfContents`**: When set, rendering of "Table of contents" section
is skipped.
- **`tocFieldTypes`**: An array of type names whose table of contents entry will
be expanded to link to individual fields in a nested list. Include the special
name `*` in the array to match all types.
- **`headingLevel`**: The initial level at which to render Markdown headings in
the output, defaults to 1. Use this if you are using `updateSchema` to embed
the output in a larger document with other sections.
- **`unknownTypeURL`**: A string or function to determine the URL for linking to
types that aren’t found in the schema being rendered. This may be the case if
you’re rendering the result of `diffSchema()`, for example. String values will
have `#${type.name.toLowerCase()}` appended, and function values will be
called with the type object for full control.

#### updateSchema(path: string, schema: object, options: object)

Given a path to a Markdown document, inject the output of `renderSchema` (with
the given schema and options) into the document between the comment markers
`` and ``. Returns a
Promise.

If the file does not exist, it will be created. If the document is empty, the
necessary comment markers will automatically be inserted, but if there is
existing content and no comment markers, the Promise will be rejected with an
error.

#### diffSchema(oldSchema: object, newSchema: object, options: object)

Given two schema JSON objects (the results of the introspection query on two
schemas), return a new schema JSON object containing only the added or updated
types and fields. You can use this to document a schema update, or to document
the effects of a schema extension (e.g. `extend type` definitions).

##### Options

- **`processTypeDiff`**: A function to add or modify fields on each type that
will be output.

## Output

Output is optimized for display on GitHub, using GitHub Flavored Markdown. Due
to the complexity of the tables in the generated document, much of the table
output is raw HTML (as allowed by Markdown).

[example]: https://github.com/exogen/graphbrainz/blob/master/docs/types.md
[graphbrainz]: https://github.com/exogen/graphbrainz