EventStoreDB provides a native interface of AtomPub over HTTP. AtomPub is a RESTful protocol that can reuse many existing components, for example reverse proxies and a client's native HTTP caching. Since events stored in EventStoreDB are immutable, cache expiration can be infinite. EventStoreDB leverages content type negotiation and you can access appropriately serialised events can as JSON or XML according to the request headers.
# Compatibility with AtomPub
EventStoreDB v5 is fully compatible with the 1.0 version of the Atom Protocol (opens new window). EventStoreDB adds extensions to the protocol, such as headers for control and custom
The latest versions of EventStoreDB (v20+) have the AtomPub protocol disabled by default. We do not advise creating new applications using AtomPub as we plan to deprecate it. Please explore our new gRPC protocol available in v20. It provides more reliable real-time event streaming with wide range of platforms and language supported.
# Existing implementations
Many environments have already implemented the AtomPub protocol, which simplifies the process.
|JVM||http://java-source.net/open-source/rss-rdf-tools (opens new window)|
|PHP||http://simplepie.org/ (opens new window) or https://github.com/fguillot/picoFeed (opens new window)|
|Ruby||https://github.com/cardmagic/simple-rss (opens new window)|
|Clojure||https://github.com/scsibug/feedparser-clj (opens new window)|
|Go||https://github.com/jteeuwen/go-pkg-rss (opens new window)|
|Python||http://code.google.com/p/feedparser/ (opens new window)|
|node.js||https://github.com/danmactough/node-feedparser (opens new window)|
|Objective-C||https://geekli.st/darvin/repos/MWFeedParser (opens new window)|
These are not officially supported by EventStoreDB.
# Content types
The preferred way of determining which content type responses EventStoreDB serves is to set the
Accept header on the request. As some clients do not deal well with HTTP headers when caching, appending a format parameter to the URL is also supported, for example,
The accepted content types for POST requests are:
The accepted content types for GET requests are: