A-Ops/0003-fix-server-startup-error.patch
gongzt b9bbe78321 fix server startup and check code
(cherry picked from commit 61fd2ce58e13735eb1fb03f42c1b094c7f8f1921)
2023-09-14 15:11:42 +08:00

107 lines
3.9 KiB
Diff

From 44f16e2e840516cb4b0ce50d63e25db744451f2c Mon Sep 17 00:00:00 2001
From: smjiao <smjiao@isoftstone.com>
Date: Thu, 14 Sep 2023 11:02:05 +0800
Subject: fix server startup error
MIME-Version: 1.0
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: 8bit
---
.../ragdoll/const/conf_handler_const.py | 8 +++
.../ragdoll/controllers/confs_controller.py | 56 +++++++++++++++++++
2 files changed, 64 insertions(+)
diff --git a/gala-ragdoll/ragdoll/const/conf_handler_const.py b/gala-ragdoll/ragdoll/const/conf_handler_const.py
index 8ef5ca6..6780dfe 100644
--- a/gala-ragdoll/ragdoll/const/conf_handler_const.py
+++ b/gala-ragdoll/ragdoll/const/conf_handler_const.py
@@ -16,5 +16,13 @@
@Author: JiaoSiMao
Description:
"""
+import re
+
NOT_SYNCHRONIZE = "NOT SYNCHRONIZE"
SYNCHRONIZED = "SYNCHRONIZED"
+LIMITS_DOMAIN_RE = re.compile('(^[*]$)|(^[@|0-9A-Za-z]+[0-9A-Za-z]$)')
+LIMITS_TYPE_VALUE = "soft|hard|-|"
+LIMITS_ITEM_VALUE = "core|data|fsize|memlock|nofile|rss|stack|cpu|nproc|as|maxlogins|maxsyslogins|priority|locks|sigpending|" \
+ "msgqueue|nice|rtprio|"
+RESOLV_KEY_VALUE = "nameserver|domain|search|sortlist|"
+FSTAB_COLUMN_NUM = 6
\ No newline at end of file
diff --git a/gala-ragdoll/ragdoll/controllers/confs_controller.py b/gala-ragdoll/ragdoll/controllers/confs_controller.py
index 814c875..7703c7c 100644
--- a/gala-ragdoll/ragdoll/controllers/confs_controller.py
+++ b/gala-ragdoll/ragdoll/controllers/confs_controller.py
@@ -27,6 +27,7 @@ from ragdoll.utils.conf_tools import ConfTools
from ragdoll.utils.host_tools import HostTools
from ragdoll.utils.object_parse import ObjectParse
from ragdoll import util
+from ragdoll.const.conf_files import yang_conf_list
TARGETDIR = GitTools().target_dir
@@ -509,3 +510,58 @@ def sync_conf_to_host_from_domain(body=None): # noqa: E501
sync_res.append(host_sync_result)
return sync_res
+
+def query_supported_confs(body=None):
+ """
+ query supported configuration list # noqa: E501
+
+ :param body:
+ :type body: dict | bytes
+
+ :rtype: List
+ """
+ if connexion.request.is_json:
+ body = DomainName.from_dict(connexion.request.get_json())
+
+ domain = body.domain_name
+
+ check_res = Format.domainCheck(domain)
+ if not check_res:
+ code_num = 400
+ base_rsp = BaseResponse(code_num, "Failed to verify the input parameter, please check the input parameters.")
+ return base_rsp, code_num
+
+ is_exist = Format.isDomainExist(domain)
+ if not is_exist:
+ code_num = 404
+ base_rsp = BaseResponse(code_num, "The current domain does not exist, please create the domain first.")
+ return base_rsp, code_num
+
+ conf_tools = ConfTools()
+ port = conf_tools.load_port_by_conf()
+ url = "http://0.0.0.0:" + port + "/management/getManagementConf"
+ headers = {"Content-Type": "application/json"}
+ get_man_conf_body = DomainName(domain_name=domain)
+ print("body is : {}".format(get_man_conf_body))
+ response = requests.post(url, data=json.dumps(get_man_conf_body), headers=headers) # post request
+ print("response is : {}".format(response.text))
+ res_code = response.status_code
+ res_json = json.loads(response.text)
+ print("return code is : {}".format(response.status_code))
+
+ if res_code != 200:
+ code_num = res_code
+ base_rsp = BaseResponse(code_num,
+ "Failed to query the configuration items managed in the current domain. " +
+ "The failure reason is:" + res_json)
+ return base_rsp, code_num
+
+ conf_files = res_json.get("confFiles")
+ if len(conf_files) == 0:
+ return yang_conf_list
+
+ exist_conf_list = []
+ for conf in conf_files:
+ exist_conf_list.append(conf.get('filePath'))
+
+ return list(set(yang_conf_list).difference(set(exist_conf_list)))
--
2.37.1.windows.1