post.rb 5.5 KB
Newer Older
1
class Post < ActiveRecord::Base
P
Pratik Naik 已提交
2 3 4 5 6 7
  module NamedExtension
    def author
      'lifo'
    end
  end

P
Pratik Naik 已提交
8 9 10 11
  scope :containing_the_letter_a, where("body LIKE '%a%'")
  scope :ranked_by_comments, order("comments_count DESC")
  scope :limit_by, lambda {|l| limit(l) }
  scope :with_authors_at_address, lambda { |address| {
12 13 14 15 16
      :conditions => [ 'authors.author_address_id = ?', address.id ],
      :joins => 'JOIN authors ON authors.id = posts.author_id'
    }
  }

17
  belongs_to :author do
18 19 20
    def greeting
      "hello"
    end
21
  end
22

23
  belongs_to :author_with_posts, :class_name => "Author", :foreign_key => :author_id, :include => :posts
24
  belongs_to :author_with_address, :class_name => "Author", :foreign_key => :author_id, :include => :author_address
25

26 27
  has_one :last_comment, :class_name => 'Comment', :order => 'id desc'

P
Pratik Naik 已提交
28 29 30
  scope :with_special_comments, :joins => :comments, :conditions => {:comments => {:type => 'SpecialComment'} }
  scope :with_very_special_comments, joins(:comments).where(:comments => {:type => 'VerySpecialComment'})
  scope :with_post, lambda {|post_id|
31 32 33
    { :joins => :comments, :conditions => {:comments => {:post_id => post_id} } }
  }

34
  has_many   :comments do
35 36 37
    def find_most_recent
      find(:first, :order => "id DESC")
    end
38
  end
39

40
  has_many :author_favorites, :through => :author
41
  has_many :author_categorizations, :through => :author, :source => :categorizations
42
  has_many :author_addresses, :through => :author
43

44
  has_one  :very_special_comment
45
  has_one  :very_special_comment_with_post, :class_name => "VerySpecialComment", :include => :post
46
  has_many :special_comments
47
  has_many :nonexistant_comments, :class_name => 'Comment', :conditions => 'comments.id < 0'
48

49
  has_and_belongs_to_many :categories
50
  has_and_belongs_to_many :special_categories, :join_table => "categories_posts", :association_foreign_key => 'category_id'
51 52

  has_many :taggings, :as => :taggable
53
  has_many :tags, :through => :taggings do
54
    def add_joins_and_select
55
      find :all, :select => 'tags.*, authors.id as author_id',
56 57 58
        :joins => 'left outer join posts on taggings.taggable_id = posts.id left outer join authors on posts.author_id = authors.id'
    end
  end
J
Jeremy Kemper 已提交
59

60
  has_many :taggings_with_delete_all, :class_name => 'Tagging', :as => :taggable, :dependent => :delete_all
61 62 63 64
  has_many :taggings_with_destroy, :class_name => 'Tagging', :as => :taggable, :dependent => :destroy

  has_many :tags_with_destroy, :through => :taggings, :source => :tag, :dependent => :destroy
  has_many :tags_with_nullify, :through => :taggings, :source => :tag, :dependent => :nullify
65

66
  has_many :misc_tags, :through => :taggings, :source => :tag, :conditions => "tags.name = 'Misc'"
67
  has_many :funky_tags, :through => :taggings, :source => :tag
68
  has_many :super_tags, :through => :taggings
69 70
  has_one :tagging, :as => :taggable

71
  has_many :invalid_taggings, :as => :taggable, :class_name => "Tagging", :conditions => 'taggings.id < 0'
72
  has_many :invalid_tags, :through => :invalid_taggings, :source => :tag
73

74 75 76
  has_many :categorizations, :foreign_key => :category_id
  has_many :authors, :through => :categorizations

77 78 79 80 81 82 83 84 85 86
  has_many :categorizations_using_author_id, :primary_key => :author_id, :foreign_key => :post_id, :class_name => 'Categorization'
  has_many :authors_using_author_id, :through => :categorizations_using_author_id, :source => :author

  has_many :taggings_using_author_id, :primary_key => :author_id, :as => :taggable, :class_name => 'Tagging'
  has_many :tags_using_author_id, :through => :taggings_using_author_id, :source => :tag

  has_many :standard_categorizations, :class_name => 'Categorization', :foreign_key => :post_id
  has_many :author_using_custom_pk,  :through => :standard_categorizations
  has_many :authors_using_custom_pk, :through => :standard_categorizations

87
  has_many :readers
88
  has_many :readers_with_person, :include => :person, :class_name => "Reader"
89
  has_many :people, :through => :readers
90 91 92 93 94
  has_many :people_with_callbacks, :source=>:person, :through => :readers,
              :before_add    => lambda {|owner, reader| log(:added,   :before, reader.first_name) },
              :after_add     => lambda {|owner, reader| log(:added,   :after,  reader.first_name) },
              :before_remove => lambda {|owner, reader| log(:removed, :before, reader.first_name) },
              :after_remove  => lambda {|owner, reader| log(:removed, :after,  reader.first_name) }
95 96
  has_many :skimmers, :class_name => 'Reader', :conditions => { :skimmer => true }
  has_many :impatient_people, :through => :skimmers, :source => :person
97

98
  def self.top(limit)
99
    ranked_by_comments.limit_by(limit)
100 101
  end

102 103 104
  def self.reset_log
    @log = []
  end
105

106 107 108 109
  def self.log(message=nil, side=nil, new_record=nil)
    return @log if message.nil?
    @log << [message, side, new_record]
  end
110

111 112 113
  def self.what_are_you
    'a post...'
  end
114 115
end

116
class SpecialPost < Post; end
117 118

class StiPost < Post
119
  self.abstract_class = true
120 121
  has_one :special_comment, :class_name => "SpecialComment"
end
122 123

class SubStiPost < StiPost
124
  self.table_name = Post.table_name
125
end
126 127 128 129 130

class PostWithComment < ActiveRecord::Base
  self.table_name = 'posts'
  default_scope where("posts.comments_count > 0").order("posts.comments_count ASC")
end
T
Tim Morgan 已提交
131 132 133 134 135 136

class PostForAuthor < ActiveRecord::Base
  self.table_name = 'posts'
  cattr_accessor :selected_author
  default_scope lambda { where(:author_id => PostForAuthor.selected_author) }
end
137 138 139 140 141 142 143

class FirstPost < ActiveRecord::Base
  self.table_name = 'posts'
  default_scope where(:id => 1)
  has_many :comments, :foreign_key => :post_id
  has_one  :comment,  :foreign_key => :post_id
end