mirror of
https://github.com/discourse/discourse.git
synced 2025-03-31 21:06:09 +08:00
FIX: can grant titles to regular users. Guardian initializer needs current_user, not the target user.
This commit is contained in:
parent
b0e6475b07
commit
561961eff6
@ -44,7 +44,7 @@ class UsersController < ApplicationController
|
|||||||
user = fetch_user_from_params
|
user = fetch_user_from_params
|
||||||
guardian.ensure_can_edit!(user)
|
guardian.ensure_can_edit!(user)
|
||||||
json_result(user, serializer: UserSerializer) do |u|
|
json_result(user, serializer: UserSerializer) do |u|
|
||||||
updater = UserUpdater.new(user)
|
updater = UserUpdater.new(current_user, user)
|
||||||
updater.update(params)
|
updater.update(params)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
class UserUpdater
|
class UserUpdater
|
||||||
def initialize(user)
|
def initialize(actor, user)
|
||||||
@user = user
|
@user = user
|
||||||
@guardian = Guardian.new(user)
|
@guardian = Guardian.new(actor)
|
||||||
end
|
end
|
||||||
|
|
||||||
def update(attributes = {})
|
def update(attributes = {})
|
||||||
|
@ -1,10 +1,13 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe UserUpdater do
|
describe UserUpdater do
|
||||||
|
|
||||||
|
let(:acting_user) { Fabricate.build(:user) }
|
||||||
|
|
||||||
describe '#update' do
|
describe '#update' do
|
||||||
it 'saves user' do
|
it 'saves user' do
|
||||||
user = Fabricate(:user, name: 'Billy Bob')
|
user = Fabricate(:user, name: 'Billy Bob')
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
updater.update(name: 'Jim Tom')
|
updater.update(name: 'Jim Tom')
|
||||||
|
|
||||||
@ -14,7 +17,7 @@ describe UserUpdater do
|
|||||||
context 'when update succeeds' do
|
context 'when update succeeds' do
|
||||||
it 'returns true' do
|
it 'returns true' do
|
||||||
user = Fabricate(:user)
|
user = Fabricate(:user)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
expect(updater.update).to be_true
|
expect(updater.update).to be_true
|
||||||
end
|
end
|
||||||
@ -24,7 +27,7 @@ describe UserUpdater do
|
|||||||
it 'returns false' do
|
it 'returns false' do
|
||||||
user = Fabricate(:user)
|
user = Fabricate(:user)
|
||||||
user.stubs(save: false)
|
user.stubs(save: false)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
expect(updater.update).to be_false
|
expect(updater.update).to be_false
|
||||||
end
|
end
|
||||||
@ -35,8 +38,8 @@ describe UserUpdater do
|
|||||||
user = Fabricate(:user, title: 'Emperor')
|
user = Fabricate(:user, title: 'Emperor')
|
||||||
guardian = stub
|
guardian = stub
|
||||||
guardian.stubs(:can_grant_title?).with(user).returns(true)
|
guardian.stubs(:can_grant_title?).with(user).returns(true)
|
||||||
Guardian.stubs(:new).with(user).returns(guardian)
|
Guardian.stubs(:new).with(acting_user).returns(guardian)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
updater.update(title: 'Minion')
|
updater.update(title: 'Minion')
|
||||||
|
|
||||||
@ -49,8 +52,8 @@ describe UserUpdater do
|
|||||||
user = Fabricate(:user, title: 'Emperor')
|
user = Fabricate(:user, title: 'Emperor')
|
||||||
guardian = stub
|
guardian = stub
|
||||||
guardian.stubs(:can_grant_title?).with(user).returns(false)
|
guardian.stubs(:can_grant_title?).with(user).returns(false)
|
||||||
Guardian.stubs(:new).with(user).returns(guardian)
|
Guardian.stubs(:new).with(acting_user).returns(guardian)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
updater.update(title: 'Minion')
|
updater.update(title: 'Minion')
|
||||||
|
|
||||||
@ -61,7 +64,7 @@ describe UserUpdater do
|
|||||||
context 'when website includes http' do
|
context 'when website includes http' do
|
||||||
it 'does not add http before updating' do
|
it 'does not add http before updating' do
|
||||||
user = Fabricate(:user)
|
user = Fabricate(:user)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
updater.update(website: 'http://example.com')
|
updater.update(website: 'http://example.com')
|
||||||
|
|
||||||
@ -72,7 +75,7 @@ describe UserUpdater do
|
|||||||
context 'when website does not include http' do
|
context 'when website does not include http' do
|
||||||
it 'adds http before updating' do
|
it 'adds http before updating' do
|
||||||
user = Fabricate(:user)
|
user = Fabricate(:user)
|
||||||
updater = UserUpdater.new(user)
|
updater = described_class.new(acting_user, user)
|
||||||
|
|
||||||
updater.update(website: 'example.com')
|
updater.update(website: 'example.com')
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user