The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
---
# this is an empty front matter
---
{% include header.html %}
<h2>REST</h2>
<p>
 ClearPress supports working in a RESTful fashion. That is to say
 there is a very systematic naming scheme for addressing entities and
 supporting the operations usually required:

 <ul>
  <li>create</li>
  <li>read</li>
  <li>update</li>
  <li>delete</li>
  <li>list</li>
  <li>add</li>
  <li>edit</li>
 </ul>
</p>

<p>
 The URL scheme looks something like this:

 <dl>
  <dt>Create</dt>
  <dd><code>POST to http://server/application/entity</code></dd>

  <dt>Read</dt>
  <dd><code>GET from http://server/application/entity/id</code></dd>

  <dt>Update</dt>
  <dd><code>POST to http://server/application/entity/id</code></dd>

  <dt>Delete</dt>
  <dd><code>POST to http://server/application/entity/id;delete</code></dd>

  <dt>Entity list</dt>
  <dd><code>GET http://server/application/entity/</code></dd>

  <dt>Add entity form</dt>
  <dd><code>GET http://server/application/entity/id;add</code></dd>

  <dt>Edit entity</dt>
  <dd><code>GET http://server/application/entity/id;edit</code></dd>
 </dl>
</p>

<p>
 On the whole this is fine - default responses are in text/html and
 that's great. Occasionally we want to use XML or JSON representations
 - simple!

 <dl>
  <dt>Entity list in XML</dt>
  <dd><code>GET http://server/application/entity.xml</code></dd>

  <dt>Entity in JSON</dt>
  <dd><code>GET http://server/application/entity/id.js</code></dd>

  <dt>Entity image</dt>
  <dd><code>GET http://server/application/entity/id.png</code></dd>
 </dl>

 Of course these do require a little work behind the scenes, like
 writing templates to support JSON or XML responses, or adjusting a
 view to return PNG images, but most of the annoying stuff should be
 taken care of for you.
</p>
{% include footer.html %}