SECURITY: do not show private topic title on /unsubscribed page

This commit is contained in:
Arpit Jalan 2018-04-16 10:14:43 +05:30
parent 940b3a7c74
commit 8d1e8fa712
4 changed files with 27 additions and 5 deletions

View File

@ -110,10 +110,11 @@ class EmailController < ApplicationController
def unsubscribed
@email = params[:email]
@topic_id = params[:topic_id]
user = User.find_by_email(params[:email])
raise Discourse::NotFound unless user
@topic = Topic.find_by(id: params[:topic_id].to_i) if params[:topic_id]
raise Discourse::NotFound unless Guardian.new(user).can_see?(@topic)
topic = Topic.find_by(id: params[:topic_id].to_i) if @topic_id
@topic = topic if topic && Guardian.new(nil).can_see?(topic)
end
end

View File

@ -7,8 +7,8 @@
</p>
<% if @topic %>
<p>
<%=t("unsubscribed.topic_description", link: render_topic_title(@topic)).html_safe%>
</p>
<p><%=t("unsubscribed.topic_description", link: render_topic_title(@topic)).html_safe%></p>
<% elsif @topic_id %>
<p><%=t("unsubscribed.private_topic_description")%></p>
<% end %>
</div>

View File

@ -760,6 +760,7 @@ en:
title: "Unsubscribed!"
description: "<b>%{email}</b> has been unsubscribed. To change your email settings <a href='%{url}'>visit your user preferences</a>."
topic_description: "To re-subscribe to %{link}, use the notification control at the bottom or right of the topic."
private_topic_description: "To re-subscribe, use the notification control at the bottom or right of the topic."
unsubscribe:
title: "Unsubscribe"

View File

@ -1,6 +1,10 @@
require 'rails_helper'
RSpec.describe EmailController do
let(:user) { Fabricate(:user) }
let(:topic) { Fabricate(:topic) }
let(:private_topic) { Fabricate(:private_message_topic) }
describe '#unsubscribed' do
describe 'when email is invalid' do
it 'should return the right response' do
@ -9,5 +13,21 @@ RSpec.describe EmailController do
expect(response.status).to eq(404)
end
end
describe 'when topic is public' do
it 'should return the right response' do
get '/email/unsubscribed', params: { email: user.email, topic_id: topic.id }
expect(response).to be_success
expect(response.body).to include(topic.title)
end
end
describe 'when topic is private' do
it 'should return the right response' do
get '/email/unsubscribed', params: { email: user.email, topic_id: private_topic.id }
expect(response).to be_success
expect(response.body).to_not include(private_topic.title)
end
end
end
end