node package manager
Loosely couple your services. Use Orgs to version and reuse your code. Create a free org »

@absinthe/socket-apollo-link

@absinthe/socket-apollo-link

Absinthe Socket Apollo Link

Installation

Using npm

$ npm install --save @absinthe/socket-apollo-link

Using yarn

$ yarn add @absinthe/socket-apollo-link

Examples

  1. Create AbsintheSocketLink (absinthe-socket-link.js)
// @flow
 
import * as AbsintheSocket from "@absinthe/socket";
import {createAbsintheSocketLink} from "@absinthe/socket-apollo-link";
import {Socket as PhoenixSocket} from "phoenix";
 
export default createAbsintheSocketLink(AbsintheSocket.create(
  new PhoenixSocket("ws://localhost:4000/socket")
));
  1. Send all the operations using AbsintheSocketLink
// @flow
 
import ApolloClient from "apollo-client";
import {InMemoryCache} from "apollo-cache-inmemory";
 
// see example 1
import absintheSocketLink from "./absinthe-socket-link";
 
const client = new ApolloClient({
  link: absintheSocketLink,
  cache: new InMemoryCache()
});
  1. Subscribe using AbsintheSocketLink and send queries and mutations using HttpLink
// @flow
 
import ApolloClient from "apollo-client";
import {ApolloLink} from "apollo-link";
import {createHttpLink} from "apollo-link-http";
import {hasSubscription} from "@jumpn/utils-graphql";
import {InMemoryCache} from "apollo-cache-inmemory";
 
// see example 1
import absintheSocketLink from "./absinthe-socket-link";
 
const link = new ApolloLink.split(
  operation => hasSubscription(operation.query),
  absintheSocketLink,
  createHttpLink({uri: "/graphql"})
);
 
const client = new ApolloClient({
  link,
  cache: new InMemoryCache()
});

API

createAbsintheSocketLink

Creates a terminating ApolloLink to request operations using given AbsintheSocket instance

Parameters

  • absintheSocket AbsintheSocket
  • onError $PropertyType<Observer<any>, "onError">
  • onStart $PropertyType<Observer<any>, "onStart">

References

License

MIT ©️ Jumpn Limited.