]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/user.rb
Merge pull request #3104 from fredrik-lindseth/patch-1
[rails.git] / app / models / user.rb
index 42fa40e538da528c8149c8bedcfa6f7504adab2a..26a9f33e153bf04c92d81335577bf37ded97bd27 100644 (file)
@@ -296,6 +296,15 @@ class User < ApplicationRecord
     digest.hexdigest
   end
 
+  def max_messages_per_hour
+    account_age_in_seconds = Time.now.utc - creation_time
+    account_age_in_hours = account_age_in_seconds / 3600
+    recent_messages = messages.where("sent_on >= ?", Time.now.utc - 3600).count
+    active_reports = issues.with_status(:open).sum(:reports_count)
+    max_messages = account_age_in_hours.ceil + recent_messages - active_reports * 10
+    max_messages.clamp(0, Settings.max_messages_per_hour)
+  end
+
   private
 
   def set_defaults