Rails良薬のKeeping Track of Who Did What


今日は、データベースにユーザー操作を記録する方法について説明します.
db/migrate/002_add_audit_trails_table.rb

class AddAuditTrailsTable < ActiveRecord::Migration
  def self.up
    create_table :audit_trails do |t|
      t.column :record_id, :integer
      t.column :record_type, :string
      t.column :event, :string
      t.column :user_id, :integer
      t.column :created_at, :datetime
    end
  end

  def self.down
    drop_table :audit_trails
  end
end

app/models/audit_swpeeper.rb

class AuditSweeper < ActionController::Caching::Sweeper
  observe Person
  def after_destroy(record)
    log(record, "DESTROY")
  end

  def after_update(record)
    log(record, "UPDATE")
  end

  def after_create(record)
    log(record, "CREATE")
  end

  def log(record, event, user = controller.session[:user])
    AuditTrail.create(:record_id => record.id,
                      :record_type => record.type.name,
                      :event => event,
                      :user_id => user)
  end
end

次にPeopleControllerがPersonオブジェクトを操作するときにaudit_を使用することを伝える必要があります.操作を記録するためにsweeper
app/controllers/people_controller.rb

cache_sweeper :audit_sweeper

auditingメカニズムはRailsのキャッシュコードに依存するためconfig/environments/developmentを確保する.rbでconfig.action_controller.perform_cachingをtrueに設定
BTW:昨日書いたブログ「Processing Uploaded Images」はなぜか私のブログのトップページに表示されないのですが、searchで見つけることができます.カエルの目にはどうしてこのようなバカなバグが現れますか.