ActiveModel is a class to be implemented by each ORM to allow Rails to generate customized controller code.
The API has the same methods as ActiveRecord, but each method returns a string that matches the ORM API.
For example:
ActiveRecord::Generators::ActiveModel.find(Foo, "params[:id]")
# => "Foo.find(params[:id])"
DataMapper::Generators::ActiveModel.find(Foo, "params[:id]")
# => "Foo.get(params[:id])"
On initialization, the ActiveModel accepts the instance name that will receive the calls:
builder = ActiveRecord::Generators::ActiveModel.new "@foo"
builder.save # => "@foo.save"
The only exception in ActiveModel for ActiveRecord is the use of self.build instead of self.new.
Attributes
| [R] | name |
Class Public methods
all(klass) Link
GET index
Source: show
# File railties/lib/rails/generators/active_model.rb, line 36 def self.all(klass) "#{klass}.all" end
build(klass, params = nil) Link
GET new POST create
Source: show
# File railties/lib/rails/generators/active_model.rb, line 50 def self.build(klass, params = nil) if params "#{klass}.new(#{params})" else "#{klass}.new" end end
find(klass, params = nil) Link
GET show GET edit PATCH/PUT update DELETE destroy
Source: show
# File railties/lib/rails/generators/active_model.rb, line 44 def self.find(klass, params = nil) "#{klass}.find(#{params})" end
new(name) Link
Source: show
# File railties/lib/rails/generators/active_model.rb, line 31 def initialize(name) @name = name end
Instance Public methods
destroy() Link
DELETE destroy
Source: show
# File railties/lib/rails/generators/active_model.rb, line 75 def destroy "#{name}.destroy!" end
errors() Link
POST create PATCH/PUT update
Source: show
# File railties/lib/rails/generators/active_model.rb, line 70 def errors "#{name}.errors" end