summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2021-04-30 22:21:01 +0200
committerGitHub <noreply@github.com>2021-04-30 22:21:01 +0200
commit9d1257d861fb20635a36bbe386dd4da25e50c610 (patch)
treec7c31da0d7d5ab0682c0c60b177e096d08cff472
parentbb34c495ae80207af439123cc11a4d5e1852b1da (diff)
parentc7430fbb8738d76e63a6972b7399fa39572e2254 (diff)
downloadvyos-1x-9d1257d861fb20635a36bbe386dd4da25e50c610.tar.gz
vyos-1x-9d1257d861fb20635a36bbe386dd4da25e50c610.zip
Merge pull request #823 from sever-sever/T3333-eq
ipsec: T3333: Fix status for SA state op-mode
-rwxr-xr-xsrc/op_mode/show_ipsec_sa.py9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/op_mode/show_ipsec_sa.py b/src/op_mode/show_ipsec_sa.py
index 066e36b5e..645a0571d 100755
--- a/src/op_mode/show_ipsec_sa.py
+++ b/src/op_mode/show_ipsec_sa.py
@@ -43,8 +43,11 @@ for sa in sas:
# list_sas() returns a list of single-item dicts
for peer in sa:
parent_sa = sa[peer]
+ child_sas = parent_sa["child-sas"]
+ installed_sas = {k: v for k, v in child_sas.items() if v["state"] == b"INSTALLED"}
- if parent_sa["state"] == b"ESTABLISHED":
+ # parent_sa["state"] = IKE state, child_sas["state"] = ESP state
+ if parent_sa["state"] == b"ESTABLISHED" and installed_sas:
state = "up"
else:
state = "down"
@@ -61,9 +64,6 @@ for sa in sas:
remote_id = "N/A"
# The counters can only be obtained from the child SAs
- child_sas = parent_sa["child-sas"]
- installed_sas = {k: v for k, v in child_sas.items() if v["state"] == b"INSTALLED"}
-
if not installed_sas:
data = [peer, state, "N/A", "N/A", "N/A", "N/A", "N/A", "N/A"]
sa_data.append(data)
@@ -71,6 +71,7 @@ for sa in sas:
for csa in installed_sas:
isa = installed_sas[csa]
csa_name = isa['name']
+ csa_name = csa_name.decode()
bytes_in = hurry.filesize.size(int(isa["bytes-in"].decode()))
bytes_out = hurry.filesize.size(int(isa["bytes-out"].decode()))