diff options
author | Christian Breunig <christian@breunig.cc> | 2023-09-22 06:16:27 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-22 06:16:27 +0200 |
commit | 7e16cea1897eba08f8e11bc5c600fcf8dc2cb591 (patch) | |
tree | 4c311798843e1544abeb04843a8cdf62a1c5ea1d /src | |
parent | 11edfade9f5ba181720099783f77dce9e282403c (diff) | |
parent | e8581998c2bfbbee349eee89df6d59cc6c4fca16 (diff) | |
download | vyos-1x-7e16cea1897eba08f8e11bc5c600fcf8dc2cb591.tar.gz vyos-1x-7e16cea1897eba08f8e11bc5c600fcf8dc2cb591.zip |
Merge pull request #2292 from vyos/mergify/bp/sagitta/pr-2289
init: T5239: configure system hostname prior to FRR startup (backport #2289)
Diffstat (limited to 'src')
-rwxr-xr-x | src/helpers/read-saved-value.py | 30 | ||||
-rwxr-xr-x | src/init/vyos-router | 7 |
2 files changed, 35 insertions, 2 deletions
diff --git a/src/helpers/read-saved-value.py b/src/helpers/read-saved-value.py new file mode 100755 index 000000000..1463e9ffe --- /dev/null +++ b/src/helpers/read-saved-value.py @@ -0,0 +1,30 @@ +#!/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.utils.config 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) diff --git a/src/init/vyos-router b/src/init/vyos-router index cc69fae5a..b8833a8a0 100755 --- a/src/init/vyos-router +++ b/src/init/vyos-router @@ -371,8 +371,11 @@ start () && chgrp ${GROUP} ${vyatta_configdir} log_action_end_msg $? - rm -f /etc/hostname - ${vyos_conf_scripts_dir}/host_name.py || log_failure_msg "could not reset host-name" + # T5239: early read of system hostname as this value is read-only once during + # FRR initialisation + tmp=$(${vyos_libexec_dir}/read-saved-value.py --path "system host-name") + hostnamectl set-hostname --static "$tmp" + ${vyos_conf_scripts_dir}/system_frr.py || log_failure_msg "could not reset FRR config" # If for any reason FRR was not started by system_frr.py - start it anyways. # This is a safety net! |