Commit 4adccb3e authored by Rémy Coutable's avatar Rémy Coutable

[EE] Introduce a new Keys::DestroyService service

Signed-off-by: default avatarRémy Coutable <remy@rymai.me>
parent 7c6d113a
...@@ -23,7 +23,7 @@ class Profiles::KeysController < Profiles::ApplicationController ...@@ -23,7 +23,7 @@ class Profiles::KeysController < Profiles::ApplicationController
def destroy def destroy
@key = current_user.keys.find(params[:id]) @key = current_user.keys.find(params[:id])
@key.destroy unless @key.is_a? LDAPKey Keys::DestroyService.new(current_user).execute(@key)
respond_to do |format| respond_to do |format|
format.html { redirect_to profile_keys_url, status: 302 } format.html { redirect_to profile_keys_url, status: 302 }
......
...@@ -2,7 +2,7 @@ module Keys ...@@ -2,7 +2,7 @@ module Keys
class BaseService class BaseService
attr_accessor :user, :params attr_accessor :user, :params
def initialize(user, params) def initialize(user, params = {})
@user, @params = user, params @user, @params = user, params
@ip_address = @params.delete(:ip_address) @ip_address = @params.delete(:ip_address)
end end
......
module Keys
class DestroyService < ::Keys::BaseService
prepend EE::Keys::DestroyService
def execute(key)
key.destroy if destroy_possible?(key)
end
# overriden in EE::Keys::DestroyService
def destroy_possible?(key)
true
end
end
end
module EE
module Keys
module DestroyService
extend ::Gitlab::Utils::Override
override :destroy_possible?
def destroy_possible?(key)
super && !key.is_a?(LDAPKey)
end
end
end
end
FactoryBot.define do
factory :ldap_key, parent: :key, class: 'LDAPKey'
end
require 'spec_helper'
describe Keys::DestroyService do
let(:user) { create(:user) }
let(:key) { create(:ldap_key) }
subject { described_class.new(user) }
it 'does not destroy LDAP key' do
key = create(:ldap_key)
expect { subject.execute(key) }.not_to change(Key, :count)
expect(key).not_to be_destroyed
end
end
require 'spec_helper'
describe Keys::DestroyService do
let(:user) { create(:user) }
subject { described_class.new(user) }
it 'destroys a key' do
key = create(:key)
expect { subject.execute(key) }.to change(Key, :count).by(-1)
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment