return 403 when trying drafts of another user

This commit is contained in:
pmusaraj 2018-09-12 13:08:02 -04:00
parent b8c0a29bec
commit aa614e393c
3 changed files with 4 additions and 11 deletions

View File

@ -16,8 +16,6 @@ class DraftsController < ApplicationController
limit: params[:limit] limit: params[:limit]
} }
help_key = "user_activity.no_drafts"
if user == current_user if user == current_user
stream = Draft.stream(opts) stream = Draft.stream(opts)
stream.each do |d| stream.each do |d|
@ -31,15 +29,13 @@ class DraftsController < ApplicationController
end end
end end
end end
help_key += ".self"
else else
help_key += ".others" raise Discourse::InvalidAccess
end end
render json: { render json: {
drafts: stream ? serialize_data(stream, DraftSerializer) : [], drafts: stream ? serialize_data(stream, DraftSerializer) : [],
no_results_help: I18n.t(help_key) no_results_help: I18n.t("user_activity.no_drafts.self")
} }
end end

View File

@ -796,7 +796,6 @@ en:
others: "No replies." others: "No replies."
no_drafts: no_drafts:
self: "You have no drafts; begin composing a reply in any topic and it will be auto-saved as a new draft." self: "You have no drafts; begin composing a reply in any topic and it will be auto-saved as a new draft."
others: "You do not have permission to see drafts for this user."
topic_flag_types: topic_flag_types:
spam: spam:

View File

@ -1,4 +1,5 @@
require 'rails_helper' require 'rails_helper'
require 'pp'
describe DraftsController do describe DraftsController do
it 'requires you to be logged in' do it 'requires you to be logged in' do
@ -28,11 +29,8 @@ describe DraftsController do
it 'does not let a user see drafts stream of another user' do it 'does not let a user see drafts stream of another user' do
user_b = Fabricate(:user) user_b = Fabricate(:user)
Draft.set(user_b, 'xxx', 0, '{}') Draft.set(user_b, 'xxx', 0, '{}')
sign_in(Fabricate(:user)) sign_in(Fabricate(:user))
get "/drafts.json", params: { username: user_b.username } get "/drafts.json", params: { username: user_b.username }
expect(response.status).to eq(200) expect(response.status).to eq(403)
parsed = JSON.parse(response.body)
expect(parsed["drafts"].length).to eq(0)
end end
end end