diff options
| author | Nataliia Solomko <natalirs1985@gmail.com> | 2024-12-11 16:48:43 +0200 | 
|---|---|---|
| committer | Nataliia Solomko <natalirs1985@gmail.com> | 2024-12-11 16:48:43 +0200 | 
| commit | a7be3c684f6e78bb9fce23948d1d3a794febe29a (patch) | |
| tree | 829c6c91a239aa493be8ba88509f3e9ab2732558 | |
| parent | 03a664a5a1f57ffcb9467434c4939f8be7e1860b (diff) | |
| download | vyos-1x-a7be3c684f6e78bb9fce23948d1d3a794febe29a.tar.gz vyos-1x-a7be3c684f6e78bb9fce23948d1d3a794febe29a.zip | |
op_mode: T6767: Check latest image version in VRF context for "add system image latest vrf <name>"
| -rw-r--r-- | python/vyos/utils/process.py | 4 | ||||
| -rwxr-xr-x | src/helpers/latest-image-url.py | 21 | ||||
| -rwxr-xr-x | src/op_mode/image_installer.py | 28 | 
3 files changed, 39 insertions, 14 deletions
| diff --git a/python/vyos/utils/process.py b/python/vyos/utils/process.py index ce880f4a4..d8aabb822 100644 --- a/python/vyos/utils/process.py +++ b/python/vyos/utils/process.py @@ -128,7 +128,7 @@ def run(command, flag='', shell=None, input=None, timeout=None, env=None,  def cmd(command, flag='', shell=None, input=None, timeout=None, env=None,          stdout=PIPE, stderr=PIPE, decode='utf-8', raising=None, message='', -        expect=[0]): +        expect=[0], auth=''):      """      A wrapper around popen, which returns the stdout and      will raise the error code of a command @@ -139,7 +139,7 @@ def cmd(command, flag='', shell=None, input=None, timeout=None, env=None,      expect:  a list of error codes to consider as normal      """      decoded, code = popen( -        command, flag, +        f'{auth} {command}'.strip(), flag,          stdout=stdout, stderr=stderr,          input=input, timeout=timeout,          env=env, shell=shell, diff --git a/src/helpers/latest-image-url.py b/src/helpers/latest-image-url.py new file mode 100755 index 000000000..ea201ef7c --- /dev/null +++ b/src/helpers/latest-image-url.py @@ -0,0 +1,21 @@ +#!/usr/bin/env python3 + +import sys + +from vyos.configquery import ConfigTreeQuery +from vyos.version import get_remote_version + + +if __name__ == '__main__': +    image_path = '' + +    config = ConfigTreeQuery() +    if config.exists('system update-check url'): +        configured_url_version = config.value('system update-check url') +        remote_url_list = get_remote_version(configured_url_version) +        if remote_url_list: +            image_path = remote_url_list[0].get('url') +        else: +            sys.exit(1) + +    print(image_path) diff --git a/src/op_mode/image_installer.py b/src/op_mode/image_installer.py index bdc16de15..1da112673 100755 --- a/src/op_mode/image_installer.py +++ b/src/op_mode/image_installer.py @@ -33,14 +33,13 @@ from errno import ENOSPC  from psutil import disk_partitions  from vyos.configtree import ConfigTree -from vyos.configquery import ConfigTreeQuery  from vyos.remote import download  from vyos.system import disk, grub, image, compat, raid, SYSTEM_CFG_VER  from vyos.template import render  from vyos.utils.io import ask_input, ask_yes_no, select_entry  from vyos.utils.file import chmod_2775 -from vyos.utils.process import cmd, run -from vyos.version import get_remote_version, get_version_data +from vyos.utils.process import cmd, run, rc_cmd +from vyos.version import get_version_data  # define text messages  MSG_ERR_NOT_LIVE: str = 'The system is already installed. Please use "add system image" instead.' @@ -99,6 +98,7 @@ FILE_ROOTFS_SRC: str = '/usr/lib/live/mount/medium/live/filesystem.squashfs'  ISO_DOWNLOAD_PATH: str = '/tmp/vyos_installation.iso'  external_download_script = '/usr/libexec/vyos/simple-download.py' +external_latest_image_url_script = '/usr/libexec/vyos/latest-image-url.py'  # default boot variables  DEFAULT_BOOT_VARS: dict[str, str] = { @@ -532,10 +532,10 @@ def download_file(local_file: str, remote_path: str, vrf: str,          download(local_file, remote_path, progressbar=progressbar,                   check_space=check_space, raise_error=True)      else: -        vrf_cmd = f'REMOTE_USERNAME={username} REMOTE_PASSWORD={password} \ -                ip vrf exec {vrf} {external_download_script} \ -                --local-file {local_file} --remote-path {remote_path}' -        cmd(vrf_cmd) +        remote_auth = f'REMOTE_USERNAME={username} REMOTE_PASSWORD={password}' +        vrf_cmd = f'ip vrf exec {vrf} {external_download_script} \ +                    --local-file {local_file} --remote-path {remote_path}' +        cmd(vrf_cmd, auth=remote_auth)  def image_fetch(image_path: str, vrf: str = None,                  username: str = '', password: str = '', @@ -550,11 +550,15 @@ def image_fetch(image_path: str, vrf: str = None,      """      # Latest version gets url from configured "system update-check url"      if image_path == 'latest': -        config = ConfigTreeQuery() -        if config.exists('system update-check url'): -            configured_url_version = config.value('system update-check url') -            remote_url_list = get_remote_version(configured_url_version) -            image_path = remote_url_list[0].get('url') +        command = external_latest_image_url_script +        if vrf: +            command = f'REMOTE_USERNAME={username} REMOTE_PASSWORD={password} \ +                        ip vrf exec {vrf} ' + command +        code, output = rc_cmd(command) +        if code: +            print(output) +            exit(MSG_INFO_INSTALL_EXIT) +        image_path = output if output else image_path      try:          # check a type of path | 
