summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Breunig <christian@breunig.cc>2024-02-13 21:53:44 +0100
committerGitHub <noreply@github.com>2024-02-13 21:53:44 +0100
commitd095fd6fb627af34b8bacf33ba737c822944fe8c (patch)
treeed05c3958f86a9818404d494cbd9ab59598d56e9
parentf583773faf67b3b1227681ff12e418f6fdc5a0fa (diff)
parentf467e61eea94f388f429cdcf0d7fc6f9363bda68 (diff)
downloadvyos-1x-d095fd6fb627af34b8bacf33ba737c822944fe8c.tar.gz
vyos-1x-d095fd6fb627af34b8bacf33ba737c822944fe8c.zip
Merge pull request #3007 from c-po/rpki-fixes
utils: T5239: add low-level read from config.boot (RPKI fixes)
-rw-r--r--python/vyos/util.py23
-rwxr-xr-xsrc/helpers/read-saved-value.py28
2 files changed, 51 insertions, 0 deletions
diff --git a/python/vyos/util.py b/python/vyos/util.py
index 1b16df76b..509b4ea00 100644
--- a/python/vyos/util.py
+++ b/python/vyos/util.py
@@ -968,3 +968,26 @@ def get_vrf_members(vrf: str) -> list:
if 'ifname' in data:
interfaces.append(data.get('ifname'))
return interfaces
+
+def read_saved_value(path: list):
+ from vyos.defaults import directories
+ config_file = os.path.join(directories['config'], 'config.boot')
+
+ if not isinstance(path, list) or not path:
+ return ''
+ from vyos.configtree import ConfigTree
+ try:
+ with open(config_file) as f:
+ config_string = f.read()
+ ct = ConfigTree(config_string)
+ except Exception:
+ return ''
+ if not ct.exists(path):
+ return ''
+ res = ct.return_values(path)
+ if len(res) == 1:
+ return res[0]
+ res = ct.list_nodes(path)
+ if len(res) == 1:
+ return ' '.join(res)
+ return res
diff --git a/src/helpers/read-saved-value.py b/src/helpers/read-saved-value.py
new file mode 100755
index 000000000..44d28832e
--- /dev/null
+++ b/src/helpers/read-saved-value.py
@@ -0,0 +1,28 @@
+#!/usr/bin/env python3
+#
+# Copyright (C) 2023 VyOS maintainers and contributors
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License version 2 or later as
+# published by the Free Software Foundation.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+from argparse import ArgumentParser
+from vyos.util import read_saved_value
+
+if __name__ == '__main__':
+ parser = ArgumentParser()
+ parser.add_argument('--path', nargs='*')
+ args = parser.parse_args()
+
+ out = read_saved_value(args.path) if args.path else ''
+ if isinstance(out, list):
+ out = ' '.join(out)
+ print(out)