diff options
| author | John Estabrook <jestabro@vyos.io> | 2024-02-27 14:54:50 -0600 | 
|---|---|---|
| committer | John Estabrook <jestabro@vyos.io> | 2024-02-28 14:02:49 -0600 | 
| commit | 70e1df1b5fcb3b1791cca320ed45b71e01e1ffda (patch) | |
| tree | 66e586d26f2ab77144adcd341da14c854bdd0795 /src | |
| parent | 5c173c5935eab3a8bd0f169759617c4296a92df7 (diff) | |
| download | vyos-1x-70e1df1b5fcb3b1791cca320ed45b71e01e1ffda.tar.gz vyos-1x-70e1df1b5fcb3b1791cca320ed45b71e01e1ffda.zip | |
configdep: T5660: remove global redundancies under vyos-configd
Diffstat (limited to 'src')
| -rwxr-xr-x | src/services/vyos-configd | 19 | ||||
| -rw-r--r-- | src/shim/vyshim.c | 12 | 
2 files changed, 26 insertions, 5 deletions
| diff --git a/src/services/vyos-configd b/src/services/vyos-configd index 355182b26..648a017d5 100755 --- a/src/services/vyos-configd +++ b/src/services/vyos-configd @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2020-2023 VyOS maintainers and contributors +# Copyright (C) 2020-2024 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 @@ -19,6 +19,7 @@ import sys  import grp  import re  import json +import typing  import logging  import signal  import importlib.util @@ -29,6 +30,7 @@ from vyos.defaults import directories  from vyos.utils.boot import boot_configuration_complete  from vyos.configsource import ConfigSourceString  from vyos.configsource import ConfigSourceError +from vyos.configdep import call_dependents  from vyos.config import Config  from vyos import ConfigError @@ -198,10 +200,12 @@ def initialization(socket):          return None      config = Config(config_source=configsource) +    dependent_func: dict[str, list[typing.Callable]] = {} +    setattr(config, 'dependent_func', dependent_func)      return config -def process_node_data(config, data) -> int: +def process_node_data(config, data, last: bool = False) -> int:      if not config:          logger.critical(f"Empty config")          return R_ERROR_DAEMON @@ -223,11 +227,18 @@ def process_node_data(config, data) -> int:      args.insert(0, f'{script_name}.py')      if script_name not in include_set: +        # call dependents now if last element of prio queue is run +        # independent of configd +        if last: +            call_dependents(dependent_func=config.dependent_func)          return R_PASS      with stdout_redirected(session_out, session_mode):          result = run_script(conf_mode_scripts[script_name], config, args) +    if last: +        call_dependents(dependent_func=config.dependent_func) +      return result  def remove_if_file(f: str): @@ -281,7 +292,9 @@ if __name__ == '__main__':              socket.send(resp.encode())              config = initialization(socket)          elif message["type"] == "node": -            res = process_node_data(config, message["data"]) +            if message["last"]: +                logger.debug(f'final element of priority queue') +            res = process_node_data(config, message["data"], message["last"])              response = res.to_bytes(1, byteorder=sys.byteorder)              logger.debug(f"Sending response {res}")              socket.send(response) diff --git a/src/shim/vyshim.c b/src/shim/vyshim.c index cae8b6152..41723e7a4 100644 --- a/src/shim/vyshim.c +++ b/src/shim/vyshim.c @@ -1,5 +1,5 @@  /* - * Copyright (C) 2020 VyOS maintainers and contributors + * Copyright (C) 2020-2024 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 @@ -49,6 +49,7 @@  #define GET_SESSION "cli-shell-api --show-working-only --show-show-defaults --show-ignore-edit showConfig"  #define COMMIT_MARKER "/var/tmp/initial_in_commit" +#define QUEUE_MARKER "/var/tmp/last_in_queue"  enum {      SUCCESS =      1 << 0, @@ -77,6 +78,7 @@ int main(int argc, char* argv[])      int ex_index;      int init_timeout = 0; +    int last = 0;      debug_print("Connecting to vyos-configd ...\n");      zmq_connect(requester, SOCKET_PATH); @@ -101,10 +103,16 @@ int main(int argc, char* argv[])          return ret;      } +    if (access(QUEUE_MARKER, F_OK) != -1) { +        last = 1; +        remove(QUEUE_MARKER); +    } +      char error_code[1];      debug_print("Sending node data ...\n"); -    char *string_node_data_msg = mkjson(MKJSON_OBJ, 2, +    char *string_node_data_msg = mkjson(MKJSON_OBJ, 3,                                          MKJSON_STRING, "type", "node", +                                        MKJSON_BOOL, "last", last,                                          MKJSON_STRING, "data", &string_node_data[0]);      zmq_send(requester, string_node_data_msg, strlen(string_node_data_msg), 0); | 
