couchrest_model/lib/couchrest/model/designs.rb

82 lines
1.9 KiB
Ruby
Raw Normal View History

2011-02-05 22:22:07 +01:00
#### NOTE Work in progress! Not yet used!
module CouchRest
module Model
# A design block in CouchRest Model groups together the functionality of CouchDB's
# design documents in a simple block definition.
#
# class Person < CouchRest::Model::Base
# property :name
# timestamps!
#
# design do
# view :by_name
# end
# end
#
module Designs
2011-02-05 22:22:07 +01:00
extend ActiveSupport::Concern
module ClassMethods
# Add views and other design document features
# to the current model.
2011-02-05 22:22:07 +01:00
def design(*args, &block)
mapper = DesignMapper.new(self)
mapper.create_view_method(:all)
2011-02-05 22:22:07 +01:00
mapper.instance_eval(&block)
2011-02-06 20:02:44 +01:00
req_design_doc_refresh
2011-02-05 22:22:07 +01:00
end
# Override the default page pagination value:
#
# class Person < CouchRest::Model::Base
# paginates_per 10
# end
#
def paginates_per(val)
@_default_per_page = val
end
# The models number of documents to return
# by default when performing pagination.
# Returns 25 unless explicitly overridden via <tt>paginates_per</tt>
def default_per_page
@_default_per_page || 25
end
2011-02-05 22:22:07 +01:00
end
#
class DesignMapper
2011-02-05 22:22:07 +01:00
attr_accessor :model
2011-02-05 22:22:07 +01:00
def initialize(model)
self.model = model
end
2011-02-05 22:22:07 +01:00
# Define a view and generate a method that will provide a new
# View instance when requested.
def view(name, opts = {})
View.create(model, name, opts)
create_view_method(name)
end
def create_view_method(name)
model.class_eval <<-EOS, __FILE__, __LINE__ + 1
def self.#{name}(opts = {})
CouchRest::Model::Designs::View.new(self, opts, '#{name}')
end
EOS
2011-02-05 22:22:07 +01:00
end
end
end
end
end