summaryrefslogtreecommitdiffstats
path: root/db/migrate/098_set_topic_authors_as_watchers.rb
blob: 5bc41fb38f6652fd8780a4153d54b12d39b61fe4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class SetTopicAuthorsAsWatchers < ActiveRecord::Migration
  def self.up
    # Sets active users who created/replied a topic as watchers of the topic
    # so that the new watch functionality at topic level doesn't affect notifications behaviour
    Message.connection.execute("INSERT INTO watchers (watchable_type, watchable_id, user_id)" +
                                 " SELECT DISTINCT 'Message', COALESCE(messages.parent_id, messages.id), messages.author_id FROM messages, users" +
                                 " WHERE messages.author_id = users.id AND users.status = 1")
  end

  def self.down
    # Removes all message watchers
    Watcher.delete_all("watchable_type = 'Message'")
  end
end