From 3fa16fe678acabe7e26ca9f87fda57f554d8a968 Mon Sep 17 00:00:00 2001 From: jesopo Date: Mon, 5 Nov 2018 13:26:11 +0000 Subject: [PATCH] Explicitly *remove* STS policy when we get a duration of 0 --- modules/sts.py | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/modules/sts.py b/modules/sts.py index c12ee01f..c16e8214 100644 --- a/modules/sts.py +++ b/modules/sts.py @@ -5,16 +5,20 @@ class Module(ModuleManager.BaseModule): def _set_policy(self, server, port, duration, one_shot): expiration = None if duration: - expiration = time.time()+int(duration) + expiration = time.time()+duration server.set_setting("sts-policy", { "port": port, "expiration": expiration, "one-shot": one_shot}) def _change_duration(self, server, info): - port = event["server"].port - if "port" in info: - port = int(info["port"]) - self._set_policy(server, port, info["duration"], False) + duration = int(info["duration"]) + if duration == 0: + server.del_setting("sts-policy") + else: + port = event["server"].port + if "port" in info: + port = int(info["port"]) + self._set_policy(server, port, duration, False) @utils.hook("received.cap.ls") def on_cap_ls(self, event):