Development
This commit is contained in:
parent
a4652866c3
commit
27eaea3d73
19 changed files with 602 additions and 427 deletions
|
|
@ -159,7 +159,7 @@ def _resolve_iface(vlan, core):
|
|||
))
|
||||
idx = next((i for i, v in enumerate(wg_sorted) if v is vlan), 0)
|
||||
return f'wg{idx}'
|
||||
lan = core.get('general', {}).get('lan_interface', 'eth0')
|
||||
lan = core.get('network_interfaces', {}).get('lan_interface', 'eth0')
|
||||
vid = validate.derive_vlan_id(vlan.get('subnet', ''), vlan.get('subnet_mask', 24)) or 1
|
||||
return lan if vid == 1 else f'{lan}.{vid}'
|
||||
|
||||
|
|
@ -258,7 +258,7 @@ def _config_datasource(name):
|
|||
vlans = core.get('vlans', [])
|
||||
|
||||
if name == 'interfaces':
|
||||
gen = core.get('general', {})
|
||||
gen = core.get('network_interfaces', {})
|
||||
wan = gen.get('wan_interface', '')
|
||||
lan = gen.get('lan_interface', '')
|
||||
return [
|
||||
|
|
@ -274,7 +274,7 @@ def _config_datasource(name):
|
|||
|
||||
if name == 'blocklists':
|
||||
rows = []
|
||||
for bl in core.get('blocklists', []):
|
||||
for bl in core.get('dns_blocking', {}).get('blocklists', []):
|
||||
row = dict(bl)
|
||||
bl_path = f'{CONFIGS_DIR}/blocklists/{bl.get("save_as", "")}'
|
||||
try:
|
||||
|
|
@ -288,7 +288,7 @@ def _config_datasource(name):
|
|||
return rows
|
||||
|
||||
if name == 'vlans':
|
||||
bl_desc = {b['name']: b.get('description', b['name']) for b in core.get('blocklists', []) if 'name' in b}
|
||||
bl_desc = {b['name']: b.get('description', b['name']) for b in core.get('dns_blocking', {}).get('blocklists', []) if 'name' in b}
|
||||
rows = []
|
||||
for v in sorted(vlans, key=lambda x: validate.derive_vlan_id(x.get('subnet', ''), x.get('subnet_mask', 24)) or 0):
|
||||
row = {k: v.get(k) for k in ('name', 'subnet', 'subnet_mask', 'radius_default', 'mdns_reflection', 'is_vpn')}
|
||||
|
|
@ -421,7 +421,7 @@ def _bl_last_update():
|
|||
def _blocklist_stats_html(core):
|
||||
bl_dir = f'{CONFIGS_DIR}/blocklists'
|
||||
rows = ''
|
||||
for bl in core.get('blocklists', []):
|
||||
for bl in core.get('dns_blocking', {}).get('blocklists', []):
|
||||
name = e(bl.get('name', ''))
|
||||
save_as = bl.get('save_as', '')
|
||||
bl_path = f'{bl_dir}/{save_as}' if save_as else ''
|
||||
|
|
@ -557,18 +557,19 @@ def _vpn_info():
|
|||
def collect_tokens():
|
||||
tokens = {}
|
||||
core = _load_core()
|
||||
gen = core.get('general', {})
|
||||
net = core.get('network_interfaces', {})
|
||||
dns_blk_gen = core.get('dns_blocking', {}).get('general', {})
|
||||
dns = core.get('upstream_dns', {})
|
||||
vlans = core.get('vlans', [])
|
||||
tokens['GENERAL_WAN_INTERFACE'] = str(gen.get('wan_interface', '-'))
|
||||
tokens['GENERAL_LAN_INTERFACE'] = str(gen.get('lan_interface', '-'))
|
||||
tokens['GENERAL_WAN_STATUS'] = _iface_status(gen.get('wan_interface', ''))
|
||||
tokens['GENERAL_LAN_STATUS'] = _iface_status(gen.get('lan_interface', ''))
|
||||
tokens['GENERAL_LOG_MAX_KB'] = str(gen.get('log_max_kb', '-'))
|
||||
tokens['GENERAL_WAN_INTERFACE'] = str(net.get('wan_interface', '-'))
|
||||
tokens['GENERAL_LAN_INTERFACE'] = str(net.get('lan_interface', '-'))
|
||||
tokens['GENERAL_WAN_STATUS'] = _iface_status(net.get('wan_interface', ''))
|
||||
tokens['GENERAL_LAN_STATUS'] = _iface_status(net.get('lan_interface', ''))
|
||||
tokens['GENERAL_LOG_MAX_KB'] = str(dns_blk_gen.get('log_max_kb', '-'))
|
||||
|
||||
sys_ifaces = _get_system_interfaces()
|
||||
# Always include currently-configured values so dropdowns are never blank.
|
||||
for configured in [gen.get('wan_interface', ''), gen.get('lan_interface', '')]:
|
||||
for configured in [net.get('wan_interface', ''), net.get('lan_interface', '')]:
|
||||
if configured and configured not in sys_ifaces:
|
||||
sys_ifaces.append(configured)
|
||||
sys_ifaces.sort()
|
||||
|
|
@ -586,10 +587,10 @@ def collect_tokens():
|
|||
)
|
||||
tokens['NETWORK_INTERFACE_STATS_SPEED_PAD'] = str(max(max_speed_len, len('Speed')))
|
||||
|
||||
tokens['GENERAL_LOG_ERRORS_ONLY'] = 'true' if gen.get('log_errors_only') else 'false'
|
||||
tokens['GENERAL_DNSMASQ_LOG_QUERIES'] = 'true' if gen.get('dnsmasq_log_queries') else 'false'
|
||||
tokens['GENERAL_DAILY_EXECUTE_TIME'] = str(gen.get('daily_execute_time_24hr_local', '-'))
|
||||
tokens['GENERAL_APPLY_ON_SAVE'] = 'true' if gen.get('apply_on_save', True) else 'false'
|
||||
tokens['GENERAL_LOG_ERRORS_ONLY'] = 'true' if dns_blk_gen.get('log_errors_only') else 'false'
|
||||
tokens['GENERAL_DNSMASQ_LOG_QUERIES'] = 'true' if net.get('dnsmasq_log_queries') else 'false'
|
||||
tokens['GENERAL_DAILY_EXECUTE_TIME'] = str(dns_blk_gen.get('daily_execute_time_24hr_local', '-'))
|
||||
tokens['GENERAL_APPLY_ON_SAVE'] = 'true' if net.get('apply_on_save', True) else 'false'
|
||||
|
||||
pending_items = get_dashboard_pending()
|
||||
if pending_items:
|
||||
|
|
@ -645,7 +646,7 @@ def collect_tokens():
|
|||
tokens['EXISTING_VLAN_NAMES_JSON'] = json.dumps([v.get('name', '') for v in vlans])
|
||||
tokens['EXISTING_VLAN_INTERFACES_JSON'] = json.dumps([_resolve_iface(v, core) for v in vlans])
|
||||
tokens['STAT_BANNED_IP_COUNT'] = str(sum(1 for b in core.get('banned_ips', []) if b.get('enabled', True)))
|
||||
tokens['STAT_BLOCKLIST_COUNT'] = str(len(core.get('blocklists', [])))
|
||||
tokens['STAT_BLOCKLIST_COUNT'] = str(len(core.get('dns_blocking', {}).get('blocklists', [])))
|
||||
tokens['BLOCKLIST_STATS_HTML'] = _blocklist_stats_html(core)
|
||||
|
||||
ddns = _load_ddns()
|
||||
|
|
@ -745,7 +746,7 @@ def collect_tokens():
|
|||
|
||||
tokens['BLOCKLIST_NAME_OPTIONS'] = json.dumps([
|
||||
{'value': bl.get('name', ''), 'label': bl.get('description', bl.get('name', ''))}
|
||||
for bl in core.get('blocklists', [])
|
||||
for bl in core.get('dns_blocking', {}).get('blocklists', [])
|
||||
])
|
||||
|
||||
tokens['ACCOUNT_LEVEL_OPTIONS'] = json.dumps([
|
||||
|
|
@ -1542,7 +1543,7 @@ def render_layout(view_id, content_html, tokens):
|
|||
problem_bars = ''
|
||||
try:
|
||||
import json as _j
|
||||
st = _j.load(open(f'{CONFIGS_DIR}/.status'))
|
||||
st = _j.load(open(f'{CONFIGS_DIR}/.health'))
|
||||
grouped = {'error': [], 'warning': []}
|
||||
for section in ('configurations', 'logs'):
|
||||
for item in st.get(section, []):
|
||||
|
|
@ -2449,7 +2450,7 @@ function startApplyPoller(uuid, bar, mine) {
|
|||
}
|
||||
|
||||
function doPoll() {
|
||||
fetch('/api/apply-status?uuid=' + encodeURIComponent(uuid))
|
||||
fetch('/api/apply-health?uuid=' + encodeURIComponent(uuid))
|
||||
.then(function(r) { return r.json(); })
|
||||
.then(onStatus)
|
||||
.catch(function() { pollTimer = setTimeout(doPoll, 3000); });
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue