Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Macroz/GraphQLviz
GraphQLviz marries GraphQL (schemas) with Graphviz.
https://github.com/Macroz/GraphQLviz
Last synced: 3 months ago
JSON representation
GraphQLviz marries GraphQL (schemas) with Graphviz.
- Host: GitHub
- URL: https://github.com/Macroz/GraphQLviz
- Owner: Macroz
- License: epl-1.0
- Created: 2015-10-11T20:27:54.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2017-04-25T09:12:54.000Z (almost 8 years ago)
- Last Synced: 2024-10-16T03:43:23.083Z (3 months ago)
- Language: Clojure
- Size: 6.54 MB
- Stars: 116
- Watchers: 5
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-graphql - GraphQLviz - GraphQLviz marries GraphQL (schemas) with Graphviz. (Tools / Julia Libraries)
- awesome-graphql - GraphQLviz - GraphQLviz marries GraphQL (schemas) with Graphviz. (Tools / Crystal Libraries)
README
# GraphQLviz [![Build Status](https://travis-ci.org/Macroz/GraphQLviz.svg?branch=master)](https://travis-ci.org/Macroz/GraphQLViz)
GraphQLviz marries GraphQL (schemas) with Graphviz.
It's a tool to show you what your schema really looks like. At the moment, it's mostly useful as a complement to [GraphiQL](https://github.com/graphql/graphiql), like printing a huge poster size version to facilitate team discussions.
## Quick Usage
Requires [Graphviz](http://www.graphviz.org) and [Java Virtual Machine](http://openjdk.java.net/).
There is a convenient uberjar release available to download from the [release page](https://github.com/Macroz/GraphQLviz/releases).
Once you have Graphviz, Java and the uberjar, then you can use GraphQLviz like a regular Java app like so:
```
java -jar graphqlviz.jar https://api.digitransit.fi/routing/v1/routers/finland/index/graphql digitransit
```[Example schema](examples/digitransit.json?raw=true) (from [Digitransit](http://digitransit.fi))
![Example graph](https://rawgit.com/Macroz/GraphQLviz/master/examples/digitransit.svg)
Run `java -jar graphqlviz.jar --help` for more options or read the Full Usage.
## Full Usage
You must have Graphviz executable from command-line. Download and install it using your package manager or go to [Graphviz](http://www.graphviz.org).
You also need [Leiningen](http://leiningen.org). Leiningen is the [Clojure](http://clojure.org) build tool that runs on the Java Virtual Machine. This means you also need Java.
If you like to use Leiningen, you can run like this:
```
lein run https://api.digitransit.fi/routing/v1/routers/finland/index/graphql digitransit
```There is a prepackaged jar in [Clojars](https://clojars.org/macroz/graphqlviz) so you don't have to build GraphQLviz yourself.
Also there is a convenient uberjar release available to download from the [release page](https://github.com/Macroz/GraphQLviz/releases).
With these JAR files you can run like this:
```
java -jar graphqlviz.jar https://api.digitransit.fi/routing/v1/routers/finland/index/graphql digitransit
```If you want to use the code from Clojure, perhaps from your own program, add to your project.clj:
[![Clojars Project](http://clojars.org/macroz/graphqlviz/latest-version.svg)](http://clojars.org/macroz/graphqlviz)
### Separate introspection
Instead of running against a live GraphQL server, you can use a downloaded result of an introspection query like this:
```
java -jar graphqlviz.jar examples/digitransit.json digitransit
```Otherwise, in the case of a URL, the introspection query is executed against the GraphQL endpoint and the results visualized.
### Authentication
Since 0.4.0, you can pass options for authenticating with the server for the introspection query (`-a` or `--auth`).
The supported authentication types are `basic`, `digest` (with user and password) as well as `oauth2` (with oauth token) See also `-h` for help.
```
java -jar graphqlviz.jar http://secret.example.com/graphql secret-schema-name -abasic -utester -ppassword
```Or with password prompt `-pp` or `--password-prompt` (since 0.5.0).
```
java -jar graphqlviz.jar http://secret.example.com/graphql secret-schema-name -abasic -utester --password-prompt
```## Backlog
- Use dynamic graph features as in [archi](https://github.com/Macroz/archi)
- Develop a complete JavaScript solution of the same idea## License
Copyright © 2015-2017 Markku Rontu
Distributed under the Eclipse Public License either version 1.0 or (at
your option) any later version.