<%# Copyright 2016-2017 Dan Luedtke Licensed to the public under the Apache License 2.0. -%> <% function strip(s) return (s:gsub("^%s*(.-)%s*$", "%1")) end function is_valid(s) return (string.len(strip(s)) > 0) end function peer_add(peers, public_key) table.insert(peers, { public_key = public_key, endpoint = "", transfer_rx = 0, transfer_tx = 0, latest_handshake = -1, persistent_keepalive = "", allowed_ips = { } }) end function peer_set_transfer(peers, public_key, rx, tx) for key, peer in pairs(peers) do if peer.public_key == public_key then peers[key].transfer_rx = rx peers[key].transfer_tx = tx break end end end function peer_set_latest_handshake(peers, public_key, latest_handshake) for key, peer in pairs(peers) do if peer.public_key == public_key then peers[key].latest_handshake = latest_handshake break end end end function peer_set_endpoint(peers, public_key, endpoint) for key, peer in pairs(peers) do if peer.public_key == public_key then peers[key].endpoint = endpoint break end end end function peer_set_persistent_keepalive(peers, public_key, persistent_keepalive) for key, peer in pairs(peers) do if peer.public_key == public_key then peers[key].persistent_keepalive = persistent_keepalive break end end end function peer_set_allowed_ips(peers, public_key, allowed_ips) for key, peer in pairs(peers) do if peer.public_key == public_key then for ipkey, ipvalue in pairs(string.split(allowed_ips, " ")) do if is_valid(ipvalue) then table.insert(peers[key].allowed_ips, strip(ipvalue)) end end break end end end local data = { } local wg_ifaces = luci.sys.exec("wg show interfaces") for key, name in pairs(string.split(wg_ifaces, "\n")) do if not is_valid(name) then break end name = strip(name) local public_key = luci.sys.exec("wg show \"" .. name .. "\" public-key") local listening_port = luci.sys.exec("wg show \"" .. name .. "\" listen-port") local peers = { } local wg_peers = luci.sys.exec("wg show \"" .. name .. "\" peers") for key, public_key in pairs(string.split(wg_peers, "\n")) do if not is_valid(public_key) then break end peer_add(peers, public_key) end local wg_endpoints = luci.sys.exec("wg show \"" .. name .. "\" endpoints") for key, endpoint in pairs(string.split(wg_endpoints, "\n")) do if not is_valid(endpoint) then break end local ln = string.split(strip(endpoint), "\t") peer_set_endpoint(peers, ln[1], strip(ln[2])) end local wg_allowed_ips = luci.sys.exec("wg show \"" .. name .. "\" allowed-ips") for key, allowed_ips in pairs(string.split(wg_allowed_ips, "\n")) do if not is_valid(allowed_ips) then break end local ln = string.split(strip(allowed_ips), "\t", 2) peer_set_allowed_ips(peers, ln[1], strip(ln[2])) end local wg_persistent_keepalives = luci.sys.exec("wg show \"" .. name .. "\" persistent-keepalive") for key, persistent_keepalive in pairs(string.split(wg_persistent_keepalives, "\n")) do if not is_valid(persistent_keepalive) then break end local ln = string.split(strip(persistent_keepalive), "\t") peer_set_persistent_keepalive(peers, strip(ln[1]), strip(ln[2])) end local wg_latest_handshakes = luci.sys.exec("wg show \"" .. name .. "\" latest-handshakes") for key, latest_handshake in pairs(string.split(wg_latest_handshakes, "\n")) do if not is_valid(latest_handshake) then break end local ln = string.split(strip(latest_handshake), "\t") peer_set_latest_handshake(peers, strip(ln[1]), tonumber(ln[2])) end local wg_transfers = luci.sys.exec("wg show \"" .. name .. "\" transfer") for key, transfer in pairs(string.split(wg_transfers, "\n")) do if not is_valid(transfer) then break end local ln = string.split(strip(transfer), "\t") peer_set_transfer(peers, ln[1], strip(ln[2]), strip(ln[3])) end table.insert(data, { name = name, public_key = strip(public_key), listening_port = tonumber(strip(listening_port)), peers = peers }) end if luci.http.formvalue("status") == "1" then luci.http.prepare_content("application/json") luci.http.write_json(data) return end -%> <%+header%>

WireGuard Status

<%- for key, iface in pairs(data) do local ifid = iface.public_key .. "_" -%> <%:Interface%> <%=iface.name%> <%- for key, peer in pairs(iface.peers) do local pid = ifid .. peer.public_key .. "_" -%> <%- end -%>
<%:Configuration%>
  <%:Collecting data...%>
<%:Peer%>

?
<%:Collecting data...%>
<%- end -%>
<%+footer%>