jchris / couchrest

A RESTful CouchDB client based on Heroku's RestClient and Couch.js - you want the version at http://github.com/couchrest/couchrest

This URL has Read+Write access

jchris (author)
Sat Nov 22 15:50:26 -0800 2008
commit  f6a1c58152e760ba19a36f909ff5a6fb6d42c96c
tree    2ac90ca296e8544c035c465c9eb333259141ade7
parent  2c63d91a81f557baa0f3e25e252cccc3da46957f parent  811ae735d73d046a445865ae52c74855de1b0992
name age message
file .gitignore Sun Oct 26 08:03:59 -0700 2008 added gem task for easy local packaging [Jeremy Burks]
file LICENSE Thu Sep 11 21:31:59 -0700 2008 added apache license [jchris]
file README.rdoc Thu Oct 02 10:57:13 -0700 2008 whitespace readme [jchris]
file Rakefile Loading commit data...
file THANKS Thu Sep 11 22:23:47 -0700 2008 updated gem version [jchris]
directory bin/
file couchrest.gemspec
directory examples/
directory lib/
directory spec/
directory utils/ Sun Aug 03 14:17:58 -0700 2008 created some utility scripts [jchris]
README.rdoc

CouchRest - CouchDB, close to the metal

CouchRest is based on [CouchDB’s couch.js test library](svn.apache.org/repos/asf/incubator/couchdb/trunk/share/www/script/couch.js), which I find to be concise, clear, and well designed. CouchRest lightly wraps CouchDB’s HTTP API, managing JSON serialization, and remembering the URI-paths to CouchDB’s API endpoints so you don’t have to.

CouchRest’s lighweight is designed to make a simple base for application and framework-specific object oriented APIs.

Easy Install

  sudo gem install jchris-couchrest -s http://gems.github.com

Relax, it’s RESTful

The core of Couchrest is Heroku’s excellent REST Client Ruby HTTP wrapper. REST Client takes all the nastyness of Net::HTTP and gives is a pretty face, while still giving you more control than Open-URI. I recommend it anytime you’re interfacing with a well-defined web service.

Running the Specs

The most complete documentation is the spec/ directory. To validate your CouchRest install, from the project root directory run `rake`, or `autotest` (requires RSpec and optionally ZenTest for autotest support).

Examples

Quick Start:

    # with !, it creates the database if it doesn't already exist
    @db = CouchRest.database!("http://localhost:5984/couchrest-test")
    response = @db.save({:key => 'value', 'another key' => 'another value'})
    doc = @db.get(response['id'])
    puts doc.inspect

Bulk Save:

    @db.bulk_save([
        {"wild" => "and random"},
        {"mild" => "yet local"},
        {"another" => ["set","of","keys"]}
      ])
    # returns ids and revs of the current docs
    puts @db.documents.inspect

Creating and Querying Views:

    @db.save({
      "_id" => "_design/first",
      :views => {
        :test => {
          :map => "function(doc){for(var w in doc){ if(!w.match(/^_/))emit(w,doc[w])}}"
          }
        }
      })
    puts @db.view('first/test')['rows'].inspect

CouchRest::Model

CouchRest::Model is a module designed along the lines of DataMapper::Resource. By subclassing, suddenly you get all sorts of powerful sugar, so that working with CouchDB in your Rails or Merb app is no harder than working with the standard SQL alternatives. See the CouchRest::Model documentation for an example article class that illustrates usage.