Skip to content

Commit

Permalink
added support for subscriptions
Browse files Browse the repository at this point in the history
  • Loading branch information
Urigo committed Mar 28, 2017
1 parent e2c4258 commit c4fabe3
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 18 deletions.
1 change: 1 addition & 0 deletions packages/graphql-server-express/src/expressApollo.ts
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ export function graphiqlExpress(options: GraphiQL.GraphiQLData) {

const graphiQLString = GraphiQL.renderGraphiQL({
endpointURL: options.endpointURL,
subscriptionsEndpoint: options.subscriptionsEndpoint,
query: query || options.query,
variables: q.variables && JSON.parse(q.variables) || options.variables,
operationName: operationName || options.operationName,
Expand Down
84 changes: 66 additions & 18 deletions packages/graphql-server-module-graphiql/src/renderGraphiQL.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ export function renderGraphiQL(data: GraphiQLData): string {
<script src="//cdn.jsdelivr.net/react/15.0.0/react.min.js"></script>
<script src="//cdn.jsdelivr.net/react/15.0.0/react-dom.min.js"></script>
<script src="//cdn.jsdelivr.net/graphiql/${GRAPHIQL_VERSION}/graphiql.min.js"></script>
<script src="//unpkg.com/subscriptions-transport-ws@0.5.3/browser/client.js"></script>
</head>
<body>
<script>
Expand Down Expand Up @@ -97,28 +98,73 @@ export function renderGraphiQL(data: GraphiQLData): string {
otherParams[k] = parameters[k];
}
}
var subscriptionsClient;
var activeSubscriptionId = -1;
function initSubscriptions() {
var subscriptionsEndpoint = 'ws://' + window.location.hostname +
(window.location.port ? ':' + window.location.port: '') + '/subscriptions';
if (window.SubscriptionsTransportWs && window.SubscriptionsTransportWs.SubscriptionClient) {
subscriptionsClient = new window.SubscriptionsTransportWs.SubscriptionClient(subscriptionsEndpoint, {
reconnect: true
});
subscriptionsClient.onConnect(function() {
console.log('Connected to GraphQL Subscriptions server...');
});
}
}
function graphQlSubscriptionFetcher(graphQLParams) {
return {
subscribe: function(observer) {
observer.next('Your subscription data will apear here after server publication!');
activeSubscriptionId = subscriptionsClient.subscribe({
query: graphQLParams.query,
variables: graphQLParams.variables
}, function(error, result) {
if (error) {
observer.error(error);
}
else {
observer.next(result);
}
});
}
}
}
// We don't use safe-serialize for location, because it's not client input.
var fetchURL = locationQuery(otherParams, '${endpointURL}');
// Defines a GraphQL fetcher using the fetch API.
function graphQLFetcher(graphQLParams) {
return fetch(fetchURL, {
method: 'post',
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
${passHeader}

This comment has been minimized.

Copy link
@comus

comus Apr 15, 2017

Contributor

hello, did you forget add back passHeader?

i cannot find the updated script using passHeader variable

},
body: JSON.stringify(graphQLParams),
credentials: 'include',
}).then(function (response) {
return response.text();
}).then(function (responseBody) {
try {
return JSON.parse(responseBody);
} catch (error) {
return responseBody;
}
});
if (subscriptionsClient && activeSubscriptionId !== -1) {
subscriptionsClient.unsubscribe(activeSubscriptionId);
}
if (subscriptionsClient && graphQLParams.query.startsWith('subscription')) {
return graphQlSubscriptionFetcher(graphQLParams);
}
else {
return fetch('/graphql', {
method: 'post',
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
},
body: JSON.stringify(graphQLParams),
credentials: 'include',
}).then(function (response) {
return response.text();
}).then(function (responseBody) {
try {
return JSON.parse(responseBody);
} catch (error) {
return responseBody;
}
});
}
}
// When the query and variables string is edited, update the URL bar so
// that it can be easily shared.
Expand Down Expand Up @@ -151,6 +197,8 @@ export function renderGraphiQL(data: GraphiQLData): string {
}),
document.body
);
initSubscriptions();
</script>
</body>
</html>`;
Expand Down

0 comments on commit c4fabe3

Please sign in to comment.