Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
FoD
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
David Schmitz
FoD
Commits
a28fb77d
Commit
a28fb77d
authored
6 years ago
by
David Schmitz
Browse files
Options
Downloads
Patches
Plain Diff
new rule concept: work on ui edit for rules with multiple source prefixes
parent
c7bd5a5a
Branches
Branches containing commit
Tags
Tags containing commit
No related merge requests found
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
flowspec/serializers.py
+1
-0
1 addition, 0 deletions
flowspec/serializers.py
flowspec/tasks.py
+4
-2
4 additions, 2 deletions
flowspec/tasks.py
flowspec/views.py
+10
-9
10 additions, 9 deletions
flowspec/views.py
with
15 additions
and
11 deletions
flowspec/serializers.py
+
1
−
0
View file @
a28fb77d
...
...
@@ -122,6 +122,7 @@ class RouteSerializer(serializers.HyperlinkedModelSerializer):
'
tcpflag
'
,
'
response
'
,
'
url
'
,
'
deleted
'
,
)
read_only_fields
=
(
'
response
'
,
'
id
'
)
...
...
This diff is collapsed.
Click to expand it.
flowspec/tasks.py
+
4
−
2
View file @
a28fb77d
...
...
@@ -63,7 +63,8 @@ def add(rule, callback=None):
else
:
# TODO PR.Applier can't work with multiple routes
#applier = PR.Applier(rule_object=rule)
applier
=
PR
.
Applier
(
rule_object
=
rule
,
route_objects
=
rule
.
routes
.
select_related
().
all
())
#applier = PR.Applier(rule_object=rule, route_objects=rule.routes.select_related().all())
applier
=
PR
.
Applier
(
rule_object
=
rule
,
route_objects
=
rule
.
get_routes_nondeleted
)
commit
,
response
=
applier
.
apply
()
if
commit
:
status
=
"
ACTIVE
"
...
...
@@ -120,7 +121,8 @@ def edit(rule, callback=None):
#logger.info("edit(): rule="+str(rule)+", rule.dir="+str(dir(rule)))
#applier = PR.Applier(rule_object=rule)
applier
=
PR
.
Applier
(
rule_object
=
rule
,
route_objects
=
rule
.
routes
.
select_related
().
all
())
#applier = PR.Applier(rule_object=rule, route_objects=rule.routes.select_related().all())
applier
=
PR
.
Applier
(
rule_object
=
rule
,
route_objects
=
rule
.
get_routes_nondeleted
)
commit
,
response
=
applier
.
apply
(
operation
=
"
replace
"
)
if
commit
:
status
=
"
ACTIVE
"
...
...
This diff is collapsed.
Click to expand it.
flowspec/views.py
+
10
−
9
View file @
a28fb77d
...
...
@@ -474,11 +474,13 @@ def edit_route(request, rule_slug):
try
:
route_reused
=
source_prefix_to_reused_route__hash
[
source
]
route_original
=
deepcopy
(
route_reused
)
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_reused=
"
+
str
(
route_reused
)
+
"
=> route_reused.source=
"
+
str
(
route_reused
.
source
))
except
:
route_reused
=
None
route_reused
=
None
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_reused=
"
+
str
(
route_reused
))
form
=
RouteForm
(
request_data
,
#instance=rule_edit.routes.get()
...
...
@@ -489,7 +491,7 @@ def edit_route(request, rule_slug):
critical_changed_values
=
[
'
source
'
,
'
destination
'
,
'
sourceport
'
,
'
destinationport
'
,
'
port
'
,
'
protocol
'
,
'
then
'
,
'
fragmenttype
'
]
if
form
.
is_valid
():
form_list
.
append
(
form
)
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_
reused
=
"
+
str
(
route_
reused
)
+
"
form valid
"
)
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_
original
=
"
+
str
(
route_
original
)
+
"
form valid
"
)
changed_data
=
form
.
changed_data
route
=
form
.
save
(
commit
=
False
)
...
...
@@ -498,7 +500,6 @@ def edit_route(request, rule_slug):
route_edit
=
route_reused
if
route_reused
!=
None
:
route_original
=
deepcopy
(
route_edit
)
route
.
name
=
route_original
.
name
#route.status = rule_original.status
route
.
response
=
route_original
.
response
...
...
@@ -526,7 +527,7 @@ def edit_route(request, rule_slug):
# route.rule.commit_edit()
#return HttpResponseRedirect(reverse("group-routes"))
else
:
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_
reused
=
"
+
str
(
route_
reused
)
+
"
=> NOT form valid
"
)
logger
.
info
(
"
views::edit_route(): source_prefix_list loop: source=
"
+
str
(
source
)
+
"
=> route_
original
=
"
+
str
(
route_
original
)
+
"
=> NOT form valid
"
)
if
request
.
user
.
is_superuser
:
form
.
fields
[
'
then
'
]
=
forms
.
ModelMultipleChoiceField
(
queryset
=
ThenAction
.
objects
.
all
().
order_by
(
'
action
'
),
required
=
True
)
form
.
fields
[
'
protocol
'
]
=
forms
.
ModelMultipleChoiceField
(
queryset
=
MatchProtocol
.
objects
.
all
().
order_by
(
'
protocol
'
),
required
=
False
)
...
...
@@ -550,6 +551,9 @@ def edit_route(request, rule_slug):
#route.rule.save()
rule_edit
.
save
()
#route.save()
rule_edit
.
status
=
"
ACTIVE
"
# ???
rule_edit
.
editing
=
False
rule_edit
.
save
()
for
route
in
new_nondeleted_routes
:
route
.
deleted
=
False
...
...
@@ -557,16 +561,13 @@ def edit_route(request, rule_slug):
for
route
in
current_routes_to_make_deleted
:
route
.
deleted
=
True
;
#
route.save()
route
.
save
()
if
bool
(
set
(
changed_data
)
&
set
(
critical_changed_values
))
or
(
not
rule_original
.
status
==
'
ACTIVE
'
):
for
form
in
form_list
:
form
.
save_m2m
()
#route.rule.commit_edit()
rule_edit
.
status
=
"
ACTIVE
"
# ???
rule_edit
.
editing
=
False
rule_edit
.
save
()
#if rule_edit.status=="ACTIVE":
rule_edit
.
commit_edit
(
current_routes_to_delete
=
current_routes_to_make_deleted
)
...
...
@@ -638,7 +639,7 @@ def calculate_route_reuse(rule_edit, source_prefix_list):
prefix
=
route
.
source
if
prefix
in
source_prefix_set
:
source_prefix_to_reused_route__hash
[
prefix
]
=
route
source_prefix_set
.
delet
e
(
prefix
)
source_prefix_set
.
remov
e
(
prefix
)
return
(
source_prefix_to_reused_route__hash
,
current_routes_to_make_deleted
)
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment