WebSub (formerly PubSubHubbub) is an open protocol for distributed publish–subscribe communication on the Internet.[1] Initially designed to extend the Atom (and RSS) protocols for data feeds, the protocol can be applied to any data type (e.g. HTML, text, pictures, audio, video) as long as it is accessible via HTTP. Its main purpose is to provide real-time notifications of changes, which improves upon the typical situation where a client periodically polls the feed server at some arbitrary interval. In this way, WebSub provides pushed HTTP notifications without requiring clients to spend resources on polling for changes.

In October 2017, PubSubHubbub was renamed to WebSub for simplicity and clarity.[2] As of January 2018, the WebSub protocol has been adopted by the W3C as a Recommendation.[3]

Protocol

edit

Under WebSub, there is an ecosystem of publishers, subscribers, and hubs.[4]

A subscriber first retrieves content from an HTTP resource (URL) by requesting it from the webserver. The subscriber then inspects the contents of the response, and if it references a hub, the subscriber can subscribe to that resource's URL (it's called a 'topic' by the spec) on that hub. The subscriber needs to run a web accessible server so that hubs can directly notify it when any of its subscribed topics have updated, using a webhook mechanism.

Publishers expose their content with the inclusion of hub references in the HTTP headers. They post notifications to those referenced hubs whenever they publish something. Thus, when a publication event occurs, the publisher calls its hubs and the hubs call their subscribers.

WebSub includes a simple verification of intent mechanism in order to prevent abusive subscriptions, and a validation mechanism allows for subscriptions to private or protected web resources. When the subscriber sends the subscription request to the hub, the subscriber address and a code needs to be included. The hub immediately sends a verification message to the subscriber with the URL of the topic and the above code. The subscription request will only be accepted if the subscriber sends a positive response to the verification request of the hub.

In order to provide a secure chain, subscribers should share a secret with the hub, which will be used by the hub to compute an HMAC key that will be sent to the subscriber. The latter can then easily verify the origin by comparing the supplied signature with a similarly computed signature on their end.

Usage

edit

WebSub is used to push content by many websites, including all blogs served by Blogger and WordPress.com,[5] news sites including CNN and Fox News, and social networks like diaspora*, Mastodon, MySpace[6] or Medium.com.[7]

Subscribing services (“feed readers”) include Flipboard, Feedly, NewsBlur, among other popular options.[8]

Community Hosted hub providers include pubsubhubbub.appspot.com (operated by Google),[9] pubsubhubbub.superfeedr.com (operated by Superfeedr),[10] and websubhub.com.[11]

Superfeedr provides a detailed PubSubHubbub guide for implementation.[12]

See also

edit

References

edit
  1. ^ PubSubHubbub
  2. ^ "WebSub @ W3C".
  3. ^ "WebSub W3C Recommendation 23 January 2018".
  4. ^ "WebSub".
  5. ^ "Rub-a-Dub-Dub in the PubSubHubbub". The WordPress.com Blog. 3 March 2010. Retrieved 6 February 2018.
  6. ^ "Companies". pubsubhub - Google Code. Retrieved 2 September 2014.
  7. ^ "Superfeedr Blog - Medium supports PubSubHubbub". 18 February 2014. Retrieved 3 May 2015.
  8. ^ "State of PubSubHubbub". Superfeedr blog. 4 July 2013. Retrieved 2 September 2014.
  9. ^ Welcome to the Google PubSubHubbub Hub!
  10. ^ Superfeedr Open PubSubHubbub Hub
  11. ^ WebSubHub
  12. ^ Superfeedr Blog - How to implement PubSubHubbub, 10 February 2015