1. GraphQL

GraphQL using GraphQL Java library.

1.1. Usage

1) Add the dependency:

Maven
Gradle
<!-- GraphQL-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-graphql</artifactId>
  <version>3.6.0</version>
</dependency>

<!--  JSON library-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-jackson</artifactId>
  <version>3.6.0</version>
</dependency>

2) Creates schema.graphql inside the src/main/resource

type Query {
    bookById(id: ID): Book
}

type Book {
    id: ID
    name: String
    pageCount: Int
    author: Author
}

type Author {
    id: ID
    firstName: String
    lastName: String
}

3) Install Jackson and GraphQL

Java
Kotlin
import io.jooby.json.JacksonModule;
import io.jooby.graphql.GraphQLModule;

{
  install(new JacksonModule());           (1)

  install(new GraphQLModule(
    RuntimeWiring.newRuntimeWiring()      (2)
        .type(newTypeWiring("Query")
            .dataFetcher("bookById", fetchers.getBookByIdDataFetcher()))
        .type(newTypeWiring("Book")
            .dataFetcher("author", fetchers.getAuthorDataFetcher()))
        .build())
   );
}
1 Install Jackson
2 Install GraphQL, uses the schema.graphql and provide a RuntimeWiring

The GraphQL module generates a POST /graphql route.

1.2. Options

1.2.1. Async

The GraphQL Java library executes queries in async mode. To turn-off the async mode:

Async Mode
Java
Kotlin
import io.jooby.json.JacksonModule;
import io.jooby.graphql.GraphQLModule;

{
  install(new GraphQLModule(...)
      .setAsync(false)                    (1)
  );
}
1 Set async false

Please refer to Asynchronous execution for more information.

1.2.2. Support HTTP Get

By default the module only install a HTTP POST route. If you want a HTTP GET:

HTTP GET
Java
Kotlin
import io.jooby.json.JacksonModule;
import io.jooby.graphql.GraphQLModule;

{
  install(new GraphQLModule(...)
      .setSupportHttpGet(true)
  );
}

1.2.3. Path

To change the default path: /graphql set the graphql.path property in your application configuration file.

1.3. IDE

Jooby comes with supports for two IDE:

They are provided as optional dependencies.

1.3.1. GraphIQL

1) Add the dependencies:

Maven
Gradle
<!--  JSON library-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-jackson</artifactId>
  <version>3.6.0</version>
</dependency>

<!-- GraphQL-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-graphql</artifactId>
  <version>3.6.0</version>
</dependency>

<!--  GraphIQL-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-graphiql</artifactId>
  <version>3.6.0</version>
</dependency>

1) Install

Java
Kotlin
import io.jooby.json.JacksonModule;
import io.jooby.graphql.GraphQLModule;
import io.jooby.graphql.GraphiQLModule;

{
  install(new JacksonModule());           (1)

  install(new GraphQLModule(...));        (2)

  install(new GraphiQLModule());          (3)
}
1 Install Jackson
2 Install GraphQL
3 Install GraphiQL

GraphiQL should be up and running at /graphql.

1.3.2. GraphQL Playground

1) Add the dependencies:

Maven
Gradle
<!--  JSON library-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-jackson</artifactId>
  <version>3.6.0</version>
</dependency>

<!-- GraphQL-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-graphql</artifactId>
  <version>3.6.0</version>
</dependency>

<!--  GraphQL Playground-->
<dependency>
  <groupId>io.jooby</groupId>
  <artifactId>jooby-graphiql-playground</artifactId>
  <version>3.6.0</version>
</dependency>

1) Install

Java
Kotlin
import io.jooby.json.JacksonModule;
import io.jooby.graphql.GraphQLModule;
import io.jooby.graphql.GraphQLPlaygroundModule;

{
  install(new JacksonModule());                    (1)

  install(new GraphQLModule(...));                 (2)

  install(new GraphQLPlaygroundModule());          (3)
}
1 Install Jackson
2 Install GraphQL
3 Install GraphQL Playground

GraphQL Playground should be up and running at /graphql.

1.4. Starter

Checkout the starter/demo project for GraphQL: GraphQL Starter.