diff options
author | Nataliia Solomko <natalirs1985@gmail.com> | 2024-04-25 13:27:50 +0300 |
---|---|---|
committer | Mergify <37929162+mergify[bot]@users.noreply.github.com> | 2024-05-01 15:34:47 +0000 |
commit | 0891817c6f0b4d4bb3e8d4c21f2873ab43e1be26 (patch) | |
tree | 5542df2c18c8941547f64bf8165b2a3f3e412600 /src/conf_mode/service_pppoe-server.py | |
parent | f69604da0a06e4bf48e3730286539f84ad02d0ef (diff) | |
download | vyos-1x-0891817c6f0b4d4bb3e8d4c21f2873ab43e1be26.tar.gz vyos-1x-0891817c6f0b4d4bb3e8d4c21f2873ab43e1be26.zip |
pppoe-server: T6234: PPPoE-server pado-delay refactoring
(cherry picked from commit 107ee099e82397b31fca8cf1ac3860cbf76f0596)
Diffstat (limited to 'src/conf_mode/service_pppoe-server.py')
-rwxr-xr-x | src/conf_mode/service_pppoe-server.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/conf_mode/service_pppoe-server.py b/src/conf_mode/service_pppoe-server.py index 328487985..c95f976d3 100755 --- a/src/conf_mode/service_pppoe-server.py +++ b/src/conf_mode/service_pppoe-server.py @@ -84,12 +84,29 @@ def verify_pado_delay(pppoe): pado_delay = pppoe['pado_delay'] delays_without_sessions = pado_delay['delays_without_sessions'] + if 'disable' in delays_without_sessions: + raise ConfigError( + 'Number of sessions must be specified for "pado-delay disable"' + ) + if len(delays_without_sessions) > 1: raise ConfigError( f'Cannot add more then ONE pado-delay without sessions, ' f'but {len(delays_without_sessions)} were set' ) + if 'disable' in [delay[0] for delay in pado_delay['delays_with_sessions']]: + # need to sort delays by sessions to verify if there is no delay + # for sessions after disabling + sorted_pado_delay = sorted(pado_delay['delays_with_sessions'], key=lambda k_v: k_v[1]) + last_delay = sorted_pado_delay[-1] + + if last_delay[0] != 'disable': + raise ConfigError( + f'Cannot add pado-delay after disabled sessions, but ' + f'"pado-delay {last_delay[0]} sessions {last_delay[1]}" was set' + ) + def verify(pppoe): if not pppoe: return None |