@absinthe/socket-apollo-link
Absinthe Socket Apollo Link
Installation
$ npm install --save @absinthe/socket-apollo-link
$ yarn add @absinthe/socket-apollo-link
Examples
- Create AbsintheSocketLink (
absinthe-socket-link.js
)
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")
));
- Send all the operations using AbsintheSocketLink
import ApolloClient from "apollo-client";
import {InMemoryCache} from "apollo-cache-inmemory";
import absintheSocketLink from "./absinthe-socket-link";
const client = new ApolloClient({
link: absintheSocketLink,
cache: new InMemoryCache()
});
- Subscribe using AbsintheSocketLink and send queries and mutations using HttpLink
import ApolloClient from "apollo-client";
import {createHttpLink} from "apollo-link-http";
import {hasSubscription} from "@jumpn/utils-graphql";
import {InMemoryCache} from "apollo-cache-inmemory";
import {split} from "apollo-link";
import absintheSocketLink from "./absinthe-socket-link";
const link = 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
AbsintheSocketonError
$ElementType<Observer<Result, Variables>, "onError"
>onStart
$ElementType<Observer<Result, Variables>, "onStart"
>
References
License
MIT :copyright: Jumpn Limited.