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
a996f040
Commit
a996f040
authored
Sep 08, 2020
by
ap4y
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Implement policy removal in policy editor
parent
6ae64a37
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
92 additions
and
3 deletions
+92
-3
ee/app/assets/javascripts/threat_monitoring/components/policy_editor/policy_editor.vue
...eat_monitoring/components/policy_editor/policy_editor.vue
+55
-3
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_editor_spec.js
...monitoring/components/policy_editor/policy_editor_spec.js
+28
-0
locale/gitlab.pot
locale/gitlab.pot
+9
-0
No files found.
ee/app/assets/javascripts/threat_monitoring/components/policy_editor/policy_editor.vue
View file @
a996f040
...
...
@@ -9,8 +9,10 @@ import {
GlSegmentedControl
,
GlButton
,
GlAlert
,
GlModal
,
GlModalDirective
,
}
from
'
@gitlab/ui
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
s__
,
__
,
sprintf
}
from
'
~/locale
'
;
import
{
redirectTo
}
from
'
~/lib/utils/url_utility
'
;
import
EnvironmentPicker
from
'
../environment_picker.vue
'
;
import
NetworkPolicyEditor
from
'
../network_policy_editor.vue
'
;
...
...
@@ -38,12 +40,14 @@ export default {
GlSegmentedControl
,
GlButton
,
GlAlert
,
GlModal
,
EnvironmentPicker
,
NetworkPolicyEditor
,
PolicyRuleBuilder
,
PolicyPreview
,
PolicyActionPicker
,
},
directives
:
{
GlModal
:
GlModalDirective
},
props
:
{
threatMonitoringPath
:
{
type
:
String
,
...
...
@@ -82,7 +86,12 @@ export default {
return
toYaml
(
this
.
policy
);
},
...
mapState
(
'
threatMonitoring
'
,
[
'
currentEnvironmentId
'
]),
...
mapState
(
'
networkPolicies
'
,
[
'
errorUpdatingPolicy
'
]),
...
mapState
(
'
networkPolicies
'
,
[
'
isUpdatingPolicy
'
,
'
isRemovingPolicy
'
,
'
errorUpdatingPolicy
'
,
'
errorRemovingPolicy
'
,
]),
shouldShowRuleEditor
()
{
return
this
.
editorMode
===
EditorModeRule
;
},
...
...
@@ -100,13 +109,16 @@ export default {
?
s__
(
'
NetworkPolicies|Save changes
'
)
:
s__
(
'
NetworkPolicies|Create policy
'
);
},
deleteModalTitle
()
{
return
sprintf
(
s__
(
'
NetworkPolicies|Delete policy: %{policy}
'
),
{
policy
:
this
.
policy
.
name
});
},
},
created
()
{
this
.
fetchEnvironments
();
},
methods
:
{
...
mapActions
(
'
threatMonitoring
'
,
[
'
fetchEnvironments
'
]),
...
mapActions
(
'
networkPolicies
'
,
[
'
createPolicy
'
,
'
updatePolicy
'
]),
...
mapActions
(
'
networkPolicies
'
,
[
'
createPolicy
'
,
'
updatePolicy
'
,
'
deletePolicy
'
]),
addRule
()
{
this
.
policy
.
rules
.
push
(
buildRule
(
RuleTypeEndpoint
));
},
...
...
@@ -151,6 +163,13 @@ export default {
if
(
!
this
.
errorUpdatingPolicy
)
redirectTo
(
this
.
threatMonitoringPath
);
});
},
removePolicy
()
{
const
policy
=
{
name
:
this
.
existingPolicy
.
name
,
manifest
:
toYaml
(
this
.
policy
)
};
return
this
.
deletePolicy
({
environmentId
:
this
.
currentEnvironmentId
,
policy
}).
then
(()
=>
{
if
(
!
this
.
errorRemovingPolicy
)
redirectTo
(
this
.
threatMonitoringPath
);
});
},
},
policyTypes
:
[{
value
:
'
networkPolicy
'
,
text
:
s__
(
'
NetworkPolicies|Network Policy
'
)
}],
editorModes
:
[
...
...
@@ -160,6 +179,16 @@ export default {
parsingErrorMessage
:
s__
(
'
NetworkPolicies|Rule mode is unavailable for this policy. In some cases, we cannot parse the YAML file back into the rules editor.
'
,
),
deleteModal
:
{
id
:
'
delete-modal
'
,
secondary
:
{
text
:
s__
(
'
NetworkPolicies|Delete policy
'
),
attributes
:
{
variant
:
'
danger
'
},
},
cancel
:
{
text
:
__
(
'
Cancel
'
),
},
},
};
</
script
>
...
...
@@ -286,13 +315,36 @@ export default {
category=
"primary"
variant=
"success"
data-testid=
"save-policy"
:loading=
"isUpdatingPolicy"
@
click=
"savePolicy"
>
{{
saveButtonText
}}
</gl-button
>
<gl-button
v-if=
"isEditing"
v-gl-modal=
"'delete-modal'"
category=
"secondary"
variant=
"danger"
data-testid=
"delete-policy"
:loading=
"isRemovingPolicy"
>
{{
s__
(
'
NetworkPolicies|Delete policy
'
)
}}
</gl-button
>
<gl-button
category=
"secondary"
variant=
"default"
:href=
"threatMonitoringPath"
>
{{
__
(
'
Cancel
'
)
}}
</gl-button>
</div>
</div>
<gl-modal
modal-id=
"delete-modal"
:title=
"deleteModalTitle"
:action-secondary=
"$options.deleteModal.secondary"
:action-cancel=
"$options.deleteModal.cancel"
@
secondary=
"removePolicy"
>
{{
s__
(
'
NetworkPolicies|Are you sure you want to delete this policy? This action cannot be undone.
'
,
)
}}
</gl-modal>
</section>
</
template
>
ee/spec/frontend/threat_monitoring/components/policy_editor/policy_editor_spec.js
View file @
a996f040
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlModal
}
from
'
@gitlab/ui
'
;
import
PolicyEditorApp
from
'
ee/threat_monitoring/components/policy_editor/policy_editor.vue
'
;
import
PolicyPreview
from
'
ee/threat_monitoring/components/policy_editor/policy_preview.vue
'
;
import
PolicyRuleBuilder
from
'
ee/threat_monitoring/components/policy_editor/policy_rule_builder.vue
'
;
...
...
@@ -51,6 +52,7 @@ describe('PolicyEditorApp component', () => {
const
findNetworkPolicyEditor
=
()
=>
wrapper
.
find
(
NetworkPolicyEditor
);
const
findPolicyName
=
()
=>
wrapper
.
find
(
"
[id='policyName']
"
);
const
findSavePolicy
=
()
=>
wrapper
.
find
(
"
[data-testid='save-policy']
"
);
const
findDeletePolicy
=
()
=>
wrapper
.
find
(
"
[data-testid='delete-policy']
"
);
beforeEach
(()
=>
{
factory
();
...
...
@@ -72,6 +74,10 @@ describe('PolicyEditorApp component', () => {
expect
(
findYAMLParsingAlert
().
exists
()).
toBe
(
false
);
});
it
(
'
does not render delete button
'
,
()
=>
{
expect
(
findDeletePolicy
().
exists
()).
toBe
(
false
);
});
describe
(
'
given .yaml editor mode is enabled
'
,
()
=>
{
beforeEach
(()
=>
{
factory
({
...
...
@@ -291,5 +297,27 @@ spec:
expect
(
redirectTo
).
not
.
toHaveBeenCalledWith
(
'
/threat-monitoring
'
);
});
});
it
(
'
renders delete button
'
,
()
=>
{
expect
(
findDeletePolicy
().
exists
()).
toBe
(
true
);
});
it
(
'
it does not trigger deletePolicy on delete button click
'
,
async
()
=>
{
findDeletePolicy
().
vm
.
$emit
(
'
click
'
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
store
.
dispatch
).
not
.
toHaveBeenCalledWith
(
'
networkPolicies/deletePolicy
'
);
});
it
(
'
removes policy and redirects to a threat monitoring path on secondary modal button click
'
,
async
()
=>
{
wrapper
.
find
(
GlModal
).
vm
.
$emit
(
'
secondary
'
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
store
.
dispatch
).
toHaveBeenCalledWith
(
'
networkPolicies/deletePolicy
'
,
{
environmentId
:
-
1
,
policy
:
{
name
:
'
policy
'
,
manifest
:
toYaml
(
wrapper
.
vm
.
policy
)
},
});
expect
(
redirectTo
).
toHaveBeenCalledWith
(
'
/threat-monitoring
'
);
});
});
});
locale/gitlab.pot
View file @
a996f040
...
...
@@ -16370,6 +16370,9 @@ msgstr ""
msgid "NetworkPolicies|Allow all outbound traffic from %{selector} to %{ruleSelector} on %{ports}"
msgstr ""
msgid "NetworkPolicies|Are you sure you want to delete this policy? This action cannot be undone."
msgstr ""
msgid "NetworkPolicies|Choose whether to enforce this policy."
msgstr ""
...
...
@@ -16379,6 +16382,12 @@ msgstr ""
msgid "NetworkPolicies|Define this policy's location, conditions and actions."
msgstr ""
msgid "NetworkPolicies|Delete policy"
msgstr ""
msgid "NetworkPolicies|Delete policy: %{policy}"
msgstr ""
msgid "NetworkPolicies|Deny all traffic"
msgstr ""
...
...
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