Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
4adccb3e
Commit
4adccb3e
authored
May 16, 2018
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[EE] Introduce a new Keys::DestroyService service
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
7c6d113a
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
59 additions
and
2 deletions
+59
-2
app/controllers/profiles/keys_controller.rb
app/controllers/profiles/keys_controller.rb
+1
-1
app/services/keys/base_service.rb
app/services/keys/base_service.rb
+1
-1
app/services/keys/destroy_service.rb
app/services/keys/destroy_service.rb
+14
-0
ee/app/services/ee/keys/destroy_service.rb
ee/app/services/ee/keys/destroy_service.rb
+12
-0
ee/spec/factories/ldap_keys.rb
ee/spec/factories/ldap_keys.rb
+3
-0
ee/spec/services/ee/keys/destroy_service_spec.rb
ee/spec/services/ee/keys/destroy_service_spec.rb
+15
-0
spec/services/keys/destroy_service_spec.rb
spec/services/keys/destroy_service_spec.rb
+13
-0
No files found.
app/controllers/profiles/keys_controller.rb
View file @
4adccb3e
...
@@ -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
}
...
...
app/services/keys/base_service.rb
View file @
4adccb3e
...
@@ -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
...
...
app/services/keys/destroy_service.rb
0 → 100644
View file @
4adccb3e
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
ee/app/services/ee/keys/destroy_service.rb
0 → 100644
View file @
4adccb3e
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
ee/spec/factories/ldap_keys.rb
0 → 100644
View file @
4adccb3e
FactoryBot
.
define
do
factory
:ldap_key
,
parent: :key
,
class:
'LDAPKey'
end
ee/spec/services/ee/keys/destroy_service_spec.rb
0 → 100644
View file @
4adccb3e
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
spec/services/keys/destroy_service_spec.rb
0 → 100644
View file @
4adccb3e
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
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment