post.rb 9.1 KB
Newer Older
1
class Post < ActiveRecord::Base
2 3 4 5 6 7
  class CategoryPost < ActiveRecord::Base
    self.table_name = "categories_posts"
    belongs_to :category
    belongs_to :post
  end

P
Pratik Naik 已提交
8 9 10 11 12 13
  module NamedExtension
    def author
      'lifo'
    end
  end

J
Jon Leighton 已提交
14 15 16 17 18 19
  module NamedExtension2
    def greeting
      "hello"
    end
  end

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

23
  scope :limit_by, lambda {|l| limit(l) }
24

25
  belongs_to :author
26

27 28
  belongs_to :author_with_posts, -> { includes(:posts) }, :class_name => "Author", :foreign_key => :author_id
  belongs_to :author_with_address, -> { includes(:author_address) }, :class_name => "Author", :foreign_key => :author_id
29

30 31 32
  def first_comment
    super.body
  end
33 34
  has_one :first_comment, -> { order('id ASC') }, :class_name => 'Comment'
  has_one :last_comment, -> { order('id desc') }, :class_name => 'Comment'
35

J
Jon Leighton 已提交
36 37
  scope :with_special_comments, -> { joins(:comments).where(:comments => {:type => 'SpecialComment'}) }
  scope :with_very_special_comments, -> { joins(:comments).where(:comments => {:type => 'VerySpecialComment'}) }
J
Jon Leighton 已提交
38
  scope :with_post, ->(post_id) { joins(:comments).where(:comments => { :post_id => post_id }) }
39

40 41 42
  scope :with_comments, -> { preload(:comments) }
  scope :with_tags, -> { preload(:taggings) }

43
  scope :tagged_with, ->(id) { joins(:taggings).where(taggings: { tag_id: id }) }
44
  scope :tagged_with_comment, ->(comment) { joins(:taggings).where(taggings: { comment: comment }) }
45

46
  has_many   :comments do
47
    def find_most_recent
48
      order("id DESC").first
49
    end
A
Arun Agrawal 已提交
50 51 52 53

    def newest
      created.last
    end
54 55 56 57

    def the_association
      proxy_association
    end
58
  end
59

J
Jon Leighton 已提交
60 61 62 63 64 65 66 67
  has_many :comments_with_extend, extend: NamedExtension, class_name: "Comment", foreign_key: "post_id" do
    def greeting
      "hello"
    end
  end

  has_many :comments_with_extend_2, extend: [NamedExtension, NamedExtension2], class_name: "Comment", foreign_key: "post_id"

68
  has_many :author_favorites, :through => :author
69
  has_many :author_categorizations, :through => :author, :source => :categorizations
70
  has_many :author_addresses, :through => :author
71 72 73
  has_many :author_address_extra_with_address,
    through: :author_with_address,
    source: :author_address_extra
74

75 76 77
  has_many :comments_with_interpolated_conditions,
    ->(p) { where "#{"#{p.aliased_table_name}." rescue ""}body = ?", 'Thank you for the welcome' },
    :class_name => 'Comment'
78

79
  has_one  :very_special_comment
80
  has_one  :very_special_comment_with_post, -> { includes(:post) }, :class_name => "VerySpecialComment"
81
  has_one :very_special_comment_with_post_with_joins, -> { joins(:post).order('posts.id') }, class_name: "VerySpecialComment"
82
  has_many :special_comments
M
Melissa Xie 已提交
83
  has_many :nonexistent_comments, -> { where 'comments.id < 0' }, :class_name => 'Comment'
J
Jon Leighton 已提交
84

85
  has_many :special_comments_ratings, :through => :special_comments, :source => :ratings
86
  has_many :special_comments_ratings_taggings, :through => :special_comments_ratings, :source => :taggings
87

88 89
  has_many :category_posts, :class_name => 'CategoryPost'
  has_many :scategories, through: :category_posts, source: :category
90
  has_and_belongs_to_many :categories
91
  has_and_belongs_to_many :special_categories, :join_table => "categories_posts", :association_foreign_key => 'category_id'
92

93
  has_many :taggings, :as => :taggable, :counter_cache => :tags_count
94
  has_many :tags, :through => :taggings do
95
    def add_joins_and_select
96 97 98
      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')
        .to_a
99 100
    end
  end
J
Jeremy Kemper 已提交
101

102
  has_many :taggings_with_delete_all, :class_name => 'Tagging', :as => :taggable, :dependent => :delete_all
103 104 105 106
  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
107

108
  has_many :misc_tags, -> { where :tags => { :name => 'Misc' } }, :through => :taggings, :source => :tag
109
  has_many :funky_tags, :through => :taggings, :source => :tag
110
  has_many :super_tags, :through => :taggings
111
  has_many :tags_with_primary_key, :through => :taggings, :source => :tag_with_primary_key
112
  has_one :tagging, :as => :taggable
J
Jon Leighton 已提交
113

114 115
  has_many :first_taggings, -> { where :taggings => { :comment => 'first' } }, :as => :taggable, :class_name => 'Tagging'
  has_many :first_blue_tags, -> { where :tags => { :name => 'Blue' } }, :through => :first_taggings, :source => :tag
116

117
  has_many :first_blue_tags_2, -> { where :taggings => { :comment => 'first' } }, :through => :taggings, :source => :blue_tag
118

119
  has_many :invalid_taggings, -> { where 'taggings.id < 0' }, :as => :taggable, :class_name => "Tagging"
120
  has_many :invalid_tags, :through => :invalid_taggings, :source => :tag
121

122 123 124
  has_many :categorizations, :foreign_key => :category_id
  has_many :authors, :through => :categorizations

125 126 127 128 129 130 131 132 133
  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
134
  has_many :named_categories, :through => :standard_categorizations
135

136
  has_many :readers
137
  has_many :secure_readers
138
  has_many :readers_with_person, -> { includes(:person) }, :class_name => "Reader"
139
  has_many :people, :through => :readers
140
  has_many :single_people, :through => :readers
141 142 143 144 145
  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) }
146
  has_many :skimmers, -> { where :skimmer => true }, :class_name => 'Reader'
147
  has_many :impatient_people, :through => :skimmers, :source => :person
148

149 150 151
  has_many :lazy_readers
  has_many :lazy_readers_skimmers_or_not, -> { where(skimmer: [ true, false ]) }, :class_name => 'LazyReader'

152 153 154
  has_many :lazy_people, :through => :lazy_readers, :source => :person
  has_many :lazy_readers_unscope_skimmers, -> { skimmers_or_not }, :class_name => 'LazyReader'
  has_many :lazy_people_unscope_skimmers, :through => :lazy_readers_unscope_skimmers, :source => :person
155

156
  def self.top(limit)
157
    ranked_by_comments.limit_by(limit)
158 159
  end

160 161 162 163
  def self.written_by(author)
    where(id: author.posts.pluck(:id))
  end

164 165 166
  def self.reset_log
    @log = []
  end
167

168 169 170 171
  def self.log(message=nil, side=nil, new_record=nil)
    return @log if message.nil?
    @log << [message, side, new_record]
  end
172 173
end

174
class SpecialPost < Post; end
175 176

class StiPost < Post
177
  self.abstract_class = true
178 179
  has_one :special_comment, :class_name => "SpecialComment"
end
180 181

class SubStiPost < StiPost
182
  self.table_name = Post.table_name
183
end
184

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

189 190 191
  has_many :comments, :foreign_key => :post_id
  has_one  :comment,  :foreign_key => :post_id
end
192 193 194

class PostWithDefaultInclude < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
195
  default_scope { includes(:comments) }
196
  has_many :comments, :foreign_key => :post_id
197 198
end

199 200 201 202 203
class PostWithSpecialCategorization < Post
  has_many :categorizations, :foreign_key => :post_id
  default_scope { where(:type => 'PostWithSpecialCategorization').joins(:categorizations).where(:categorizations => { :special => true }) }
end

204 205
class PostWithDefaultScope < ActiveRecord::Base
  self.table_name = 'posts'
J
Jon Leighton 已提交
206
  default_scope { order(:title) }
207 208 209 210
end

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

class PostThatLoadsCommentsInAnAfterSaveHook < ActiveRecord::Base
  self.table_name = 'posts'
  has_many :comments, class_name: "CommentThatAutomaticallyAltersPostBody", foreign_key: :post_id
217

218 219 220 221
  after_save do |post|
    post.comments.load
  end
end
222

223 224 225 226 227 228 229 230 231
class PostWithAfterCreateCallback < ActiveRecord::Base
  self.table_name = 'posts'
  has_many :comments, foreign_key: :post_id

  after_create do |post|
    update_attribute(:author_id, comments.first.id)
  end
end

232 233 234 235 236
class PostWithCommentWithDefaultScopeReferencesAssociation < ActiveRecord::Base
  self.table_name = 'posts'
  has_many :comment_with_default_scope_references_associations, foreign_key: :post_id
  has_one :first_comment, class_name: "CommentWithDefaultScopeReferencesAssociation", foreign_key: :post_id
end
237 238 239 240

class SerializedPost < ActiveRecord::Base
  serialize :title
end