about summary refs log tree commit diff
path: root/app
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2016-10-02 15:33:24 +0200
committerEugen Rochko <eugen@zeonfederated.com>2016-10-02 15:33:24 +0200
commit2d4f9ecebf286aa9868f00373294c5e68b6f4b93 (patch)
treef73c3ad69f4315a1dcf106d0af35230a59260d1b /app
parentbe86d4e0a3c40e95648971bc9b0fe58c58cbc5da (diff)
Validate against multiple reblogs of same status by same account
Diffstat (limited to 'app')
-rw-r--r--app/models/status.rb1
1 files changed, 1 insertions, 0 deletions
diff --git a/app/models/status.rb b/app/models/status.rb
index 1f1a70946..7ff0487a3 100644
--- a/app/models/status.rb
+++ b/app/models/status.rb
@@ -16,6 +16,7 @@ class Status < ApplicationRecord
   validates :account, presence: true
   validates :uri, uniqueness: true, unless: 'local?'
   validates :text, presence: true, length: { maximum: 500 }, if: proc { |s| s.local? && !s.reblog? }
+  validates :reblog, uniqueness: { scope: :account, message: 'of status already exists' }, if: 'reblog?'
 
   scope :with_counters, -> { select('statuses.*, (select count(r.id) from statuses as r where r.reblog_of_id = statuses.id) as reblogs_count, (select count(f.id) from favourites as f where f.status_id = statuses.id) as favourites_count') }
   scope :with_includes, -> { includes(:account, :media_attachments, :stream_entry, mentions: :account, reblog: [:account, mentions: :account], thread: :account) }