summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
Diffstat (limited to 'app')
-rw-r--r--app/models/concerns/subscribable.rb21
-rw-r--r--app/models/subscription.rb6
2 files changed, 17 insertions, 10 deletions
diff --git a/app/models/concerns/subscribable.rb b/app/models/concerns/subscribable.rb
index 5f2725a6d7f..0723db548d8 100644
--- a/app/models/concerns/subscribable.rb
+++ b/app/models/concerns/subscribable.rb
@@ -12,7 +12,7 @@ module Subscribable
has_many :subscriptions, dependent: :destroy, as: :subscribable
end
- def subscribed?(user, project)
+ def subscribed?(user, project = nil)
if subscription = subscriptions.find_by(user: user, project: project)
subscription.subscribed
else
@@ -27,20 +27,22 @@ module Subscribable
end
def subscribers(project)
- subscriptions.where(project: project, subscribed: true).map(&:user)
+ subscriptions_available(project).
+ where(subscribed: true).
+ map(&:user)
end
- def toggle_subscription(user, project)
+ def toggle_subscription(user, project = nil)
find_or_initialize_subscription(user, project).
update(subscribed: !subscribed?(user, project))
end
- def subscribe(user, project)
+ def subscribe(user, project = nil)
find_or_initialize_subscription(user, project).
update(subscribed: true)
end
- def unsubscribe(user, project)
+ def unsubscribe(user, project = nil)
find_or_initialize_subscription(user, project).
update(subscribed: false)
end
@@ -49,6 +51,13 @@ module Subscribable
def find_or_initialize_subscription(user, project)
subscriptions.
- find_or_initialize_by(user_id: user.id, project_id: project.id)
+ find_or_initialize_by(user_id: user.id, project_id: project.try(:id))
+ end
+
+ def subscriptions_available(project)
+ t = Subscription.arel_table
+
+ subscriptions.
+ where(t[:project_id].eq(nil).or(t[:project_id].eq(project.try(:id))))
end
end
diff --git a/app/models/subscription.rb b/app/models/subscription.rb
index f881d999384..17869c8bac2 100644
--- a/app/models/subscription.rb
+++ b/app/models/subscription.rb
@@ -3,9 +3,7 @@ class Subscription < ActiveRecord::Base
belongs_to :project
belongs_to :subscribable, polymorphic: true
- validates :user, :project, :subscribable, presence: true
+ validates :user, :subscribable, presence: true
- validates :project_id,
- uniqueness: { scope: [:subscribable_id, :subscribable_type, :user_id] },
- presence: true
+ validates :project_id, uniqueness: { scope: [:subscribable_id, :subscribable_type, :user_id] }
end