From 7a27726e0e1e1de47f8abfb64e9c28eadb34c55b Mon Sep 17 00:00:00 2001 From: Dmytro Aleksandrov Date: Sat, 18 Aug 2018 00:43:12 +0300 Subject: T784: Added update dns dynamic operation --- src/op_mode/dynamic_dns.py | 92 +++++++++++++++++++++++++++++++++++++++ src/op_mode/dynamic_dns_status.py | 67 ---------------------------- 2 files changed, 92 insertions(+), 67 deletions(-) create mode 100755 src/op_mode/dynamic_dns.py delete mode 100755 src/op_mode/dynamic_dns_status.py (limited to 'src/op_mode') diff --git a/src/op_mode/dynamic_dns.py b/src/op_mode/dynamic_dns.py new file mode 100755 index 000000000..7ac3dfe9f --- /dev/null +++ b/src/op_mode/dynamic_dns.py @@ -0,0 +1,92 @@ +#!/usr/bin/env python3 +import os +import argparse +import jinja2 +import sys +import time + +from vyos.config import Config + +cache_file = r'/var/cache/ddclient/ddclient.cache' + +OUT_TMPL_SRC = """ +{%- for entry in hosts -%} +ip address : {{ entry.ip }} +host-name : {{ entry.host }} +last update : {{ entry.time }} +update-status: {{ entry.status }} + +{% endfor -%} +""" + + +def show_status(): + # Do nothing if service is not configured + c = Config() + if not c.exists_effective('service dns dynamic'): + print("Dynamic DNS not configured") + sys.exit(0) + + data = { + 'hosts': [] + } + + with open(cache_file, 'r') as f: + for line in f: + if line.startswith('#'): + continue + + outp = { + 'host': '', + 'ip': '', + 'time': '' + } + + if 'host=' in line: + host = line.split('host=')[1] + if host: + outp['host'] = host.split(',')[0] + + if 'ip=' in line: + ip = line.split('ip=')[1] + if ip: + outp['ip'] = ip.split(',')[0] + + if 'atime=' in line: + atime = line.split('atime=')[1] + if atime: + tmp = atime.split(',')[0] + outp['time'] = time.strftime("%Y-%m-%d %H:%M:%S", time.gmtime(int(tmp, base=10))) + + if 'status=' in line: + status = line.split('status=')[1] + if status: + outp['status'] = status.split(',')[0] + + data['hosts'].append(outp) + + tmpl = jinja2.Template(OUT_TMPL_SRC) + print(tmpl.render(data)) + + +def update_ddns(): + os.system('systemctl stop ddclient') + os.remove(cache_file) + os.system('systemctl start ddclient') + + +def main(): + parser = argparse.ArgumentParser() + group = parser.add_mutually_exclusive_group() + group.add_argument("--status", help="Show DDNS status", action="store_true") + group.add_argument("--update", help="Update DDNS on a given interface", action="store_true") + args = parser.parse_args() + + if args.status: + show_status() + elif args.update: + update_ddns() + + +if __name__ == '__main__': + main() diff --git a/src/op_mode/dynamic_dns_status.py b/src/op_mode/dynamic_dns_status.py deleted file mode 100755 index bbff01f49..000000000 --- a/src/op_mode/dynamic_dns_status.py +++ /dev/null @@ -1,67 +0,0 @@ -#!/usr/bin/env python3 - -import jinja2 -import sys -import time - -from vyos.config import Config - -cache_file = r'/var/cache/ddclient/ddclient.cache' - -OUT_TMPL_SRC = """ -{%- for entry in hosts -%} -ip address : {{ entry.ip }} -host-name : {{ entry.host }} -last update : {{ entry.time }} -update-status: {{ entry.status }} - -{% endfor -%} -""" - -if __name__ == '__main__': - # Do nothing if service is not configured - c = Config() - if not c.exists_effective('service dns dynamic'): - print("Dynamic DNS not configured") - sys.exit(0) - - data = { - 'hosts': [] - } - - with open(cache_file, 'r') as f: - for line in f: - if line.startswith('#'): - continue - - outp = { - 'host': '', - 'ip': '', - 'time': '' - } - - if 'host=' in line: - host = line.split('host=')[1] - if host: - outp['host'] = host.split(',')[0] - - if 'ip=' in line: - ip = line.split('ip=')[1] - if ip: - outp['ip'] = ip.split(',')[0] - - if 'atime=' in line: - atime = line.split('atime=')[1] - if atime: - tmp = atime.split(',')[0] - outp['time'] = time.strftime("%Y-%m-%d %H:%M:%S", time.gmtime(int(tmp, base=10))) - - if 'status=' in line: - status = line.split('status=')[1] - if status: - outp['status'] = status.split(',')[0] - - data['hosts'].append(outp) - - tmpl = jinja2.Template(OUT_TMPL_SRC) - print(tmpl.render(data)) -- cgit v1.2.3 From 55ee5d903817e3a80fb6272d790dcce1044f8a9b Mon Sep 17 00:00:00 2001 From: Runar Borge Date: Sun, 19 Aug 2018 22:25:34 +0200 Subject: T689: Reboot/Poweroff now not working after last changes --- op-mode-definitions/poweroff.xml | 4 ++-- op-mode-definitions/reboot.xml | 4 ++-- src/op_mode/powerctrl.py | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) (limited to 'src/op_mode') diff --git a/op-mode-definitions/poweroff.xml b/op-mode-definitions/poweroff.xml index ff27f4f4d..e2483fefc 100644 --- a/op-mode-definitions/poweroff.xml +++ b/op-mode-definitions/poweroff.xml @@ -4,14 +4,14 @@ Poweroff the system - sudo ${vyos_op_scripts_dir}/powerctrl.py --poweroff now + sudo ${vyos_op_scripts_dir}/powerctrl.py --poweroff Poweroff the system without confirmation - sudo ${vyos_op_scripts_dir}/powerctrl.py --yes --poweroff now + sudo ${vyos_op_scripts_dir}/powerctrl.py --yes --poweroff diff --git a/op-mode-definitions/reboot.xml b/op-mode-definitions/reboot.xml index 340c8ca82..affdffd98 100644 --- a/op-mode-definitions/reboot.xml +++ b/op-mode-definitions/reboot.xml @@ -4,14 +4,14 @@ Reboot the system - sudo ${vyos_op_scripts_dir}/powerctrl.py --reboot now + sudo ${vyos_op_scripts_dir}/powerctrl.py --reboot Reboot the system without confirmation - sudo ${vyos_op_scripts_dir}/powerctrl.py --yes --reboot now + sudo ${vyos_op_scripts_dir}/powerctrl.py --yes --reboot diff --git a/src/op_mode/powerctrl.py b/src/op_mode/powerctrl.py index f73d6c005..8a66b3afd 100755 --- a/src/op_mode/powerctrl.py +++ b/src/op_mode/powerctrl.py @@ -126,9 +126,9 @@ def main(): args = parser.parse_args() try: - if args.reboot: + if args.reboot is not None: execute_shutdown(args.reboot, reboot=True, ask=args.yes) - if args.poweroff: + if args.poweroff is not None: execute_shutdown(args.poweroff, reboot=False,ask=args.yes) if args.cancel: cancel_shutdown() -- cgit v1.2.3