Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/contentful-labs/gazette
Contentful Gazette: bidirectional real-time content management and delivery
https://github.com/contentful-labs/gazette
browserify contentful pubnub react webhooks
Last synced: 3 months ago
JSON representation
Contentful Gazette: bidirectional real-time content management and delivery
- Host: GitHub
- URL: https://github.com/contentful-labs/gazette
- Owner: contentful-labs
- Created: 2017-02-23T13:11:57.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-03-25T15:41:19.000Z (almost 8 years ago)
- Last Synced: 2024-10-01T03:24:13.372Z (4 months ago)
- Topics: browserify, contentful, pubnub, react, webhooks
- Language: JavaScript
- Homepage: https://contentful-labs.github.io/gazette/
- Size: 1.95 MB
- Stars: 16
- Watchers: 29
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Contentful Gazette
*bidirectional real-time content management and delivery*
![Demo](./demo.gif)
## Disclaimers
This application was produced during a hackathon. It's a quick Proof of Concept created in 8h. It's not ready to be used in production.
### Known shortcomings
- there's no [server side rendering](https://facebook.github.io/react/docs/react-dom-server.html). It won't work without JavaScript enabled and load times will most likely suffer
- entry changes are populated with the real-time sync faster than they end up in the CDA. A page refreshed right after syncing may still show the previous version. To mitigate this problem we could use `localStorage` to cache versions received with the sync channel
- failed update are not reverted from the state of the app. You can provide a value that won't pass validations and will be rejected by the CMA, but it'll stay as is in the front-end### Security
**Never ever give your CMA token away to applications you don't trust**. Contentful Gazette will store your CMA token in-memory only until the browser tab is closed. You can verify what we do with your token by studying the code of [src/contentful.js](./src/contentful.js).
## Setting up your own Gazette
### Prepare content
1. create a new space in [Contentful](https://www.contentful.com)
2. create a content type with ID `article` consisting of 3 fields: `title`, `lead`, `content` (see below)
3. create a Content Delivery API key (or use the default one)
4. write some articles :)### Run it locally and on GitHub Pages
1. update [src/config.json](./src/config.json) with your space ID and the CDA key
2. install dependencies with `npm install`
3. start dev server by running `npm run build-dev`
4. push it to GitHub Pages using `npm run deploy-gh`### Get live updates
1. create a [PubNub](https://www.pubnub.com/) application with a key set
2. for your space create a webhook for entry publication events calling PubNub (see below)
3. update [src/config.json](./src/config.json) with your PubNub subscribe key### Write changes from Gazette back to Contentful
1. click on the `edit this website` ribbon on the top left corner of gazette and paste your Content Management API token
2. click in any of the textfields and change a value
3. open gazette in a different tab or look at the entries in the Contentful web app to see you changes get synchronized### Appendix: content type
![Content type](./ct.png)
```js
{
"name": "article",
"description": "Contentful Gazette article",
"displayField": "title",
"fields": [
{
"name": "title",
"id": "title",
"type": "Symbol",
"localized": false,
"required": false,
"disabled": false,
"omitted": false,
"validations": []
},
{
"name": "lead",
"id": "lead",
"type": "Symbol",
"localized": false,
"required": false,
"disabled": false,
"omitted": false,
"validations": []
},
{
"name": "content",
"id": "content",
"type": "Text",
"localized": false,
"required": false,
"disabled": false,
"omitted": false,
"validations": []
}
],
"sys": {/* redacted */}
}
```### Appendix: webhook
First you have to compose your publish URL. Refer the [PubNub documentation](https://www.pubnub.com/docs/pubnub-rest-api-documentation#publish-subscribe-publish-v1-via-post-post):
```
https://pubsub.pubnub.com/publish/{pub_key}/{sub_key}/0/articles/0?store=1
```Then this URL should be used for as a [Contentful webhook](https://www.contentful.com/developers/docs/concepts/webhooks/). Please note it should be triggerd only on entry publication.
![Webhook](./webhook.png)
## Authors
This project won the 2017 Winter Hackathon at Contentful.
Contributors:
- [andrefs](https://github.com/andrefs) (code)
- [hlabas](https://github.com/hlabas) (product ownership)
- [jelz](https://github.com/jelz) (code)
- [joaoramos](https://github.com/joaoramos) (visuals)
- [TimBeyer](https://github.com/TimBeyer) (code)