mirror of
https://github.com/kenzok8/small-package
synced 2025-01-08 13:27:36 +08:00
update 2022-06-20 23:47:51
This commit is contained in:
parent
5dbb7c1cd7
commit
7cfeafd2f7
@ -7,7 +7,7 @@ include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=adguardhome
|
||||
PKG_VERSION:=0.107.7
|
||||
PKG_RELEASE:=54
|
||||
PKG_RELEASE:=55
|
||||
|
||||
PKG_SOURCE_PROTO:=git
|
||||
PKG_SOURCE_VERSION:=b01efd8c984f3c442cce19faa76de4681d507191
|
||||
|
@ -1,10 +1,11 @@
|
||||
--- a/client/src/login/Login/Form.js
|
||||
+++ b/client/src/login/Login/Form.js
|
||||
@@ -23,6 +23,7 @@ const Form = (props) => {
|
||||
id="username1"
|
||||
name="username"
|
||||
@@ -25,7 +25,7 @@ const Form = (props) => {
|
||||
type="text"
|
||||
+ value="root"
|
||||
className="form-control"
|
||||
component={renderInputField}
|
||||
placeholder={t('username_placeholder')}
|
||||
- placeholder={t('username_placeholder')}
|
||||
+ placeholder="默认用户名密码都是root"
|
||||
autoComplete="username"
|
||||
autocapitalize="none"
|
||||
disabled={processing}
|
||||
|
@ -1,85 +0,0 @@
|
||||
#
|
||||
# Copyright (C) 2010-2011 OpenWrt.org
|
||||
#
|
||||
# This is free software, licensed under the GNU General Public License v2.
|
||||
# See /LICENSE for more information.
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=my-autocore
|
||||
PKG_VERSION:=1
|
||||
PKG_RELEASE:=7
|
||||
|
||||
include $(INCLUDE_DIR)/package.mk
|
||||
include $(INCLUDE_DIR)/target.mk
|
||||
|
||||
define Package/my-autocore-arm
|
||||
SECTION:=libs
|
||||
CATEGORY:=Libraries
|
||||
TITLE:=ARM auto core script.
|
||||
MAINTAINER:=CN_SZTL
|
||||
DEPENDS:=@(arm||aarch64) \
|
||||
+TARGET_bcm27xx:bcm27xx-userland \
|
||||
+TARGET_bcm53xx:nvram \
|
||||
+ethtool
|
||||
VARIANT:=arm
|
||||
endef
|
||||
|
||||
define Package/my-autocore-x86
|
||||
SECTION:=libs
|
||||
CATEGORY:=Libraries
|
||||
TITLE:=x86/x64 auto core loadbalance script.
|
||||
MAINTAINER:=Lean / CN_SZTL
|
||||
DEPENDS:=@TARGET_x86 +bc +lm-sensors +ethtool
|
||||
VARIANT:=x86
|
||||
endef
|
||||
|
||||
define Package/my-autocore-arm/description
|
||||
Display more details info about the devices in LuCI.
|
||||
endef
|
||||
|
||||
define Download/cpuinfo
|
||||
URL:=https://raw.githubusercontent.com/immortalwrt/immortalwrt/master/package/emortal/autocore/files/generic
|
||||
URL_FILE:=cpuinfo
|
||||
FILE:=cpuinfo
|
||||
HASH:=skip
|
||||
endef
|
||||
|
||||
define Build/Prepare
|
||||
sed -i 's/cpu_arch="?"/cpu_arch="ARMv8 Processor"/' $(DL_DIR)/cpuinfo
|
||||
endef
|
||||
|
||||
define Build/Compile
|
||||
endef
|
||||
|
||||
define Package/autocore/install/Default
|
||||
$(INSTALL_DIR) $(1)/sbin
|
||||
$(INSTALL_BIN) $(DL_DIR)/cpuinfo $(1)/sbin/cpuinfo
|
||||
$(INSTALL_BIN) ./files/common/ethinfo $(1)/sbin/ethinfo
|
||||
$(INSTALL_DIR) $(1)/www/luci-static/resources/view/status/include
|
||||
$(INSTALL_DATA) ./files/common/29_eth.js $(1)/www/luci-static/resources/view/status/include/
|
||||
$(INSTALL_DIR) $(1)/usr/lib/lua/luci/view/admin_status/index
|
||||
$(INSTALL_DATA) ./files/common/disc_status.htm $(1)/usr/lib/lua/luci/view/admin_status/index/
|
||||
endef
|
||||
|
||||
define Package/my-autocore-arm/install
|
||||
$(call Package/autocore/install/Default,$(1))
|
||||
|
||||
ifneq ($(filter ipq% %mt7622, $(TARGETID)),)
|
||||
$(INSTALL_BIN) ./files/arm/tempinfo $(1)/sbin/
|
||||
endif
|
||||
endef
|
||||
|
||||
define Package/my-autocore-x86/install
|
||||
$(call Package/autocore/install/Default,$(1))
|
||||
|
||||
$(INSTALL_DIR) $(1)/etc/init.d
|
||||
$(INSTALL_BIN) ./files/x86/autocore $(1)/etc/init.d/autocore
|
||||
$(INSTALL_DIR) $(1)/usr/lib/lua/luci/view/admin_status/index/
|
||||
$(INSTALL_DATA) ./files/x86/nvme_status.htm $(1)/usr/lib/lua/luci/view/admin_status/index/
|
||||
endef
|
||||
|
||||
$(eval $(call Download,cpuinfo))
|
||||
$(eval $(call BuildPackage,my-autocore-arm))
|
||||
$(eval $(call BuildPackage,my-autocore-x86))
|
@ -1,18 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
IEEE_PATH="/sys/class/ieee80211"
|
||||
THERMAL_PATH="/sys/class/thermal"
|
||||
|
||||
wifi_temp1="$(awk '{printf("%.1f°C ", $0 / 1000)}' "$IEEE_PATH"/phy*/hwmon*/temp1_input | awk '$1=$1')"
|
||||
wifi_temp2="$(awk '{printf("%.1f°C ", $0 / 1000)}' "$IEEE_PATH"/phy*/device/hwmon/hwmon*/temp1_input | awk '$1=$1')"
|
||||
NSS_LOAD="$(awk '{print$1}' "$DRV"/stats/cpu_load_ubi | awk '$1=$1' | tail -n 1)"
|
||||
|
||||
if grep -q "ipq40xx" "/etc/openwrt_release"; then
|
||||
if [ -e "$IEEE_PATH/phy0/hwmon0/temp1_input" ]; then
|
||||
mt76_temp=" $(awk -F ': ' '{print $2}' "$IEEE_PATH/phy0/hwmon0/temp1_input")°C"
|
||||
fi
|
||||
echo -n "WiFi:${mt76_temp} ${wifi_temp}"
|
||||
else
|
||||
cpu_temp="$(awk '{printf("%.1f°C", $0 / 1000)}' "$THERMAL_PATH/thermal_zone0/temp")"
|
||||
echo -n "CPU: ${cpu_temp}, WiFi: ${wifi_temp1} ${wifi_temp2}"
|
||||
fi
|
@ -1,34 +0,0 @@
|
||||
'use strict';
|
||||
'require rpc';
|
||||
|
||||
var callEthInfo = rpc.declare({
|
||||
object: 'luci',
|
||||
method: 'getEthInfo'
|
||||
});
|
||||
|
||||
return L.Class.extend({
|
||||
title: _('Interfaces'),
|
||||
|
||||
load: function() {
|
||||
return L.resolveDefault(callEthInfo(), {});
|
||||
},
|
||||
|
||||
render: function(info) {
|
||||
if (info && info.result) {
|
||||
var result = "";
|
||||
var ports = eval('(' + info.result + ')');
|
||||
var tmp = "<div class='table' width='100%' cellspacing='10' style='text-align: center' id='ethinfo'><ul style='list-style: none; margin:0 auto; display: inline-block;'>";
|
||||
for (var i in ports) {
|
||||
tmp = tmp + String.format(
|
||||
'<li style="float: left; margin: 0px 1em;"><span style="line-height:25px">%s</span><br /><small><img draggable="false" src="/luci-static/resources/icons/%s" /><br />%s<br />%s</small></li>',
|
||||
ports[i].name,
|
||||
ports[i].status ? 'port_up.png' : 'port_down.png',
|
||||
ports[i].speed,
|
||||
ports[i].duplex ? _('full-duplex') : _('half-duplex'));
|
||||
}
|
||||
tmp + "</ul></div>";
|
||||
result = tmp;
|
||||
return result;
|
||||
}
|
||||
}
|
||||
});
|
@ -1,278 +0,0 @@
|
||||
<% local raid = {}
|
||||
local devs = {}
|
||||
local devinfo = {}
|
||||
local colors = { "c0c0ff", "fbbd00", "e97c30", "a0e0a0", "e0c0ff" }
|
||||
local mounts = nixio.fs.readfile("/proc/mounts")
|
||||
|
||||
local show_raid = 1
|
||||
local show_disc = 1
|
||||
|
||||
if self then
|
||||
if self.hide_raid then
|
||||
show_raid = 0
|
||||
end
|
||||
if self.hide_disc then
|
||||
show_disc = 0
|
||||
end
|
||||
end
|
||||
|
||||
function disp_size(s)
|
||||
local units = { "kB", "MB", "GB", "TB" }
|
||||
local i, unit
|
||||
s = s / 2
|
||||
for i, unit in ipairs(units) do
|
||||
if (i == #units) or (s < 1024) then
|
||||
return math.floor(s * 100) / 100 .. unit
|
||||
end
|
||||
s = s / 1024
|
||||
end
|
||||
end
|
||||
|
||||
function first_line(s)
|
||||
local n = s:find("\n")
|
||||
if n then
|
||||
return s:sub(1, n-1)
|
||||
end
|
||||
return s
|
||||
end
|
||||
|
||||
function get_fs(pname, status)
|
||||
for r,raid in ipairs(raid) do
|
||||
for m,member in ipairs(raid.members) do
|
||||
if member.name == pname then
|
||||
return "(raid member)"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local mounted_fs = mounts:match("\n[a-z/]*" .. pname .. " [^ ]* ([^ ]*)")
|
||||
if mounted_fs then
|
||||
if status == "standby" then
|
||||
return "(" .. mounted_fs .. ")"
|
||||
end
|
||||
local df = luci.sys.exec("df /dev/" .. pname):match(" ([0-9]+)%% ")
|
||||
return "(" .. mounted_fs .. " " .. df .. "%)"
|
||||
end
|
||||
|
||||
if status == "standby" then
|
||||
return
|
||||
end
|
||||
|
||||
local blkid = luci.sys.exec(" blkid -s TYPE /dev/" .. pname):match("TYPE=\"(.*)\"")
|
||||
if blkid then
|
||||
return "(" .. blkid .. ")"
|
||||
end
|
||||
end
|
||||
|
||||
function get_status(raid)
|
||||
for m,member in ipairs(raid.members) do
|
||||
for d,dev in ipairs(devinfo) do
|
||||
if member.name == dev.name then
|
||||
return dev.status
|
||||
end
|
||||
for p,part in ipairs(dev.parts) do
|
||||
if member.name == part.name then
|
||||
return dev.status
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
function get_parts(dev,status,size)
|
||||
local c = 1
|
||||
local unused = size
|
||||
local parts = {}
|
||||
|
||||
for part in nixio.fs.glob("/sys/block/" .. dev .."/" .. dev .. "*") do
|
||||
local pname = nixio.fs.basename(part)
|
||||
local psize = nixio.fs.readfile(part .. "/size")
|
||||
table.insert(parts, {name=pname, size=psize, perc=math.floor(psize*100/size), fs=get_fs(pname,status), color=colors[c]})
|
||||
c = c + 1
|
||||
unused = unused - psize
|
||||
end
|
||||
if unused > 2048 then
|
||||
table.insert(parts, { name="", fs=get_fs(dev,status), size=unused, color=colors[c] })
|
||||
end
|
||||
return parts
|
||||
end
|
||||
|
||||
for dev in nixio.fs.glob("/sys/block/*") do
|
||||
if nixio.fs.access(dev .. "/md") then
|
||||
local name = nixio.fs.basename(dev)
|
||||
local rlevel = first_line(nixio.fs.readfile(dev .. "/md/level"))
|
||||
local ndisks = tonumber(nixio.fs.readfile(dev .. "/md/raid_disks"))
|
||||
local size = tonumber(nixio.fs.readfile(dev .. "/size"))
|
||||
local metav = nixio.fs.readfile(dev .. "/md/metadata_version")
|
||||
local degr = tonumber(nixio.fs.readfile(dev .. "/md/degraded"))
|
||||
local sync = first_line(nixio.fs.readfile(dev .. "/md/sync_action"))
|
||||
local sync_speed = tonumber(nixio.fs.readfile(dev .. "/md/sync_speed"))
|
||||
local sync_compl = nixio.fs.readfile(dev .. "/md/sync_completed")
|
||||
local status = "active"
|
||||
if sync ~= "idle" then
|
||||
local progress, total = nixio.fs.readfile(dev .. "/md/sync_completed"):match("^([0-9]*)[^0-9]*([0-9]*)")
|
||||
local rem = (total - progress) / sync_speed / 2
|
||||
local rems = math.floor(rem % 60)
|
||||
if rems < 10 then rems = "0" .. rems end
|
||||
rem = math.floor(rem / 60)
|
||||
local remm = math.floor(rem % 60)
|
||||
if remm < 10 then remm = "0" .. remm end
|
||||
local remh = math.floor(rem / 60)
|
||||
local remstr = remh .. ":" .. remm .. ":" .. rems
|
||||
status = sync .. " (" .. math.floor(sync_speed/1024) .. "MB/s, " .. math.floor(progress * 1000 / total) /10 .. "%, rem. " .. remstr .. ")"
|
||||
elseif degr == 1 then
|
||||
status = "degraded"
|
||||
end
|
||||
|
||||
local members = {}
|
||||
local c = 1
|
||||
for member in nixio.fs.glob("/sys/block/" .. name .. "/md/dev-*") do
|
||||
local dname = nixio.fs.basename(nixio.fs.readlink(member .. "/block"))
|
||||
local dsize = disp_size(tonumber(nixio.fs.readfile(member .. "/block/size")))
|
||||
local dstate = nixio.fs.readfile(member .. "/state"):gsub("_", " "):match "^%s*(.-)%s*$"
|
||||
table.insert(members, { name = dname, size = dsize, state = dstate, color = colors[c] })
|
||||
c = c + 1
|
||||
end
|
||||
table.insert(raid, {name=name, rlevel=rlevel, ndisks=ndisks, size=size, metav=metav, status=status, members=members })
|
||||
end
|
||||
end
|
||||
|
||||
if show_disc == 1 then
|
||||
for dev in nixio.fs.glob("/sys/class/scsi_disk/*/device") do
|
||||
local section
|
||||
local model = nixio.fs.readfile(dev .. "/model")
|
||||
local fw = nixio.fs.readfile(dev .. "/rev")
|
||||
for bdev in nixio.fs.glob(dev .. "/block/*") do
|
||||
local section
|
||||
local name = nixio.fs.basename(bdev)
|
||||
local size = tonumber(nixio.fs.readfile(bdev .. "/size"))
|
||||
local unused = size
|
||||
local status = "-"
|
||||
local temp = "-"
|
||||
local serial = "-"
|
||||
local secsize = "-"
|
||||
|
||||
for _,line in ipairs(luci.util.execl("smartctl -A -i -n standby -f brief /dev/" .. name)) do
|
||||
local attrib, val
|
||||
if section == 1 then
|
||||
attrib, val = line:match "^(.*):%s*(.*)"
|
||||
elseif section == 2 then
|
||||
attrib, val = line:match("^([0-9 ]*) [^ ]* * [POSRCK-]* *[0-9-]* *[0-9-]* *[0-9-]* *[0-9-]* *([0-9-]*)")
|
||||
else
|
||||
attrib = line:match "^=== START OF (.*) SECTION ==="
|
||||
if attrib == "INFORMATION" then
|
||||
section = 1
|
||||
elseif attrib == "READ SMART DATA" then
|
||||
section = 2
|
||||
elseif status == "-" then
|
||||
val = line:match "^Device is in (.*) mode"
|
||||
if val then
|
||||
status = val:lower()
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if not attrib then
|
||||
if section ~= 2 then section = 0 end
|
||||
elseif (attrib == "Power mode is") or (attrib == "Power mode was") then
|
||||
status = val:lower():match "(%S*)"
|
||||
elseif attrib == "Sector Sizes" then
|
||||
secsize = val:match "([0-9]*) bytes physical"
|
||||
elseif attrib == "Sector Size" then
|
||||
secsize = val:match "([0-9]*)"
|
||||
elseif attrib == "Serial Number" then
|
||||
serial = val
|
||||
elseif attrib == "194" then
|
||||
temp = val .. "°C"
|
||||
end
|
||||
end
|
||||
table.insert(devinfo, {name=name, model=model, fw=fw, size=size, status=status, temp=temp, serial=serial, secsize=secsize, parts=get_parts(name,status,size) })
|
||||
end
|
||||
end
|
||||
|
||||
for r,dev in ipairs(raid) do
|
||||
table.insert(devinfo, {name=dev.name, model="Linux RAID", size=dev.size, status=get_status(dev), secsize=secsize, parts=get_parts(dev.name,status,dev.size) })
|
||||
end
|
||||
end
|
||||
|
||||
if show_disc == 1 then %>
|
||||
<div class="cbi-section">
|
||||
<h3><%:Disks%></h3>
|
||||
<table class="cbi-section-table" style="white-space: nowrap">
|
||||
<tr>
|
||||
<th width="5%"> </th>
|
||||
<th width="30%"><%:Model%></th>
|
||||
<th width="15%"><%:Serial number%></th>
|
||||
<th width="10%"><%:Firmware%></th>
|
||||
<th width="10%"><%:Capacity%></th>
|
||||
<th width="5%"><%:Sector size%></th>
|
||||
<th width="5%"><%:Temperature%></th>
|
||||
<th width="20%"><%:Power state%></th>
|
||||
</tr>
|
||||
<% local style=true
|
||||
for d,dev in ipairs(devinfo) do %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td class="cbi-vluae-field" style="padding-bottom:0px; border-bottom-width:0px; vertical-align:middle" rowspan="4"><%=dev.name%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.model%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.serial%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.fw%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=disp_size(dev.size)%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.secsize%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.temp%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.status%></td>
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td style="padding:0px; border-top-width:0px;" colspan="7" rowspan="2">
|
||||
<table style="border: 0pt; border-collapse:collapse; width:100%; padding:0px; margin:0px"><tr>
|
||||
<% for _,part in pairs(dev.parts) do %>
|
||||
<td style="text-align:center; padding: 0px 4px; border-radius: 3px; background-color:#<%=part.color%>" width="<%=part.perc%>%"><%=part.name%> <%=disp_size(part.size)%> <%=part.fs%></td>
|
||||
<% end %>
|
||||
</tr></table>
|
||||
</td>
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<% style = not style
|
||||
end %>
|
||||
</table>
|
||||
</div>
|
||||
<% end
|
||||
if show_raid == 1 and #raid > 0 then %>
|
||||
<div class="cbi-section">
|
||||
<h3><%:Raid arrays%></h3>
|
||||
<table class="cbi-section-table" style="white-space:nowrap">
|
||||
<tr>
|
||||
<th width="5%"> </th>
|
||||
<th width="13%"><%:Level%></th>
|
||||
<th width="13%"><%:# Disks%></th>
|
||||
<th width="13%"><%:Capacity%></th>
|
||||
<th width="13%"><%:Metadata%></th>
|
||||
<th width="43%"><%:Status%></th>
|
||||
</tr>
|
||||
<% local style=true
|
||||
for r,dev in ipairs(raid) do %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td class="cbi-vluae-field" style="padding-bottom:0px; border-bottom-width:0px; vertical-align:middle" rowspan="4"><%=dev.name%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.rlevel%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.ndisks%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=disp_size(dev.size)%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.metav%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.status%></td>
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td style="padding-top:0px; border-top-width:0px" colspan="6" rowspan="2">
|
||||
<table style="border: 0pt; border-collapse:collapse; width:100%; padding:0px; margin:0px"><tr>
|
||||
<% for _,member in pairs(dev.members) do %>
|
||||
<td style="text-align:center; padding: 0px 4px; border-radius: 3px; background-color:#<%=member.color%>; white-space: nowrap"><%=member.name%> <%=member.size%> (<%=member.state%>)</td>
|
||||
<% end %>
|
||||
</tr></table>
|
||||
</td>
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<% style = not style
|
||||
end %>
|
||||
</table>
|
||||
</div>
|
||||
<% end %>
|
@ -1,39 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
a=$(ip address | grep ^[0-9] | awk -F: '{print $2}' | sed "s/ //g" | grep '^[e]' | grep -v "@" | grep -v "\.")
|
||||
b=$(echo "$a" | wc -l)
|
||||
rm -f /tmp/state/ethinfo
|
||||
|
||||
echo -n "[" > /tmp/state/ethinfo
|
||||
|
||||
for i in $(seq 1 $b)
|
||||
do
|
||||
h=$(echo '{"name":' )
|
||||
c=$(echo "$a" | sed -n ${i}p)
|
||||
d=$(ethtool $c)
|
||||
|
||||
e=$(echo "$d" | grep "Link detected" | awk -F: '{printf $2}' | sed 's/^[ \t]*//g')
|
||||
if [ $e = yes ]; then
|
||||
l=1
|
||||
else
|
||||
l=0
|
||||
fi
|
||||
|
||||
f=$(echo "$d" | grep "Speed" | awk -F: '{printf $2}' | sed 's/^[ \t]*//g' | tr -d "Unknown!")
|
||||
[ -z "$f" ] && f=" - "
|
||||
|
||||
g=$(echo "$d" | grep "Duplex" | awk -F: '{printf $2}' | sed 's/^[ \t]*//g')
|
||||
if [ "$g" == "Full" ]; then
|
||||
x=1
|
||||
else
|
||||
x=0
|
||||
fi
|
||||
|
||||
echo -n "$h \"$c\", \"status\": $l, \"speed\": \"$f\", \"duplex\": $x}," >> /tmp/state/ethinfo
|
||||
done
|
||||
|
||||
sed -i 's/.$//' /tmp/state/ethinfo
|
||||
|
||||
echo -n "]" >> /tmp/state/ethinfo
|
||||
|
||||
cat /tmp/state/ethinfo
|
@ -1,53 +0,0 @@
|
||||
#!/bin/sh /etc/rc.common
|
||||
# Copyright (C) 2017 lean <coolsnowwolf@gmail.com>
|
||||
|
||||
START=99
|
||||
|
||||
start()
|
||||
{
|
||||
rfc=4096
|
||||
cc=$(grep -c processor /proc/cpuinfo)
|
||||
rsfe=$(echo $cc*$rfc | bc)
|
||||
sysctl -w net.core.rps_sock_flow_entries=$rsfe >/dev/null
|
||||
for fileRps in $(ls /sys/class/net/eth*/queues/rx-*/rps_cpus)
|
||||
do
|
||||
echo $cc > $fileRps
|
||||
done
|
||||
|
||||
for fileRfc in $(ls /sys/class/net/eth*/queues/rx-*/rps_flow_cnt)
|
||||
do
|
||||
echo $rfc > $fileRfc
|
||||
done
|
||||
|
||||
uci set network.@globals[0].packet_steering=1
|
||||
uci commit network
|
||||
|
||||
a=$(cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq)
|
||||
b=$(echo -n ' : ')
|
||||
c=$(cat /proc/cpuinfo | grep 'core id' | sort -u | wc -l)
|
||||
d=$(echo -n ' Core ')
|
||||
e=$(cat /proc/cpuinfo | grep 'processor' | wc -l)
|
||||
f=$(echo -n ' Thread ')
|
||||
g=$(dmesg | grep 'DMI:' | awk -F ',' '{print $1$2 }' | awk -F ':' '{print $2 }')
|
||||
h=${g}' '${b}${c}${d}${e}${f}
|
||||
|
||||
mkdir -p /tmp/sysinfo
|
||||
echo $h > /tmp/sysinfo/model
|
||||
|
||||
a=$(ip address | grep ^[0-9] | awk -F: '{print $2}' | sed "s/ //g" | grep '^[e]' | grep -v "@" | grep -v "\.")
|
||||
b=$(echo "$a" | wc -l)
|
||||
for i in $(seq 1 $b)
|
||||
do
|
||||
c=$(echo "$a" | sed -n ${i}p)
|
||||
ethtool -K $c rx-checksum on >/dev/null 2>&1
|
||||
ethtool -K $c tx-checksum-ip-generic on >/dev/null 2>&1 || (
|
||||
ethtool -K $c tx-checksum-ipv4 on >/dev/null 2>&1
|
||||
ethtool -K $c tx-checksum-ipv6 on >/dev/null 2>&1)
|
||||
ethtool -K $c tx-scatter-gather on >/dev/null 2>&1
|
||||
ethtool -K $c gso on >/dev/null 2>&1
|
||||
ethtool -K $c tso on >/dev/null 2>&1
|
||||
ethtool -K $c ufo on >/dev/null 2>&1
|
||||
done
|
||||
|
||||
[ -f /etc/index.htm ] && mv /etc/index.htm /usr/lib/lua/luci/view/admin_status/index.htm
|
||||
}
|
@ -1,228 +0,0 @@
|
||||
<% local raid = {}
|
||||
local devs = {}
|
||||
local devinfo = {}
|
||||
local colors = { "c0c0ff", "fbbd00", "e97c30", "a0e0a0", "b2c005", "e0c0ff" }
|
||||
local mounts = nixio.fs.readfile("/proc/mounts")
|
||||
|
||||
local show_raid = 1
|
||||
local show_disc = 1
|
||||
|
||||
if self then
|
||||
if self.hide_raid then
|
||||
show_raid = 0
|
||||
end
|
||||
if self.hide_disc then
|
||||
show_disc = 0
|
||||
end
|
||||
end
|
||||
|
||||
function disp_size(s)
|
||||
local units = { "kB", "MB", "GB", "TB" }
|
||||
local i, unit
|
||||
s = s / 2
|
||||
for i, unit in ipairs(units) do
|
||||
if (i == #units) or (s < 1024) then
|
||||
return math.floor(s * 100) / 100 .. unit
|
||||
end
|
||||
s = s / 1024
|
||||
end
|
||||
end
|
||||
|
||||
function first_line(s)
|
||||
local n = s:find("\n")
|
||||
if n then
|
||||
return s:sub(1, n-1)
|
||||
end
|
||||
return s
|
||||
end
|
||||
|
||||
function get_fs(pname, status)
|
||||
for r,raid in ipairs(raid) do
|
||||
for m,member in ipairs(raid.members) do
|
||||
if member.name == pname then
|
||||
return "(raid member)"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local mounted_fs = mounts:match("\n[a-z/]*" .. pname .. " [^ ]* ([^ ]*)")
|
||||
if mounted_fs then
|
||||
if status == "standby" then
|
||||
return "(" .. mounted_fs .. ")"
|
||||
end
|
||||
local df = luci.sys.exec("df /dev/" .. pname):match(" ([0-9]+)%% ")
|
||||
return "(" .. mounted_fs .. " " .. df .. "%)"
|
||||
end
|
||||
|
||||
if status == "standby" then
|
||||
return
|
||||
end
|
||||
|
||||
local blkid = luci.sys.exec(" blkid -s TYPE /dev/" .. pname):match("TYPE=\"(.*)\"")
|
||||
if blkid then
|
||||
return "(" .. blkid .. ")"
|
||||
end
|
||||
end
|
||||
|
||||
function get_status(raid)
|
||||
for m,member in ipairs(raid.members) do
|
||||
for d,dev in ipairs(devinfo) do
|
||||
if member.name == dev.name then
|
||||
return dev.status
|
||||
end
|
||||
for p,part in ipairs(dev.parts) do
|
||||
if member.name == part.name then
|
||||
return dev.status
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
function get_parts(dev,status,size)
|
||||
local c = 1
|
||||
local unused = size
|
||||
local parts = {}
|
||||
|
||||
for part in nixio.fs.glob("/sys/block/" .. dev .."/" .. dev .. "*") do
|
||||
local pname = nixio.fs.basename(part)
|
||||
local psize = nixio.fs.readfile(part .. "/size")
|
||||
table.insert(parts, {name=pname, size=psize, perc=math.floor(psize*100/size), fs=get_fs(pname,status), color=colors[c]})
|
||||
c = c + 1
|
||||
unused = unused - psize
|
||||
end
|
||||
if unused > 2048 then
|
||||
table.insert(parts, { name="", fs=get_fs(dev,status), size=unused, color=colors[c] })
|
||||
end
|
||||
return parts
|
||||
end
|
||||
|
||||
for dev in nixio.fs.glob("/sys/block/*") do
|
||||
if nixio.fs.access(dev .. "/md") then
|
||||
local name = nixio.fs.basename(dev)
|
||||
local rlevel = first_line(nixio.fs.readfile(dev .. "/md/level"))
|
||||
local ndisks = tonumber(nixio.fs.readfile(dev .. "/md/raid_disks"))
|
||||
local size = tonumber(nixio.fs.readfile(dev .. "/size"))
|
||||
local metav = nixio.fs.readfile(dev .. "/md/metadata_version")
|
||||
local degr = tonumber(nixio.fs.readfile(dev .. "/md/degraded"))
|
||||
local sync = first_line(nixio.fs.readfile(dev .. "/md/sync_action"))
|
||||
local sync_speed = tonumber(nixio.fs.readfile(dev .. "/md/sync_speed"))
|
||||
local sync_compl = nixio.fs.readfile(dev .. "/md/sync_completed")
|
||||
local status = "active"
|
||||
if sync ~= "idle" then
|
||||
local progress, total = nixio.fs.readfile(dev .. "/md/sync_completed"):match("^([0-9]*)[^0-9]*([0-9]*)")
|
||||
local rem = (total - progress) / sync_speed / 2
|
||||
local rems = math.floor(rem % 60)
|
||||
if rems < 10 then rems = "0" .. rems end
|
||||
rem = math.floor(rem / 60)
|
||||
local remm = math.floor(rem % 60)
|
||||
if remm < 10 then remm = "0" .. remm end
|
||||
local remh = math.floor(rem / 60)
|
||||
local remstr = remh .. ":" .. remm .. ":" .. rems
|
||||
status = sync .. " (" .. math.floor(sync_speed/1024) .. "MB/s, " .. math.floor(progress * 1000 / total) /10 .. "%, rem. " .. remstr .. ")"
|
||||
elseif degr == 1 then
|
||||
status = "degraded"
|
||||
end
|
||||
|
||||
local members = {}
|
||||
local c = 1
|
||||
for member in nixio.fs.glob("/sys/block/" .. name .. "/md/dev-*") do
|
||||
local dname = nixio.fs.basename(nixio.fs.readlink(member .. "/block"))
|
||||
local dsize = disp_size(tonumber(nixio.fs.readfile(member .. "/block/size")))
|
||||
local dstate = nixio.fs.readfile(member .. "/state"):gsub("_", " "):match "^%s*(.-)%s*$"
|
||||
table.insert(members, { name = dname, size = dsize, state = dstate, color = colors[c] })
|
||||
c = c + 1
|
||||
end
|
||||
table.insert(raid, {name=name, rlevel=rlevel, ndisks=ndisks, size=size, metav=metav, status=status, members=members })
|
||||
end
|
||||
end
|
||||
|
||||
if show_disc == 1 then
|
||||
for dev in nixio.fs.glob("/sys/class/nvme/*/device/nvme/*") do
|
||||
local section
|
||||
local model = nixio.fs.readfile(dev .. "/model")
|
||||
local fw = nixio.fs.readfile(dev .. "/firmware_rev")
|
||||
for bdev in nixio.fs.glob(dev .. "/nvme*") do
|
||||
local section
|
||||
local name = nixio.fs.basename(bdev)
|
||||
local size = tonumber(nixio.fs.readfile(bdev .. "/size"))
|
||||
local unused = size
|
||||
local status = "-"
|
||||
local temp = "-"
|
||||
local serial = "-"
|
||||
local secsize = "-"
|
||||
|
||||
for _,line in ipairs(luci.util.execl("smartctl -A -i -d nvme -n standby -f brief /dev/" .. name)) do
|
||||
local attrib, val
|
||||
if section == 1 then
|
||||
attrib, val = line:match "^(.*):%s*(.*)"
|
||||
elseif section == 2 then
|
||||
attrib, val = line:match("^([0-9 ]*) [^ ]* * [POSRCK-]* *[0-9-]* *[0-9-]* *[0-9-]* *[0-9-]* *([0-9-]*)")
|
||||
else
|
||||
attrib = line:match "^=== START OF (.*) SECTION ==="
|
||||
if attrib == "INFORMATION" then
|
||||
section = 1
|
||||
elseif attrib == "READ SMART DATA" then
|
||||
section = 2
|
||||
elseif status == "-" then
|
||||
val = line:match "^Device is in (.*) mode"
|
||||
if val then
|
||||
status = val:lower()
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if not attrib then
|
||||
if section ~= 2 then section = 0 end
|
||||
elseif (attrib == "Power mode is") or (attrib == "Power mode was") then
|
||||
status = val:lower():match "(%S*)"
|
||||
elseif attrib == "Serial Number" then
|
||||
serial = val
|
||||
elseif attrib == "194" then
|
||||
temp = val .. "°C"
|
||||
end
|
||||
end
|
||||
table.insert(devinfo, {name=name, model=model, fw=fw, size=size, serial=serial, parts=get_parts(name,status,size) })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if show_raid == 1 and #devinfo > 0 then %>
|
||||
<div class="cbi-section">
|
||||
<h3><%:NVMe SSD%></h3>
|
||||
<table class="cbi-section-table" style="white-space: nowrap">
|
||||
<tr>
|
||||
<th width="5%"> </th>
|
||||
<th width="30%"><%:Model%></th>
|
||||
<th width="25%"><%:Serial number%></th>
|
||||
<th width="20%"><%:Firmware%></th>
|
||||
<th width="20%"><%:Capacity%></th>
|
||||
<!-- <th width="10%"><%:Temperature%></th>-->
|
||||
</tr>
|
||||
<% local style=true
|
||||
for d,dev in ipairs(devinfo) do %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td class="cbi-vluae-field" style="padding-bottom:0px; border-bottom-width:0px; vertical-align:middle" rowspan="4"><%=dev.name%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.model%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.serial%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.fw%></td>
|
||||
<td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=disp_size(dev.size)%></td>
|
||||
<!-- <td class="cbi-value-field" style="padding-bottom:0px; border-bottom-width:0px" rowspan="2"><%=dev.temp%></td>-->
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=(style and 1 or 2)%>">
|
||||
<td style="padding:0px; border-top-width:0px" colspan="7" rowspan="2">
|
||||
<table style="border: 0pt; border-collapse:collapse; width:100%; padding:0px; margin:0px"><tr>
|
||||
<% for _,part in pairs(dev.parts) do %>
|
||||
<td style="text-align:center; padding: 0px 4px; border-radius: 3px; background-color:#<%=part.color%>" width="<%=part.perc%>%"><%=part.name%> <%=disp_size(part.size)%> <%=part.fs%></td>
|
||||
<% end %>
|
||||
</tr></table>
|
||||
</td>
|
||||
</tr>
|
||||
<tr style="height:0px" />
|
||||
<% style = not style
|
||||
end %>
|
||||
</table>
|
||||
</div>
|
||||
<% end %>
|
@ -5,12 +5,12 @@
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=xray-plugin
|
||||
PKG_VERSION:=1.5.7
|
||||
PKG_VERSION:=1.5.8
|
||||
PKG_RELEASE:=$(AUTORELEASE)
|
||||
|
||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
||||
PKG_SOURCE_URL:=https://codeload.github.com/teddysun/xray-plugin/tar.gz/v$(PKG_VERSION)?
|
||||
PKG_HASH:=55f72a44a4089eb211ab0e35f064723c028854243e8388d0fcc5d8524aa5fb6b
|
||||
PKG_HASH:=1f20d622e684f06e5117bdd3652b2444806cd1f58ea013c9fdcb5ad7fd7982b9
|
||||
|
||||
PKG_LICENSE:=MIT
|
||||
PKG_LICENSE_FILES:=LICENSE
|
||||
|
Loading…
Reference in New Issue
Block a user