diff options
author | Christian Breunig <christian@breunig.cc> | 2023-09-19 20:38:52 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-09-19 20:38:52 +0200 |
commit | 483482f16133d5aa61b07a88cca5bce7bb7776f8 (patch) | |
tree | 0e54ea3bb667a425214f04aeb9d0b3b79faa71c7 /src | |
parent | db53c8e77cd93d5d7f16036b4d7b783083caf32e (diff) | |
parent | ac21a4e69fac27504b62927a20d0a6a273abb034 (diff) | |
download | vyos-1x-483482f16133d5aa61b07a88cca5bce7bb7776f8.tar.gz vyos-1x-483482f16133d5aa61b07a88cca5bce7bb7776f8.zip |
Merge pull request #2289 from c-po/t5239-frr
init: T5239: configure system hostname prior to FRR startup
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 9ef1fa335..dd07d2e4b 100755 --- a/src/init/vyos-router +++ b/src/init/vyos-router @@ -374,8 +374,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! |