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

J
Jon Leighton 已提交
8 9
  scope :containing_the_letter_a, -> { where("body LIKE '%a%'") }
  scope :ranked_by_comments,      -> { order("comments_count DESC") }
10

11
  scope :limit_by, lambda {|l| limit(l) }
12

13
  belongs_to :author do
14 15 16
    def greeting
      "hello"
    end
17
  end
18

19
  belongs_to :author_with_posts, :class_name => "Author", :foreign_key => :author_id, :include => :posts
20
  belongs_to :author_with_address, :class_name => "Author", :foreign_key => :author_id, :include => :author_address
21

22 23 24 25
  def first_comment
    super.body
  end
  has_one :first_comment, :class_name => 'Comment', :order => 'id ASC'
26 27
  has_one :last_comment, :class_name => 'Comment', :order => 'id desc'

J
Jon Leighton 已提交
28 29
  scope :with_special_comments, -> { joins(:comments).where(:comments => {:type => 'SpecialComment'}) }
  scope :with_very_special_comments, -> { joins(:comments).where(:comments => {:type => 'VerySpecialComment'}) }
J
Jon Leighton 已提交
30
  scope :with_post, ->(post_id) { joins(:comments).where(:comments => { :post_id => post_id }) }
31

32
  has_many   :comments do
33
    def find_most_recent
34
      scoped(:order => "id DESC").first
35
    end
A
Arun Agrawal 已提交
36 37 38 39

    def newest
      created.last
    end
40 41 42 43

    def the_association
      proxy_association
    end
44
  end
45

46
  has_many :author_favorites, :through => :author
47
  has_many :author_categorizations, :through => :author, :source => :categorizations
48
  has_many :author_addresses, :through => :author
49

50
  has_many :comments_with_interpolated_conditions, :class_name => 'Comment',
51
    :conditions => proc { ["#{"#{aliased_table_name}." rescue ""}body = ?", 'Thank you for the welcome'] }
52

53
  has_one  :very_special_comment
54
  has_one  :very_special_comment_with_post, :class_name => "VerySpecialComment", :include => :post
55
  has_many :special_comments
56
  has_many :nonexistant_comments, :class_name => 'Comment', :conditions => 'comments.id < 0'
J
Jon Leighton 已提交
57

58
  has_many :special_comments_ratings, :through => :special_comments, :source => :ratings
59
  has_many :special_comments_ratings_taggings, :through => :special_comments_ratings, :source => :taggings
60

61
  has_and_belongs_to_many :categories
62
  has_and_belongs_to_many :special_categories, :join_table => "categories_posts", :association_foreign_key => 'category_id'
63 64

  has_many :taggings, :as => :taggable
65
  has_many :tags, :through => :taggings do
66
    def add_joins_and_select
67 68
      scoped(:select => 'tags.*, authors.id as author_id',
        :joins => 'left outer join posts on taggings.taggable_id = posts.id left outer join authors on posts.author_id = authors.id').all
69 70
    end
  end
J
Jeremy Kemper 已提交
71

72 73 74 75
  has_many :interpolated_taggings, :class_name => 'Tagging', :as => :taggable, :conditions => proc { "1 = #{1}" }
  has_many :interpolated_tags, :through => :taggings
  has_many :interpolated_tags_2, :through => :interpolated_taggings, :source => :tag

76
  has_many :taggings_with_delete_all, :class_name => 'Tagging', :as => :taggable, :dependent => :delete_all
77 78 79 80
  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
81

J
Jon Leighton 已提交
82
  has_many :misc_tags, :through => :taggings, :source => :tag, :conditions => { :tags => { :name => 'Misc' } }
83
  has_many :funky_tags, :through => :taggings, :source => :tag
84
  has_many :super_tags, :through => :taggings
85
  has_many :tags_with_primary_key, :through => :taggings, :source => :tag_with_primary_key
86
  has_one :tagging, :as => :taggable
J
Jon Leighton 已提交
87

J
Jon Leighton 已提交
88 89
  has_many :first_taggings, :as => :taggable, :class_name => 'Tagging', :conditions => { :taggings => { :comment => 'first' } }
  has_many :first_blue_tags, :through => :first_taggings, :source => :tag, :conditions => { :tags => { :name => 'Blue' } }
90

J
Jon Leighton 已提交
91
  has_many :first_blue_tags_2, :through => :taggings, :source => :blue_tag, :conditions => { :taggings => { :comment => 'first' } }
92

93
  has_many :invalid_taggings, :as => :taggable, :class_name => "Tagging", :conditions => 'taggings.id < 0'
94
  has_many :invalid_tags, :through => :invalid_taggings, :source => :tag
95

96 97 98
  has_many :categorizations, :foreign_key => :category_id
  has_many :authors, :through => :categorizations

99 100 101 102 103 104 105 106 107
  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
108
  has_many :named_categories, :through => :standard_categorizations
109

110
  has_many :readers
111
  has_many :secure_readers
112
  has_many :readers_with_person, :include => :person, :class_name => "Reader"
113
  has_many :people, :through => :readers
114
  has_many :secure_people, :through => :secure_readers
115
  has_many :single_people, :through => :readers
116 117 118 119 120
  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) }
121 122
  has_many :skimmers, :class_name => 'Reader', :conditions => { :skimmer => true }
  has_many :impatient_people, :through => :skimmers, :source => :person
123

124
  def self.top(limit)
125
    ranked_by_comments.limit_by(limit)
126 127
  end

128 129 130
  def self.reset_log
    @log = []
  end
131

132 133 134 135
  def self.log(message=nil, side=nil, new_record=nil)
    return @log if message.nil?
    @log << [message, side, new_record]
  end
136

137 138 139
  def self.what_are_you
    'a post...'
  end
140 141
end

142
class SpecialPost < Post; end
143 144

class StiPost < Post
145
  self.abstract_class = true
146 147
  has_one :special_comment, :class_name => "SpecialComment"
end
148 149

class SubStiPost < StiPost
150
  self.table_name = Post.table_name
151
end
152

153 154 155 156 157
ActiveSupport::Deprecation.silence do
  class DeprecatedPostWithComment < ActiveRecord::Base
    self.table_name = 'posts'
    default_scope where("posts.comments_count > 0").order("posts.comments_count ASC")
  end
158
end
T
Tim Morgan 已提交
159 160 161 162 163

class PostForAuthor < ActiveRecord::Base
  self.table_name = 'posts'
  cattr_accessor :selected_author
end
164 165 166

class FirstPost < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
167
  default_scope { where(:id => 1) }
168

169 170 171
  has_many :comments, :foreign_key => :post_id
  has_one  :comment,  :foreign_key => :post_id
end
172 173 174

class PostWithDefaultInclude < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
175
  default_scope { includes(:comments) }
176
  has_many :comments, :foreign_key => :post_id
177 178 179 180
end

class PostWithDefaultScope < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
181
  default_scope { order(:title) }
182 183 184 185
end

class SpecialPostWithDefaultScope < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
186
  default_scope { where(:id => [1, 5,6]) }
187
end