This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (
This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (
commit 170e61f0f1f1ead05aacf04c903660f21472452f
tree b41e5b22c813a0d73bc78c1494f4d005b9cc5495
parent ee53792a25b7e76f9c0c317e00092cf5096add40
tree b41e5b22c813a0d73bc78c1494f4d005b9cc5495
parent ee53792a25b7e76f9c0c317e00092cf5096add40
| name | age | message | |
|---|---|---|---|
| |
README | Thu May 29 12:46:46 -0700 2008 | |
| |
TODO | ||
| |
couchrest.rb | ||
| |
examples/ | ||
| |
lib/ | ||
| |
script/ | ||
| |
spec/ | ||
| |
vendor/ | ||
| |
views/ | ||
| |
website/ | Wed Mar 19 22:38:01 -0700 2008 |
README
Couchrest is a loose port of the couch.js library from CouchDB’s Futon admin interface, which I find to be concise, cl
ear, and well designed.
I prefer to stay close to the metal, especially when the metal is as clean and simple as CouchDB’s HTTP API. The main th
ing Couchrest does for you is manage the Ruby <=> JSON serialization, and point your actions (database creation,
document CRUD, view creation and queries, etc) at the appropriate API endpoints.
The core of Couchrest is Heroku’s excellent REST Client Ruby HTTP wrapper. REST Client takes all the nastyness of Ne
t::HTTP and gives is a pretty face, while still giving you more control than Open-URI. I recommend it anytime you’re in
terfacing with a well-defined API. (We use it for Grabb.it’s Tumblr integration, and it works like a charm.)
The most complete source of documentation are the spec files. To ensure that your environment is setup for successful
CouchRest operation, from the project root directory run `autotest` or `spec spec` (requires RSpec and optionally
ZenTest for autotest support).
Quick Start:
@cr = CouchRest.new("http://localhost:5984")
@db = @cr.create_db('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"]}
])
puts @db.documents.inspect # returns ids and revs of the current docs
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








