Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codecommission/subscriptions-transport-sse
A Server-Side-Events (SSE) client + server for GraphQL subscriptions
https://github.com/codecommission/subscriptions-transport-sse
apollo client graphql server server-side-events subscriptions transport
Last synced: 3 months ago
JSON representation
A Server-Side-Events (SSE) client + server for GraphQL subscriptions
- Host: GitHub
- URL: https://github.com/codecommission/subscriptions-transport-sse
- Owner: CodeCommission
- License: mit
- Created: 2017-04-26T12:14:34.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-06-22T08:33:25.000Z (over 6 years ago)
- Last Synced: 2024-10-12T19:43:44.357Z (3 months ago)
- Topics: apollo, client, graphql, server, server-side-events, subscriptions, transport
- Language: JavaScript
- Homepage: https://github.com/MikeBild/graphql-subscriptions-sse-presence-list
- Size: 109 KB
- Stars: 66
- Watchers: 5
- Forks: 9
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# subscriptions-transport-sse
A GraphQL Server-Side-Events (SSE) server and client to facilitate GraphQL subscriptions.
> That's an API compatible SSE transport implementation of [subscriptions-transport-ws](https://github.com/apollographql/subscriptions-transport-ws).
## Example
* [GraphQL subscriptions over Server-Side-Events](https://github.com/MikeBild/graphql-subscriptions-sse-presence-list)
## Getting Started
```bash
Using Yarn:
$ yarn add subscriptions-transport-sseOr, using NPM:
$ npm install --save subscriptions-transport-sse
```### ExpressJS Server
Starting with the server, create a new simple SubscriptionsManager, with a PubSub implementation:
```javascript
import { SubscriptionManager, PubSub } from 'graphql-subscriptions'const schema = {} // Replace with your GraphQL schema object
const pubsub = new PubSub()const subscriptionManager = new SubscriptionManager({
schema,
pubsub
})
```Now, use your subscriptionManager, and create your SubscriptionServer:
```javascript
const express = require('express')
const app = express()
const expressGraphQLSubscriptionsSSETransport = require('subscriptions-transport-sse')expressGraphQLSubscriptionsSSETransport.SubscriptionServer({
onSubscribe: (msg, params) => Object.assign({}, params, { context: { loaders: loaders(), } }),
subscriptionManager: graphqlSubscriptions.subscriptionManager,
}, {
express: app,
path: '/subscriptions',
})app.listen(SERVICE_PORT, () => console.log(`Listen on ${SERVICE_PORT}`))
```### Apollo Client (Browser)
For client side, we will use SubscriptionClient, and we also need to extend our network interface to use this transport for GraphQL subscriptions:
```javascript
import { SubscriptionClient, addGraphQLSubscriptions } from 'subscriptions-transport-sse'
const httpClient = createNetworkInterface({uri: `https://my-graphql.example.com/graphql`})
const sseClient = new SubscriptionClient(`https://my-graphql.example.com/subscriptions`)
const apolloClient = new ApolloClient({networkInterface: addGraphQLSubscriptions(httpClient, sseClient)})
```Now, when you want to use subscriptions in client side, use your ApolloClient instance, with subscribe or subscribeToMore (according to your apollo-client usage):
```javascript
apolloClient.subscribeToMore({
document: gql`
subscription onNewItem {
newItemCreated {
id
}
}`,
variables: {},
updateQuery: (prev, {subscriptionData}) => {
return; // Modify your store and return new state with the new arrived data
}
});
```## API
> TBD, but compatible with [subscriptions-transport-ws](https://github.com/apollographql/subscriptions-transport-ws).
## Issue Reporting
If you have found a bug or if you have a feature request, please report them at this repository issues section. Please do not report security vulnerabilities on the public [GitHub issue tracker](https://github.com/MikeBild/subscriptions-transport-sse/issues).
## License
This project is licensed under the MIT license. See the [LICENSE](LICENSE) file for more info.
## Thanks
You like this __subscriptions-transport-sse__ and you want to see what coming next? Follow me on Twitter [`@mikebild`](https://twitter.com/mikebild).
Enjoy!