discourse/app/controllers/email_controller.rb

118 lines
3.6 KiB
Ruby
Raw Normal View History

2013-02-06 03:16:51 +08:00
class EmailController < ApplicationController
skip_before_action :check_xhr, :preload_json, :redirect_to_login_if_required
layout 'no_ember'
2013-02-06 03:16:51 +08:00
before_action :ensure_logged_in, only: :preferences_redirect
2013-02-06 03:16:51 +08:00
def preferences_redirect
redirect_to(email_preferences_path(current_user.username_lower))
end
def unsubscribe
@not_found = true
@watched_count = nil
if key = UnsubscribeKey.find_by(key: params[:key])
if @user = key.user
post = key.post
@topic = post&.topic || key.topic
@type = key.unsubscribe_key_type
@not_found = false
if current_user.present? && (@user != current_user)
@different_user = @user.name
@return_url = request.original_url
end
watching = TopicUser.notification_levels[:watching]
if @topic
@watching_topic = TopicUser.exists?(user_id: @user.id, notification_level: watching, topic_id: @topic.id)
if @topic.category_id
if CategoryUser.exists?(user_id: @user.id, notification_level: CategoryUser.watching_levels, category_id: @topic.category_id)
@watched_count = TopicUser.joins(:topic)
2017-07-28 09:20:09 +08:00
.where(user: @user, notification_level: watching, "topics.category_id" => @topic.category_id)
.count
end
end
end
end
end
end
def perform_unsubscribe
key = UnsubscribeKey.find_by(key: params[:key])
raise Discourse::NotFound unless key && key.user
topic = key&.post&.topic || key.topic
user = key.user
updated = false
if topic
if params["unwatch_topic"]
TopicUser.where(topic_id: topic.id, user_id: user.id)
2017-07-28 09:20:09 +08:00
.update_all(notification_level: TopicUser.notification_levels[:tracking])
updated = true
end
if params["unwatch_category"] && topic.category_id
TopicUser.joins(:topic)
2017-07-28 09:20:09 +08:00
.where(:user => user,
:notification_level => TopicUser.notification_levels[:watching],
"topics.category_id" => topic.category_id)
.update_all(notification_level: TopicUser.notification_levels[:tracking])
CategoryUser.where(user_id: user.id,
2017-07-28 09:20:09 +08:00
category_id: topic.category_id,
notification_level: CategoryUser.watching_levels
)
2017-07-28 09:20:09 +08:00
.destroy_all
updated = true
end
if params["mute_topic"]
TopicUser.where(topic_id: topic.id, user_id: user.id)
2017-07-28 09:20:09 +08:00
.update_all(notification_level: TopicUser.notification_levels[:muted])
updated = true
end
end
if params["disable_mailing_list"]
2016-06-17 09:57:23 +08:00
user.user_option.update_columns(mailing_list_mode: false)
updated = true
end
if params["disable_digest_emails"]
user.user_option.update_columns(email_digests: false)
updated = true
end
if params["unsubscribe_all"]
user.user_option.update_columns(email_always: false,
2017-07-28 09:20:09 +08:00
email_digests: false,
email_direct: false,
email_private_messages: false)
updated = true
2013-02-06 03:16:51 +08:00
end
unless updated
redirect_to :back
2016-01-20 17:25:25 +08:00
else
if topic
redirect_to path("/email/unsubscribed?topic_id=#{topic.id}&email=#{user.email}")
else
redirect_to path("/email/unsubscribed?email=#{user.email}")
end
2016-01-20 17:25:25 +08:00
end
2013-02-06 03:16:51 +08:00
end
def unsubscribed
@email = params[:email]
raise Discourse::NotFound if !User.find_by_email(params[:email])
@topic = Topic.find_by(id: params[:topic_id].to_i) if params[:topic_id]
2013-02-06 03:16:51 +08:00
end
end