graphql-subscriptions-wsdeprecated

A WebSocket client for GraphQL subscriptions

Usage no npm install needed!

<script type="module">
  import graphqlSubscriptionsWs from 'https://cdn.skypack.dev/graphql-subscriptions-ws';
</script>

README

graphql-subscriptions-ws

Work in progress!

A client for GraphQL subscriptions over WebSocket. Server implementation coming soon!

Getting started

yarn add subscriptions-transport-ws
# or
npm install subscriptions-transport-ws

Relay

import { createClient } from 'graphql-subscriptions-ws';
import { Network } from 'relay-runtime';

const subscriptionsClient = createClient({
  url: 'wss://some.url/graphql',
  connectionParams: () => {
    const session = getSession();
    if (!session) {
      return null;
    }
    return {
      Authorization: `Bearer ${session.token}`,
    };
  },
});

export const network = Network.create(
  // fetch
  (operation, variables, cacheConfig) => {
    return Observable.create((sink) => {
      fetchQuery(operation, variables, cacheConfig, sink);
    });
  },
  // subscribe
  (operation, variables) => {
    return Observable.create((sink) => {
      if (!operation.text) {
        return sink.error(new Error('Operation text cannot be empty'));
      }
      return subscriptionsClient.subscribe(
        {
          operationName: operation.name,
          query: operation.text,
          variables,
        },
        sink
      );
    });
  }
);

Protocol

Read more about it in the PROTOCOL.md

Want to help?

Want to file a bug, contribute some code, or improve documentation? Excellent! Read up on our guidelines for contributing.