/graphql-transport-ws

WebSocket transport for GraphQL subscriptions

Primary LanguageGoBSD 2-Clause "Simplified" LicenseBSD-2-Clause

graphql-transport-ws

Build Status

(Work in progress!)

A Go package that leverages WebSockets to transport GraphQL subscriptions, queries and mutations implementing the Apollo@v0.9.4 protocol

Use with graph-gophers/graphql-go

To use this library with github.com/graph-gophers/graphql-go you can wrap the relay handler it provides the following way:

package main

import (
	"fmt"
	"net/http"

	graphql "github.com/graph-gophers/graphql-go"
	"github.com/graph-gophers/graphql-go/relay"
	"github.com/graph-gophers/graphql-transport-ws/graphqlws"
)

const schema = `
	schema {
		subscription: Subscription
	}

	type Subscription {
		...
	}
`

type resolver struct {
	// ...
}

func main() {
	// init graphQL schema
	s, err := graphql.ParseSchema(schema, &resolver{})
	if err != nil {
		panic(err)
	}

	// graphQL handler
	graphQLHandler := graphqlws.NewHandlerFunc(s, &relay.Handler{Schema: s})
	http.HandleFunc("/graphql", graphQLHandler)

	// start HTTP server
	if err := http.ListenAndServe(fmt.Sprintf(":%d", 8080), nil); err != nil {
		panic(err)
	}
}

For a more in depth example see this repo.

Client

Check apollographql/subscription-transport-ws for details on how to use WebSockets on the client side.