GraphQL-Ruby’s JavaScript client includes four kinds of support for Apollo Client:
Apollo 2 is supported by implementing Apollo Links.
graphql-ruby-client
includes support for subscriptions with Pusher and ApolloLink.
To use it, add PusherLink
before your HttpLink
.
For example:
// Load Apollo stuff
import { ApolloLink } from 'apollo-link';
import { ApolloClient } from 'apollo-client';
import { HttpLink } from 'apollo-link-http';
import { InMemoryCache } from 'apollo-cache-inmemory';
// Load PusherLink from graphql-ruby-client
import PusherLink from 'graphql-ruby-client/subscriptions/PusherLink';
// Load Pusher and create a client
import Pusher from "pusher-js"
var pusherClient = new Pusher("your-app-key", { cluster: "us2" })
// Make the HTTP link which actually sends the queries
const httpLink = new HttpLink({
uri: '/graphql',
credentials: 'include'
});
// Make the Pusher link which will pick up on subscriptions
const pusherLink = new PusherLink({pusher: pusherClient})
// Combine the two links to work together
const link = ApolloLink.from([pusherLink, httpLink])
// Initialize the client
const client = new ApolloClient({
link: link,
cache: new InMemoryCache()
});
This link will check responses for the X-Subscription-ID
header, and if it’s present, it will use that value to subscribe to Pusher for future updates.
graphql-ruby-client
includes support for subscriptions with Ably and ApolloLink.
To use it, add AblyLink
before your HttpLink
.
For example:
// Load Apollo stuff
import { ApolloLink } from 'apollo-link';
import { ApolloClient } from 'apollo-client';
import { HttpLink } from 'apollo-link-http';
import { InMemoryCache } from 'apollo-cache-inmemory';
// Load Ably and create a client
const Ably = require("ably")
const ablyClient = new Ably.Realtime({ key: "your-app-key" })
// Make the HTTP link which actually sends the queries
const httpLink = new HttpLink({
uri: '/graphql',
credentials: 'include'
});
// Make the Ably link which will pick up on subscriptions
const ablyLink = new AblyLink({ably: ablyClient})
// Combine the two links to work together
const link = ApolloLink.from([ablyLink, httpLink])
// Initialize the client
const client = new ApolloClient({
link: link,
cache: new InMemoryCache()
});
This link will check responses for the X-Subscription-ID
header, and if it’s present, it will use that value to subscribe to Ably for future updates.
For your app key, make a key with “Subscribe” and “Presence” privileges and use that:
/javascript_client/ably_key.png
graphql-ruby-client
includes support for subscriptions with ActionCable and ApolloLink.
To use it, construct a split link that routes:
ActionCableLink
; andHttpLink
For example:
import { ApolloLink } from 'apollo-link';
import { ApolloClient } from 'apollo-client';
import { HttpLink } from 'apollo-link-http';
import { InMemoryCache } from 'apollo-cache-inmemory';
import ActionCable from 'actioncable';
import ActionCableLink from 'graphql-ruby-client/subscriptions/ActionCableLink';
const cable = ActionCable.createConsumer()
const httpLink = new HttpLink({
uri: '/graphql',
credentials: 'include'
});
const hasSubscriptionOperation = ({ query: { definitions } }) => {
return definitions.some(
({ kind, operation }) => kind === 'OperationDefinition' && operation === 'subscription'
)
}
const link = ApolloLink.split(
hasSubscriptionOperation,
new ActionCableLink({cable}),
httpLink
);
const client = new ApolloClient({
link: link,
cache: new InMemoryCache()
});
graphql-ruby-client
includes support for Apollo 1 client subscriptions over Pusher%20or%20%5BActionCable%5D(/subscriptions/action_cable_implementation).
To use it, require subscriptions/addGraphQLSubscriptions
and call the function with your network interface and transport client (example below).
See the Subscriptions guide for information about server-side setup.
Pass {pusher: pusherClient}
to use Pusher:
// Load Pusher and create a client
var Pusher = require("pusher-js")
var pusherClient = new Pusher(appKey, options)
// Add subscriptions to the network interface with the `pusher:` options
var addGraphQLSubscriptions = require("graphql-ruby-client/subscriptions/addGraphQLSubscriptions")
addGraphQLSubscriptions(myNetworkInterface, {pusher: pusherClient})
// Optionally, add persisted query support:
var OperationStoreClient = require("./OperationStoreClient")
RailsNetworkInterface.use([OperationStoreClient.apolloMiddleware])
By passing {cable: cable}
, all subscription
queries will be routed to ActionCable.
For example:
// Load ActionCable and create a consumer
var ActionCable = require('actioncable')
var cable = ActionCable.createConsumer()
window.cable = cable
// Load ApolloClient and create a network interface
var apollo = require('apollo-client')
var RailsNetworkInterface = apollo.createNetworkInterface({
uri: '/graphql',
opts: {
credentials: 'include',
},
headers: {
'X-CSRF-Token': $("meta[name=csrf-token]").attr("content"),
}
});
// Add subscriptions to the network interface
var addGraphQLSubscriptions = require("graphql-ruby-client/subscriptions/addGraphQLSubscriptions")
addGraphQLSubscriptions(RailsNetworkInterface, {cable: cable})
// Optionally, add persisted query support:
var OperationStoreClient = require("./OperationStoreClient")
RailsNetworkInterface.use([OperationStoreClient.apolloMiddleware])