Merge branch 'develop' into coretk-enhance/gui-logging
This commit is contained in:
commit
b7206fe7b9
4 changed files with 56 additions and 0 deletions
|
@ -61,6 +61,9 @@ class CoreEmu:
|
|||
self.service_manager = ConfigServiceManager()
|
||||
config_services_path = os.path.abspath(os.path.dirname(configservices.__file__))
|
||||
self.service_manager.load(config_services_path)
|
||||
custom_dir = self.config.get("custom_config_services_dir")
|
||||
if custom_dir:
|
||||
self.service_manager.load(custom_dir)
|
||||
|
||||
# catch exit event
|
||||
atexit.register(self.shutdown)
|
||||
|
|
|
@ -222,6 +222,7 @@ class LinuxNetClient:
|
|||
self.run(f"{IP_BIN} link set {name} type bridge stp_state 0")
|
||||
self.run(f"{IP_BIN} link set {name} type bridge forward_delay 0")
|
||||
self.run(f"{IP_BIN} link set {name} type bridge mcast_snooping 0")
|
||||
self.run(f"{IP_BIN} link set {name} type bridge group_fwd_mask 65528")
|
||||
self.device_up(name)
|
||||
|
||||
def delete_bridge(self, name: str) -> None:
|
||||
|
|
|
@ -14,6 +14,7 @@ frr_sbin_search = "/usr/local/sbin /usr/sbin /usr/lib/frr"
|
|||
# this may be a comma-separated list, and directory names should be unique
|
||||
# and not named 'services'
|
||||
#custom_services_dir = /home/username/.core/myservices
|
||||
#custom_config_services_dir = /home/username/.coretk/custom_services
|
||||
|
||||
# uncomment to establish a standalone control backchannel for accessing nodes
|
||||
# (overriden by the session option of the same name)
|
||||
|
|
51
daemon/scripts/core-service-update
Executable file
51
daemon/scripts/core-service-update
Executable file
|
@ -0,0 +1,51 @@
|
|||
#!/usr/bin/env python
|
||||
import argparse
|
||||
import re
|
||||
from io import TextIOWrapper
|
||||
|
||||
|
||||
def parse_args() -> argparse.Namespace:
|
||||
parser = argparse.ArgumentParser(
|
||||
description=f"Helps transition older CORE services to work with newer versions")
|
||||
parser.add_argument("-f", "--file", dest="file", type=argparse.FileType("r"),
|
||||
help=f"service file to update")
|
||||
return parser.parse_args()
|
||||
|
||||
|
||||
def update_service(service_file: TextIOWrapper) -> None:
|
||||
update = []
|
||||
for line in service_file.readlines():
|
||||
# update service attributes
|
||||
line = re.sub(r"^(\s+)_([a-z])", r"\1\2", line)
|
||||
# rename dirs to directories
|
||||
line = re.sub(r"^(\s+)dirs", r"\1directories", line)
|
||||
# fix import states for service
|
||||
line = re.sub(r"^.+import.+CoreService.+$",
|
||||
r"from core.services.coreservices import CoreService", line)
|
||||
# fix method signatures
|
||||
line = re.sub(r"def generateconfig\(cls, node, filename, services\)",
|
||||
r"def generate_config(cls, node, filename)", line)
|
||||
line = re.sub(r"def getvalidate\(cls, node, services\)",
|
||||
r"def get_validate(cls, node)", line)
|
||||
line = re.sub(r"def getstartup\(cls, node, services\)",
|
||||
r"def get_startup(cls, node)", line)
|
||||
line = re.sub(r"def getconfigfilenames\(cls, nodenum, services\)",
|
||||
r"def get_configs(cls, node)", line)
|
||||
# remove unwanted lines
|
||||
if re.search(r"addservice\(", line):
|
||||
continue
|
||||
if re.search(r"from.+\.ipaddr|import ipaddr", line):
|
||||
continue
|
||||
if re.search(r"from.+\.ipaddress|import ipaddress", line):
|
||||
continue
|
||||
# add modified line to make updated copy
|
||||
update.append(line)
|
||||
service_file.close()
|
||||
|
||||
with open(f"{service_file.name}.update", "w") as f:
|
||||
f.writelines(update)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
args = parse_args()
|
||||
update_service(args.file)
|
Loading…
Add table
Reference in a new issue