summaryrefslogtreecommitdiff
path: root/python/vyos
diff options
context:
space:
mode:
authorJohn Estabrook <jestabro@vyos.io>2021-12-09 12:34:10 -0600
committerJohn Estabrook <jestabro@vyos.io>2021-12-09 12:34:10 -0600
commit9e34d2761e7d88d49782b94c0b1a0f5de3029546 (patch)
tree8e29b2c1b1975d67aa6417e7b9683c16b61bd275 /python/vyos
parentf168e409acb314d1c15a4343643be7c07ce79b44 (diff)
downloadvyos-1x-9e34d2761e7d88d49782b94c0b1a0f5de3029546.tar.gz
vyos-1x-9e34d2761e7d88d49782b94c0b1a0f5de3029546.zip
vyos.util: T4061: add function to check for completion of boot config
Diffstat (limited to 'python/vyos')
-rw-r--r--python/vyos/configsource.py3
-rw-r--r--python/vyos/defaults.py2
-rw-r--r--python/vyos/util.py9
3 files changed, 13 insertions, 1 deletions
diff --git a/python/vyos/configsource.py b/python/vyos/configsource.py
index b0981d25e..a0f6a46b5 100644
--- a/python/vyos/configsource.py
+++ b/python/vyos/configsource.py
@@ -19,6 +19,7 @@ import re
import subprocess
from vyos.configtree import ConfigTree
+from vyos.util import boot_configuration_complete
class VyOSError(Exception):
"""
@@ -117,7 +118,7 @@ class ConfigSourceSession(ConfigSource):
# Running config can be obtained either from op or conf mode, it always succeeds
# once the config system is initialized during boot;
# before initialization, set to empty string
- if os.path.isfile('/tmp/vyos-config-status'):
+ if boot_configuration_complete():
try:
running_config_text = self._run([self._cli_shell_api, '--show-active-only', '--show-show-defaults', '--show-ignore-edit', 'showConfig'])
except VyOSError:
diff --git a/python/vyos/defaults.py b/python/vyos/defaults.py
index dacdbdef2..7e62d2b13 100644
--- a/python/vyos/defaults.py
+++ b/python/vyos/defaults.py
@@ -29,6 +29,8 @@ directories = {
}
+config_status = '/tmp/vyos-config-status'
+
cfg_group = 'vyattacfg'
cfg_vintage = 'vyos'
diff --git a/python/vyos/util.py b/python/vyos/util.py
index 1834b78bd..dcb332e5c 100644
--- a/python/vyos/util.py
+++ b/python/vyos/util.py
@@ -733,3 +733,12 @@ def is_wwan_connected(interface):
# return True/False if interface is in connected state
return dict_search('modem.generic.state', tmp) == 'connected'
+
+def boot_configuration_complete() -> bool:
+ """ Check if the boot config loader has completed
+ """
+ from vyos.defaults import config_status
+
+ if os.path.isfile(config_status):
+ return True
+ return False