2013-02-06 03:16:51 +08:00
|
|
|
class Draft < ActiveRecord::Base
|
|
|
|
NEW_TOPIC = 'new_topic'
|
|
|
|
NEW_PRIVATE_MESSAGE = 'new_private_message'
|
|
|
|
EXISTING_TOPIC = 'topic_'
|
|
|
|
|
|
|
|
def self.set(user, key, sequence, data)
|
|
|
|
d = find_draft(user,key)
|
|
|
|
if d
|
|
|
|
return if d.sequence > sequence
|
2013-10-02 10:17:27 +08:00
|
|
|
d.update_columns(data: data, sequence: sequence)
|
2013-02-06 03:16:51 +08:00
|
|
|
else
|
2013-10-02 10:17:27 +08:00
|
|
|
Draft.create!(user_id: user.id, draft_key: key, data: data, sequence: sequence)
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.get(user, key, sequence)
|
|
|
|
d = find_draft(user,key)
|
2013-02-07 23:45:24 +08:00
|
|
|
if d && d.sequence == sequence
|
2013-02-06 03:16:51 +08:00
|
|
|
d.data
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.clear(user, key, sequence)
|
|
|
|
d = find_draft(user,key)
|
|
|
|
if d && d.sequence <= sequence
|
|
|
|
d.destroy
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-03-26 06:56:21 +08:00
|
|
|
def self.find_draft(user, key)
|
|
|
|
if user.is_a?(User)
|
|
|
|
find_by(user_id: user.id, draft_key: key)
|
|
|
|
else
|
|
|
|
find_by(user_id: user, draft_key: key)
|
|
|
|
end
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
2015-06-02 11:45:47 +08:00
|
|
|
|
|
|
|
def self.cleanup!
|
|
|
|
exec_sql("DELETE FROM drafts where sequence < (
|
|
|
|
SELECT max(s.sequence) from draft_sequences s
|
|
|
|
WHERE s.draft_key = drafts.draft_key AND
|
|
|
|
s.user_id = drafts.user_id
|
|
|
|
)")
|
2015-06-03 16:52:41 +08:00
|
|
|
|
|
|
|
# remove old drafts
|
|
|
|
delete_drafts_older_than_n_days = SiteSetting.delete_drafts_older_than_n_days.days.ago
|
|
|
|
Draft.where("updated_at < ?", delete_drafts_older_than_n_days).destroy_all
|
2015-06-02 11:45:47 +08:00
|
|
|
end
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
2013-05-24 10:48:32 +08:00
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: drafts
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# user_id :integer not null
|
|
|
|
# draft_key :string(255) not null
|
|
|
|
# data :text not null
|
2014-08-27 13:19:25 +08:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2013-05-24 10:48:32 +08:00
|
|
|
# sequence :integer default(0), not null
|
|
|
|
#
|
|
|
|
# Indexes
|
|
|
|
#
|
|
|
|
# index_drafts_on_user_id_and_draft_key (user_id,draft_key)
|
|
|
|
#
|