This example demonstrates a simple Atom server that partially conforms to the Atom Publishing Format and Protocol.
Atom Entries, Atom Media Link Entries, and media are persisted to the file system. The ROME Java library provides support for the parsing and serializing of Atom Feed and Entry documents.
The example consists of four web resources implemented by the following:
com.sun.jersey.samples.atomserver.resources.ServiceResourcecom.sun.jersey.samples.atomserver.resources.FeedResourcecom.sun.jersey.samples.atomserver.resources.EntryResourcecom.sun.jersey.samples.atomserver.resources.EditEntryResourceThe mapping of the URI path space is presented in the following table:
| URI path | Resource class | HTTP methods | 
|---|---|---|
| /service | ServiceResource | GET | 
| /collection/ | FeedResource | GET, POST | 
| /collection/{entry} | EntryResource | GET | 
| /collection/{entry}/media | EntryResource | GET | 
| /collection/edit/{entry} | EditEntryResource | PUT, DELETE | 
| /collection/edit/{entry}/media | EditEntryResource | PUT | 
The Atom Feed/Entries and media are persisted to a file system. The structure of the file system is as follows:
collectioncollection/feed.xmlcollection/<uuid>/entry.xmlatom:id of the Atom Entry.collection/<uuid>/mediaTo remove the Atom Feed document and all the Atom (or Atom Media Link)
    Entries delete the collection directory.
Run the example as follows:
mvn clean compile exec:java
This deploys the Atom server using Grizzly
A WADL description may be accessed at the URL:
http://localhost:9998/atom/application.wadlFollowing steps are using cURL command line tool:
Get the service document:
curl http://127.0.0.1:9998/atom/service
This returns the following sevice document:
<service xmlns="http://purl.org/atom/app#"
        xmlns:atom="http://www.w3.org/2005/Atom">
    <workspace>
        <atom:title>Service</atom:title>
        <collection href="http://localhost:9998/atom/collection">
            <atom:title>Entries</atom:title>
            <categories>
                <atom:category term="storage" scheme="urn:storage" label="storage" />
            </categories>
        </collection>
    </workspace>
</service>The service document contains one workspace with one collection.
Create a media link entry:
curl -i -X POST --data "Something is rotten in the state of Denmark" -HContent-type:text/plain http://127.0.0.1:9998/atom/collection
Get the Atom Feed document:
curl http://127.0.0.1:9998/atom/collection
which returns the following:
    <?xml version="1.0" encoding="UTF-8"?>
    <feed xmlns="http://www.w3.org/2005/Atom" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/">
      <title>Feed</title>
      <link rel="self" href="http://127.0.0.1:9998/atom/collection" />
      <entry>
        <title>Media Entry</title>
        <link rel="self" href="http://127.0.0.1:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd" />
        <link rel="edit" href="http://127.0.0.1:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd" />
        <link rel="edit-media" href="http://127.0.0.1:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media" />
        <id>bdac4727-cbc3-4c37-ad1e-206672bc48dd</id>
        <updated>2011-03-23T05:51:28Z</updated>
        <content type="TEXT" src="http://127.0.0.1:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media" />
      </entry>
    </feed>
The Atom Feed document contains one Atom Media Link Entry. The
    atom:content contains a link to the media. (Note that the UUIDs
    and hence the URIs will be different than those shown in this example. Substitute the UUID
    in the example for the one returned rather than copying and
    pasting these commands directly.)
    The Atom Entry document, which will be the same as the entry
    element in the Atom Feed document, can be retrived from the URI of the
    link element with the self or edit value
    for the rel attribute. The id element contains the
    unique ID of the entry, which is a UUID.
Get the media:
curl http://127.0.0.1:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media
which returns:
Something is rotten in the state of Denmark
Updating the media:
curl -X PUT --data "Hamlet said: Something is rotten in the state of Denmark" -HContent-type:text/plain http://127.0.0.1:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media
The entry now has an updated time when the entry is retrieved:
curl http://127.0.0.1:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd
which returns:
<entry xmlns="http://www.w3.org/2005/Atom"> <title>Media Entry</title> <link rel="self" href="http://localhost:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd" /> <link rel="edit-media" href="http://localhost:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media" /> <link rel="edit" href="http://localhost:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd/" /> <id>bdac4727-cbc3-4c37-ad1e-206672bc48dd</id> <updated>2011-03-23T06:12:46Z</updated> <content type="TEXT" src="http://localhost:9998/atom/collection/bdac4727-cbc3-4c37-ad1e-206672bc48dd/media" /> </entry>
Delete the Atom Entry:
curl -X DELETE http://localhost:9998/atom/collection/edit/bdac4727-cbc3-4c37-ad1e-206672bc48dd
The edit link is used to delete the entry. Retrieving
    the Atom Feed document:
curl http://localhost:9998/atom/collection
returns a feed with no entries:
<?xml version="1.0" encoding="UTF-8"?> <feed xmlns="http://www.w3.org/2005/Atom" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/"> <title>Feed</title> <link rel="self" href="http://localhost:9998/atom/collection" /> </feed>