summaryrefslogtreecommitdiff
path: root/src/services
diff options
context:
space:
mode:
authorzdc <zdc@users.noreply.github.com>2019-11-17 19:10:30 +0200
committerChristian Poessinger <christian@poessinger.com>2019-11-17 18:10:30 +0100
commit4e4f1dbd745952a24d70c3e2d7dc495d675dff34 (patch)
treea259b86cf1b8ded71f126ec58c3c55bfe87f0a5f /src/services
parent1f7b0412316d0d3a308fca77c3a2bd0119287319 (diff)
downloadvyos-1x-4e4f1dbd745952a24d70c3e2d7dc495d675dff34.tar.gz
vyos-1x-4e4f1dbd745952a24d70c3e2d7dc495d675dff34.zip
dns: T1786: add proper processing of 'system disable-dhcp-nameservers'
Diffstat (limited to 'src/services')
-rwxr-xr-xsrc/services/vyos-hostsd16
1 files changed, 7 insertions, 9 deletions
diff --git a/src/services/vyos-hostsd b/src/services/vyos-hostsd
index 5c2ea71c8..5fb7a68ab 100755
--- a/src/services/vyos-hostsd
+++ b/src/services/vyos-hostsd
@@ -22,6 +22,7 @@ import time
import json
import signal
import traceback
+import re
import zmq
@@ -154,14 +155,10 @@ def add_name_servers(data, entries, tag):
def delete_name_servers(data, tag):
name_servers = data['name_servers']
- keys_for_deletion = []
-
- for ns in name_servers:
- if name_servers[ns]['tag'] == tag:
- keys_for_deletion.append(ns)
-
- for k in keys_for_deletion:
- del name_servers[k]
+ regex_filter = re.compile(tag)
+ for ns in list(name_servers.keys()):
+ if regex_filter.match(name_servers[ns]['tag']):
+ del name_servers[ns]
def set_host_name(state, data):
if data['host_name']:
@@ -174,8 +171,9 @@ def set_host_name(state, data):
def get_name_servers(state, tag):
ns = []
data = state['name_servers']
+ regex_filter = re.compile(tag)
for n in data:
- if data[n]['tag'] == tag:
+ if regex_filter.match(data[n]['tag']):
ns.append(n)
return ns