Feature: Ability to switch between multiple accounts (#881)
* Feature: Ability to switch between multiple accounts * Fix rubocop * Fix assigned inboxes * fix auth json * Add account switcher in UI * fix ordering on administrate * Add switch accounts to sidebar * add account id * Fix schema.rb timestamp * Revert "add account id" This reverts commit 27570f50ef584cb9a5f69454f43f630b318c8807. * Add a check for account Co-authored-by: Pranav Raj Sreepuram <pranavrajs@gmail.com>
This commit is contained in:
@@ -11,23 +11,26 @@ RSpec.describe ContactPolicy, type: :policy do
|
||||
let(:agent) { create(:user, account: account) }
|
||||
let(:contact) { create(:contact) }
|
||||
|
||||
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
|
||||
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
|
||||
|
||||
permissions :index?, :show?, :update? do
|
||||
context 'when administrator' do
|
||||
it { expect(contact_policy).to permit(administrator, contact) }
|
||||
it { expect(contact_policy).to permit(administrator_context, contact) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(contact_policy).not_to permit(agent, contact) }
|
||||
it { expect(contact_policy).to permit(agent_context, contact) }
|
||||
end
|
||||
end
|
||||
|
||||
permissions :create? do
|
||||
context 'when administrator' do
|
||||
it { expect(contact_policy).to permit(administrator, contact) }
|
||||
it { expect(contact_policy).to permit(administrator_context, contact) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(contact_policy).to permit(agent, contact) }
|
||||
it { expect(contact_policy).to permit(agent_context, contact) }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -10,24 +10,26 @@ RSpec.describe InboxPolicy, type: :policy do
|
||||
let(:administrator) { create(:user, :administrator, account: account) }
|
||||
let(:agent) { create(:user, account: account) }
|
||||
let(:inbox) { create(:inbox) }
|
||||
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
|
||||
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
|
||||
|
||||
permissions :create?, :destroy?, :update?, :set_agent_bot? do
|
||||
context 'when administrator' do
|
||||
it { expect(inbox_policy).to permit(administrator, inbox) }
|
||||
it { expect(inbox_policy).to permit(administrator_context, inbox) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(inbox_policy).not_to permit(agent, inbox) }
|
||||
it { expect(inbox_policy).not_to permit(agent_context, inbox) }
|
||||
end
|
||||
end
|
||||
|
||||
permissions :index? do
|
||||
context 'when administrator' do
|
||||
it { expect(inbox_policy).to permit(administrator, inbox) }
|
||||
it { expect(inbox_policy).to permit(administrator_context, inbox) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(inbox_policy).to permit(agent, inbox) }
|
||||
it { expect(inbox_policy).to permit(agent_context, inbox) }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -10,24 +10,26 @@ RSpec.describe UserPolicy, type: :policy do
|
||||
let(:administrator) { create(:user, :administrator, account: account) }
|
||||
let(:agent) { create(:user, account: account) }
|
||||
let(:user) { create(:user, account: account) }
|
||||
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
|
||||
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
|
||||
|
||||
permissions :create?, :update?, :destroy? do
|
||||
context 'when administrator' do
|
||||
it { expect(user_policy).to permit(administrator, user) }
|
||||
it { expect(user_policy).to permit(administrator_context, user) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(user_policy).not_to permit(agent, user) }
|
||||
it { expect(user_policy).not_to permit(agent_context, user) }
|
||||
end
|
||||
end
|
||||
|
||||
permissions :index? do
|
||||
context 'when administrator' do
|
||||
it { expect(user_policy).to permit(administrator, user) }
|
||||
it { expect(user_policy).to permit(administrator_context, user) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(user_policy).to permit(agent, user) }
|
||||
it { expect(user_policy).to permit(agent_context, user) }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user