diff --git a/package/lean/luci-app-qbittorrent/Makefile b/package/lean/luci-app-qbittorrent/Makefile
index 343d888466..32bb8c0fa1 100644
--- a/package/lean/luci-app-qbittorrent/Makefile
+++ b/package/lean/luci-app-qbittorrent/Makefile
@@ -1,15 +1,16 @@
# Copyright (C) 2019 Openwrt.org
#
-# This is free software, licensed under the Apache License, Version 2.0 .
+# This is a free software, use it under Apache Licene 2.0 & GNU General Public License v3.0.
#
include $(TOPDIR)/rules.mk
-LUCI_TITLE:=LuCI support for qBittorrent
-LUCI_DEPENDS:=+qBittorrent +python
+LUCI_TITLE:=qbittorrent-nox for LuCI
+LUCI_DEPENDS:=+qBittorrent-Enhanced-Edition
LUCI_PKGARCH:=all
+PKG_NAME:=luci-app-qbittorrent
PKG_VERSION=1.0
-PKG_RELEASE:=18
+PKG_RELEASE:=1
include $(TOPDIR)/feeds/luci/luci.mk
diff --git a/package/lean/luci-app-qbittorrent/luasrc/controller/qbittorrent.lua b/package/lean/luci-app-qbittorrent/luasrc/controller/qbittorrent.lua
index 77d58b971c..11d169c6c6 100644
--- a/package/lean/luci-app-qbittorrent/luasrc/controller/qbittorrent.lua
+++ b/package/lean/luci-app-qbittorrent/luasrc/controller/qbittorrent.lua
@@ -13,4 +13,4 @@ function act_status()
e.running=luci.sys.call("pgrep qbittorrent-nox >/dev/null")==0
luci.http.prepare_content("application/json")
luci.http.write_json(e)
-end
\ No newline at end of file
+end
diff --git a/package/lean/luci-app-qbittorrent/luasrc/model/cbi/qbittorrent.lua b/package/lean/luci-app-qbittorrent/luasrc/model/cbi/qbittorrent.lua
index 7431394f24..b5dbe9d7e7 100644
--- a/package/lean/luci-app-qbittorrent/luasrc/model/cbi/qbittorrent.lua
+++ b/package/lean/luci-app-qbittorrent/luasrc/model/cbi/qbittorrent.lua
@@ -1,371 +1,32 @@
-
-local o=luci.sys.exec("uci get qbittorrent.main.Port | xargs echo -n") or 8080
+local e=require"luci.model.uci".cursor()
+local o=e:get_first("qbittorrent","Preferences","port") or 8080
local a=(luci.sys.call("pidof qbittorrent-nox > /dev/null")==0)
local t=""
if a then
-t=" "
-end
-
-function titlesplit(Value)
- return "
" .. translate(Value) .. "
"
+t=" "
end
m = Map("qbittorrent", translate("qBittorrent"), translate("qBittorrent is a cross-platform free and open-source BitTorrent client")..t)
-s = m:section(NamedSection, "main", "qbittorrent")
+m:section(SimpleSection).template="qbittorrent/qbittorrent_status"
-s:tab("basic", translate("Basic Settings"))
+s_basic = m:section(TypedSection, "basic", translate("Basic Settings"))
+s_basic.anonymous = true
-o = s:taboption("basic", Flag, "enabled", translate("Enabled"))
-o.default = "1"
+enable = s_basic:option(Flag, "enable", translate("Enable"))
+profile_dir = s_basic:option(Value,"profile_dir",translate("profile_dir"),translate("Store configuration files in the Path"))
+profile_dir.default = "/root"
-o = s:taboption("basic", ListValue, "user", translate("Run daemon as user"))
-local u
-for u in luci.util.execi("cat /etc/passwd | cut -d ':' -f1") do
- o:value(u)
-end
+s_download = m:section(TypedSection, "Preferences", translate("Download Settings"))
+s_download.anonymous = true
+download_dir = s_download:option(Value,"download_dir",translate("download_dir"),translate("Store download files in the Path"))
+download_dir.default = "/root/download"
-o = s:taboption("basic", Value, "profile", translate("Store configuration files in the Path"))
-o.default = '/tmp'
+s_webui = m:section(TypedSection, "Preferences", translate("WEBUI Settings"))
+s_webui.anonymous = true
+port = s_webui:option(Value,"port",translate("port"),translate("WEBUI listening port"))
+port.default = "8080"
-o = s:taboption("basic", Value, "SavePath", translate("Store download files in the Path"))
-o.placeholder = "/tmp/download"
-
-o = s:taboption("basic", Value, "Port", translate("WEBUI listening port"))
-o.datatype = "port"
-o.placeholder = "8080"
-
-o = s:taboption("basic", Flag, "UseRandomPort", translate("Use Random Port"), translate("Randomly assigns a different port every time qBittorrent starts up"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("basic", Value, "PortRangeMin", translate("Connection Port"), translate("Incoming connection port"))
-o:depends("UseRandomPort", false)
-o.datatype = "range(1024,65535)"
-
-
-s:tab("connection", translate("Connection Settings"))
-
-o = s:taboption("connection", Flag, "UPnP", translate("Use UPnP for Connections"), translate("Use UPnP/ NAT-PMP port forwarding from my router. Refer to the "
- .. "wiki ."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-
-o = s:taboption("connection", Value, "GlobalDLLimit", translate("Global Download Speed"), translate("Global Download Speed Limit(KiB/s)."))
-o.datatype = "float"
-o.placeholder = "0"
-
-o = s:taboption("connection", Value, "GlobalUPLimit", translate("Global Upload Speed"), translate("Global Upload Speed Limit(KiB/s)."))
-o.datatype = "float"
-o.placeholder = "0"
-
-o = s:taboption("connection", Value, "GlobalDLLimitAlt", translate("Alternative Download Speed"), translate("Alternative Download Speed Limit(KiB/s)."))
-o.datatype = "float"
-o.placeholder = "10"
-
-o = s:taboption("connection", Value, "GlobalUPLimitAlt", translate("Alternative Upload Speed"), translate("Alternative Upload Speed Limit(KiB/s)."))
-o.datatype = "float"
-o.placeholder = "10"
-
-o = s:taboption("connection", ListValue, "BTProtocol", translate("Enabled protocol"), translate("The protocol that was enabled."))
-o:value("Both", translate("TCP and UTP"))
-o:value("TCP", translate("TCP"))
-o:value("UTP", translate("UTP"))
-o.default = "Both"
-
-o = s:taboption("connection", Value, "InetAddress", translate("Inet Address"), translate("The address that respond to the trackers."))
-
-s:tab("downloads", translate("Download Settings"))
-
-o = s:taboption("downloads", Flag, "CreateTorrentSubfolder", translate("Create Subfolder"), translate("Create subfolder for torrents with multiple files."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("downloads", Flag, "StartInPause", translate("Start In Pause"), translate("Do not start the download automatically."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("downloads", Flag, "AutoDeleteAddedTorrentFile", translate("Auto Delete Torrent File"), translate("The .torrent files will be deleted afterwards."))
-o.enabled = "IfAdded"
-o.disabled = "Never"
-o.default = o.disabled
-
-o = s:taboption("downloads", Flag, "PreAllocation", translate("Pre Allocation"), translate("Pre-allocate disk space for all files."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("downloads", Flag, "UseIncompleteExtension", translate("Use Incomplete Extension"), translate("The incomplete task will be added the extension of !qB."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("downloads", Flag, "TempPathEnabled", translate("Temp Path Enabled"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("downloads", Value, "TempPath", translate("Temp Path"), translate("The absolute and relative path can be set."))
-o:depends("TempPathEnabled", "true")
-o.placeholder = "temp/"
-
-o = s:taboption("downloads", Value, "DiskWriteCacheSize", translate("Disk Cache Size (MiB)"), translate("The value -1 is auto and 0 is disable. In default, it is set to 64MiB."))
-o.datatype = "integer"
-o.placeholder = "64"
-
-o = s:taboption("downloads", Value, "DiskWriteCacheTTL", translate("Disk Cache TTL (s)"), translate("In default, it is set to 60s."))
-o.datatype = "integer"
-o.placeholder = "60"
-
-o = s:taboption("downloads", DummyValue, "Saving Management", titlesplit("Saving Management"))
-
-o = s:taboption("downloads", ListValue, "DisableAutoTMMByDefault", translate("Default Torrent Management Mode"))
-o:value("true", translate("Manual"))
-o:value("false", translate("Automaic"))
-o.default = "true"
-
-o = s:taboption("downloads", ListValue, "CategoryChanged", translate("Torrent Category Changed"), translate("Choose the action when torrent category changed."))
-o:value("true", translate("Switch torrent to Manual Mode"))
-o:value("false", translate("Relocate torrent"))
-o.default = "false"
-
-o = s:taboption("downloads", ListValue, "DefaultSavePathChanged", translate("Default Save Path Changed"), translate("Choose the action when default save path changed."))
-o:value("true", translate("Switch affected torrent to Manual Mode"))
-o:value("false", translate("Relocate affected torrent"))
-o.default = "true"
-
-o = s:taboption("downloads", ListValue, "CategorySavePathChanged", translate("Category Save Path Changed"), translate("Choose the action when category save path changed."))
-o:value("true", translate("Switch affected torrent to Manual Mode"))
-o:value("false", translate("Relocate affected torrent"))
-o.default = "true"
-
-o = s:taboption("downloads", Value, "TorrentExportDir", translate("Torrent Export Dir"), translate("The .torrent files will be copied to the target directory."))
-
-o = s:taboption("downloads", Value, "FinishedTorrentExportDir", translate("Finished Torrent Export Dir"), translate("The .torrent files for finished downloads will be copied to the target directory."))
-
-s:tab("bittorrent", translate("Bittorrent Settings"))
-
-o = s:taboption("bittorrent", Flag, "DHT", translate("Enable DHT"), translate("Enable DHT (decentralized network) to find more peers"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("bittorrent", Flag, "PeX", translate("Enable PeX"), translate("Enable Peer Exchange (PeX) to find more peers"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("bittorrent", Flag, "LSD", translate("Enable LSD"), translate("Enable Local Peer Discovery to find more peers"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("bittorrent", Flag, "uTP_rate_limited", translate("uTP Rate Limit"), translate("Apply rate limit to μTP protocol."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("bittorrent", ListValue, "Encryption", translate("Encryption Mode"), translate("Enable DHT (decentralized network) to find more peers"))
-o:value("0", translate("Prefer Encryption"))
-o:value("1", translate("Require Encryption"))
-o:value("2", translate("Disable Encryption"))
-o.default = "0"
-
-o = s:taboption("bittorrent", Value, "MaxConnecs", translate("Max Connections"), translate("The max number of connections."))
-o.datatype = "integer"
-o.placeholder = "500"
-
-o = s:taboption("bittorrent", Value, "MaxConnecsPerTorrent", translate("Max Connections Per Torrent"), translate("The max number of connections per torrent."))
-o.datatype = "integer"
-o.placeholder = "100"
-
-o = s:taboption("bittorrent", Value, "MaxUploads", translate("Max Uploads"), translate("The max number of connected peers."))
-o.datatype = "integer"
-o.placeholder = "8"
-
-o = s:taboption("bittorrent", Value, "MaxUploadsPerTorrent", translate("Max Uploads Per Torrent"), translate("The max number of connected peers per torrent."))
-o.datatype = "integer"
-o.placeholder = "4"
-
-o = s:taboption("bittorrent", Value, "MaxRatio", translate("Max Ratio"), translate("The max ratio for seeding. -1 is to disable the seeding."))
-o.datatype = "float"
-o.placeholder = "-1"
-
-o = s:taboption("bittorrent", ListValue, "MaxRatioAction", translate("Max Ratio Action"), translate("The action when reach the max seeding ratio."))
-o:value("0", translate("Pause them"))
-o:value("1", translate("Remove them"))
-o.defaule = "0"
-
-o = s:taboption("bittorrent", Value, "GlobalMaxSeedingMinutes", translate("Max Seeding Minutes"), translate("Units: minutes"))
-o.datatype = "integer"
-
-o = s:taboption("bittorrent", DummyValue, "Queueing Setting", titlesplit("Queueing Setting"))
-
-o = s:taboption("bittorrent", Flag, "QueueingEnabled", translate("Enable Torrent Queueing"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("bittorrent", Value, "MaxActiveDownloads", translate("Maximum Active Downloads"))
-o.datatype = "integer"
-o.placeholder = "3"
-
-o = s:taboption("bittorrent", Value, "MaxActiveUploads", translate("Max Active Uploads"))
-o.datatype = "integer"
-o.placeholder = "3"
-
-o = s:taboption("bittorrent", Value, "MaxActiveTorrents", translate("Max Active Torrents"))
-o.datatype = "integer"
-o.placeholder = "5"
-
-o = s:taboption("bittorrent", Flag, "IgnoreSlowTorrents", translate("Ignore Slow Torrents"), translate("Do not count slow torrents in these limits."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("bittorrent", Value, "SlowTorrentsDownloadRate", translate("Download rate threshold"), translate("Units: KiB/s"))
-o.datatype = "integer"
-o.placeholder = "2"
-
-o = s:taboption("bittorrent", Value, "SlowTorrentsUploadRate", translate("Upload rate threshold"), translate("Units: KiB/s"))
-o.datatype = "integer"
-o.placeholder = "2"
-
-o = s:taboption("bittorrent", Value, "SlowTorrentsInactivityTimer", translate("Torrent inactivity timer"), translate("Units: seconds"))
-o.datatype = "integer"
-o.placeholder = "60"
-
-s:tab("webgui", translate("WebUI Settings"))
-
-o = s:taboption("webgui", Flag, "UseUPnP", translate("Use UPnP for WebUI"), translate("Using the UPnP / NAT-PMP port of the router for connecting to WebUI."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("webgui", Value, "Username", translate("Username"), translate("The login name for WebUI."))
-o.placeholder = "admin"
-
-o = s:taboption("webgui", Value, "Password", translate("Password"), translate("The login password for WebUI."))
-o.password = true
-
-o = s:taboption("webgui", Value, "Locale", translate("Locale Language"))
-o:value("en", translate("English"))
-o:value("zh", translate("Chinese"))
-o.default = "en"
-
-o = s:taboption("webgui", Flag, "CSRFProtection", translate("CSRF Protection"), translate("Enable Cross-Site Request Forgery (CSRF) protection."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("webgui", Flag, "ClickjackingProtection", translate("Clickjacking Protection"), translate("Enable clickjacking protection."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("webgui", Flag, "HostHeaderValidation", translate("Host Header Validation"), translate("Validate the host header."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("webgui", Flag, "LocalHostAuth", translate("Local Host Authentication"), translate("Force authentication for clients on localhost."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("webgui", Flag, "AuthSubnetWhitelistEnabled", translate("Enable Subnet Whitelist"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("webgui", DynamicList, "AuthSubnetWhitelist", translate("Subnet Whitelist"))
-o:depends("AuthSubnetWhitelistEnabled", "true")
-
-s:tab("advanced", translate("Advance Settings"))
-
-o = s:taboption("advanced", Flag, "AnonymousMode", translate("Anonymous Mode"), translate("When enabled, qBittorrent will take certain measures to try"
- .. " to mask its identity. Refer to the wiki "))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Flag, "SuperSeeding", translate("Super Seeding"), translate("The super seeding mode."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("advanced", Value, "configuration", translate("Profile Folder Suffix"), translate("Suffix for profile folder"))
-
-o = s:taboption("advanced", Flag, "IncludeOverhead", translate("Limit Overhead Usage"), translate("The overhead usage is been limitted."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("advanced", Flag, "IgnoreLimitsLAN", translate("Ignore LAN Limit"), translate("Ignore the speed limit to LAN."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Flag, "osCache", translate("Use os Cache"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Value, "OutgoingPortsMax", translate("Max Outgoing Port"), translate("The max outgoing port."))
-o.datatype = "port"
-
-o = s:taboption("advanced", Value, "OutgoingPortsMin", translate("Min Outgoing Port"), translate("The min outgoing port."))
-o.datatype = "port"
-
-o = s:taboption("advanced", ListValue, "SeedChokingAlgorithm", translate("Choking Algorithm"), translate("The strategy of choking algorithm."))
-o:value("RoundRobin", translate("Round Robin"))
-o:value("FastestUpload", translate("Fastest Upload"))
-o:value("AntiLeech", translate("Anti-Leech"))
-o.default = "FastestUpload"
-
-o = s:taboption("advanced", Flag, "AnnounceToAllTrackers", translate("Announce To All Trackers"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.disabled
-
-o = s:taboption("advanced", Flag, "AnnounceToAllTiers", translate("Announce To All Tiers"))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Flag, "Enabled", translate("Enable Log"), translate("Enable logger to log file."))
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Value, "Path", translate("Log Path"), translate("The path for qbittorrent log."))
-o:depends("Enabled", "true")
-
-o = s:taboption("advanced", Flag, "Backup", translate("Enable Backup"), translate("Backup log file when oversize the given size."))
-o:depends("Enabled", "true")
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Flag, "DeleteOld", translate("Delete Old Backup"), translate("Delete the old log file."))
-o:depends("Enabled", "true")
-o.enabled = "true"
-o.disabled = "false"
-o.default = o.enabled
-
-o = s:taboption("advanced", Value, "MaxSizeBytes", translate("Log Max Size"), translate("The max size for qbittorrent log (Unit: Bytes)."))
-o:depends("Enabled", "true")
-o.placeholder = "66560"
-
-o = s:taboption("advanced", Value, "SaveTime", translate("Log Saving Period"), translate("The log file will be deteted after given time. 1d -- 1 day, 1m -- 1 month, 1y -- 1 year"))
-o:depends("Enabled", "true")
-o.datatype = "string"
-
-return m
+return m
\ No newline at end of file
diff --git a/package/lean/luci-app-qbittorrent/po/zh-cn/qbittorrent.po b/package/lean/luci-app-qbittorrent/po/zh-cn/qbittorrent.po
index 001a33f599..51013dab4f 100644
--- a/package/lean/luci-app-qbittorrent/po/zh-cn/qbittorrent.po
+++ b/package/lean/luci-app-qbittorrent/po/zh-cn/qbittorrent.po
@@ -50,525 +50,4 @@ msgid "WEBUI Settings"
msgstr "WEBUI设置"
msgid "WEBUI listening port"
-msgstr "WebUI 监听端口"
-
-msgid "Use Random Port"
-msgstr "随机传入连接端口"
-
-msgid "Randomly assigns a different port every time qBittorrent starts up"
-msgstr "在每次启动时使用不同的传入连接端口"
-
-msgid "Connection Port"
-msgstr "用于传入连接的端口"
-
-msgid "Incoming connection port"
-msgstr "推荐在防火墙 -> 流量规则 中,打开这个端口获得更好的下载速度( TCP+UDP )"
-
-msgid "Bittorrent Settings"
-msgstr "Bittorrent 设置"
-
-msgid "WebUI Settings"
-msgstr "WebUI 设置"
-
-msgid "Advance Settings"
-msgstr "高级设置"
-
-
-msgid "Run daemon as user"
-msgstr "用户组"
-
-msgid "Parent Path for Profile Folder"
-msgstr "配置保存路径"
-
-msgid "The path for storing profile folder using by command: --profile [PATH] ."
-msgstr "配置文件的保存路径,默认的配置文件夹在/tmp下。例如:/etc/config"
-
-msgid "Profile Folder Suffix"
-msgstr "配置目录后缀"
-
-msgid "Suffix for profile folder, for example, qBittorrent_[NAME] ."
-msgstr "配置文件文件夹的后缀。例如: qBittorrent_[NAME] "
-
-msgid "Locale Language"
-msgstr "WebUI语言"
-
-msgid "English"
-msgstr "英文"
-
-msgid "Chinese"
-msgstr "中文"
-
-msgid "Enable Log"
-msgstr "启用日志"
-
-msgid "Enable logger to log file."
-msgstr "qBittorrent的启动和运行信息文档。"
-
-msgid "Log Path"
-msgstr "日志文件"
-
-msgid "The path for qbittorrent log."
-msgstr "日志文件自定义保存路径,默认都在配置文件夹的data下。"
-
-msgid "Enable Backup"
-msgstr "启用备份"
-
-msgid "Backup log file when oversize the given size."
-msgstr "备份日志文件。"
-
-msgid "Delete Old Backup"
-msgstr "删除备份"
-
-msgid "Delete the old log file."
-msgstr "符合下列设定后将删除旧的日志文件。"
-
-msgid "Log Max Size"
-msgstr "日志保存大小"
-
-msgid "Log Saving Period"
-msgstr "日志保存期限"
-
-msgid "The max size for qbittorrent log (Unit: Bytes)."
-msgstr "设定日志文件的大小(单位:字节)"
-
-msgid "The log file will be deteted after given time. 1d -- 1 day, 1m -- 1 month, 1y -- 1 year"
-msgstr "设定日志文件的时间(1d-1天,1m-1个月,1y-1年)"
-
-msgid "Connection Settings"
-msgstr "连接设置"
-
-msgid "Use UPnP for Connections"
-msgstr "端口自动转发"
-
-msgid "Use UPnP/ NAT-PMP port forwarding from my router."
-msgstr "使用路由器的UPnP/NAT-PMP端口自动转发。"
-
-msgid "Use Random Port"
-msgstr "启用随机端口"
-
-msgid "Use different port on each startup voids the first"
-msgstr "在每次启动时使用随机的端口。"
-
-msgid "Connection Port"
-msgstr "自定义端口"
-
-msgid "Generate Randomly"
-msgstr "默认端口:8999"
-
-msgid "Global Download Speed"
-msgstr "全局下载速度限制"
-
-msgid "Global Download Speed Limit(KiB/s)."
-msgstr "全局下载速度限制(KiB/s),0为无限制。"
-
-msgid "Global Upload Speed"
-msgstr "全局上传速度限制"
-
-msgid "Alternative Download Speed"
-msgstr "备用下载速度限制"
-
-msgid "Alternative Upload Speed"
-msgstr "备用上传速度限制"
-
-msgid "Global Upload Speed Limit(KiB/s)."
-msgstr "全局上传速度限制(KiB/s),0为无限制。"
-
-msgid "Alternative Download Speed Limit(KiB/s)."
-msgstr "备用下载速度限制(KiB/s),0为无限制。"
-
-msgid "Alternative Upload Speed Limit(KiB/s)."
-msgstr "备用上传速度限制(KiB/s),0为无限制。"
-
-msgid "Enabled protocol"
-msgstr "启用的协议"
-
-msgid "The protocol that was enabled."
-msgstr "当前已启用的协议。"
-
-msgid "TCP and UTP"
-msgstr "TCP和UTP"
-
-msgid "Inet Address"
-msgstr "输入地址"
-
-msgid "The address that respond to the trackers."
-msgstr "响应跟踪器的地址。"
-
-msgid "When adding seeds"
-msgstr "当添加种子时"
-
-msgid "Downloads Settings"
-msgstr "下载设置"
-
-msgid "Create Subfolder"
-msgstr "创建目录"
-
-msgid "Create subfolder for torrents with multiple files."
-msgstr "为含多个文件的种子创建子文件夹。"
-
-msgid "Start In Pause"
-msgstr "开始暂停"
-
-msgid "Do not start the download automatically."
-msgstr "在下载任务添加后暂停。"
-
-msgid "Auto Delete Torrent File"
-msgstr "删除种子"
-
-msgid "The .torrent files will be deleted afterwards."
-msgstr "下载完成后自动删除这个种子文件。"
-
-msgid "Pre Allocation"
-msgstr "磁盘预分配"
-
-msgid "Pre-allocate disk space for all files."
-msgstr "为刚添加的文件预先分配磁盘空间。"
-
-msgid "Use Incomplete Extension"
-msgstr "使用扩展名"
-
-msgid "The incomplete task will be added the extension of !qB."
-msgstr "为不完整的文件添加后缀名!qB"
-
-msgid "Save Path"
-msgstr "文件保存路径"
-
-msgid "The path to save the download file. For example:/mnt/sda1/download"
-msgstr "下载文件的保存路径。例如:/mnt/sda1/download"
-
-msgid "Temp Path Enabled"
-msgstr "启用临时目录"
-
-msgid "Temp Path"
-msgstr "临时路径"
-
-msgid "The absolute and relative path can be set."
-msgstr "可以设置绝对和相对路径。"
-
-msgid "Disk Cache Size (MiB)"
-msgstr "磁盘缓存"
-
-msgid "The value -1 is auto and 0 is disable. In default, it is set to 64MiB."
-msgstr "数值1是自动的,0是禁用的。默认设置为64MiB。"
-
-msgid "Disk Cache TTL (s)"
-msgstr "磁盘缓存TTL"
-
-msgid "In default, it is set to 60s."
-msgstr "默认设置为60秒。"
-
-msgid "Saving Management"
-msgstr "保存管理"
-
-msgid "Default Torrent Management Mode"
-msgstr "默认种子管理模式"
-
-msgid "Manual"
-msgstr "手动"
-
-msgid "Automaic"
-msgstr "自动"
-
-msgid "Torrent Category Changed"
-msgstr "当种子分类修改时"
-
-msgid "Choose the action when torrent category changed."
-msgstr "选择种子类别更改时的操作。"
-
-msgid "Switch torrent to Manual Mode"
-msgstr "将种子切换到手动模式"
-
-msgid "Relocate torrent"
-msgstr "重新定位种子"
-
-msgid "Default Save Path Changed"
-msgstr "当默认保存路径修改时"
-
-msgid "Choose the action when default save path changed."
-msgstr "选择默认保存路径更改时的操作。"
-
-msgid "Switch affected torrent to Manual Mode"
-msgstr "将受影响的种子切换到手动模式"
-
-msgid "Relocate affected torrent"
-msgstr "重新定位种子"
-
-msgid "Category Save Path Changed"
-msgstr "当分类保存路径修改时"
-
-msgid "Choose the action when category save path changed."
-msgstr "选择分类保存路径更改时的操作。"
-
-msgid "Torrent Export Dir"
-msgstr "种子导出目录"
-
-msgid "The .torrent files will be copied to the target directory."
-msgstr "种子文件将被复制到目标目录。例如:/etc/config"
-
-msgid "Finished Torrent Export Dir"
-msgstr "复制种子文件"
-
-msgid "The .torrent files for finished downloads will be copied to the target directory."
-msgstr "将已下载完成的种子文件复制到目标目录。例如:/etc/config"
-
-msgid "Bittorrent Settings"
-msgstr "BT设置""
-
-msgid "Enable DHT"
-msgstr "启用DHT"
-
-msgid "Enable DHT (decentralized network) to find more peers"
-msgstr "启用DHT(去中心化网络) 以找到更多用户。"
-
-msgid "Enable PeX"
-msgstr "启用PeX"
-
-msgid "Enable Peer Exchange (PeX) to find more peers"
-msgstr "启用用户交换(PeX)以找到更多用户。"
-
-msgid "Enable LSD"
-msgstr "启用LSD"
-
-msgid "Enable Local Peer Discovery to find more peers"
-msgstr "启用本地用户发现以找到更多用户。"
-
-msgid "uTP Rate Limit"
-msgstr "uTP速度限制"
-
-msgid "Apply rate limit to µTP protocol."
-msgstr "针对µTP协议进行速度限制。"
-
-msgid "Encryption Mode"
-msgstr "加密模式"
-
-msgid "Enable DHT (decentralized network) to find more peers"
-msgstr "使DHT(分散网络)能够找到更多的对等点。"
-
-msgid "Prefer Encryption"
-msgstr "偏好加密"
-
-msgid "Require Encryption"
-msgstr "强制加密"
-
-msgid "Disable Encryption"
-msgstr "禁用加密"
-
-msgid "Max Connections"
-msgstr "连接数限制"
-
-msgid "The max number of connections."
-msgstr "全局最大连接数。"
-
-msgid "Max Connections Per Torrent"
-msgstr "种子连接数限制"
-
-msgid "The max number of connections per torrent."
-msgstr "每个种子的最大连接数。"
-
-msgid "Max Uploads"
-msgstr "最大上传数"
-
-msgid "The max number of connected peers."
-msgstr "全局最大上传线程数。"
-
-msgid "Max Uploads Per Torrent"
-msgstr "种子上传限制"
-
-msgid "The max number of connected peers per torrent."
-msgstr "每个种子上传线程最大值。"
-
-msgid "Share rate limit"
-msgstr "分享率限制"
-
-msgid "Max Ratio"
-msgstr "最大的分享率"
-
-msgid "The max ratio for seeding. -1 is to disable the seeding."
-msgstr "分享的最大比例设定。-1是禁用做种。"
-
-msgid "Max Seeding Minutes"
-msgstr "最大做种时间"
-
-msgid "Units: minutes"
-msgstr "做种最大比例设定。单位:分钟"
-
-msgid "Max Ratio Action"
-msgstr "达到后"
-
-msgid "The action when reach the max seeding ratio."
-msgstr "达到设定分享率和时间后的动作。"
-
-msgid "Pause them"
-msgstr "暂停"
-
-msgid "Remove them"
-msgstr "删除"
-
-msgid "Queueing Setting"
-msgstr "种子排队设置"
-
-msgid "Enable Torrent Queueing"
-msgstr "启用种子排队"
-
-msgid "Maximum Active Downloads"
-msgstr "最大活动的下载数"
-
-msgid "Max Active Uploads"
-msgstr "最大活动的上传数"
-
-msgid "Max Active Torrents"
-msgstr "最大活动的种子数"
-
-msgid "Ignore Slow Torrents"
-msgstr "忽略慢速的种子"
-
-msgid "Do not count slow torrents in these limits."
-msgstr "慢速的种子不包在括限制内。"
-
-msgid "Download rate threshold"
-msgstr "下载速度阈值"
-
-msgid "Upload rate threshold"
-msgstr "上传速度阈值"
-
-msgid "Units: KiB/s"
-msgstr "单位:KiB/s"
-
-msgid "Torrent inactivity timer"
-msgstr "种子不活动时间"
-
-msgid "Units: seconds"
-msgstr "时间单位:分钟"
-
-msgid "WebUI Settings"
-msgstr "WebUI设置"
-
-msgid "Username"
-msgstr ""
-
-msgid "Password"
-msgstr ""
-
-msgid "Use UPnP for WebUI"
-msgstr "WebUI端口转发"
-
-msgid "Using the UPnP / NAT-PMP port of the router for connecting to WebUI."
-msgstr "使用路由器的UPnP/NAT-PMP端口转发到WebUI。"
-
-msgid "The login name for WebUI."
-msgstr "WebUI的登录用户名设置。"
-
-msgid "The login password for WebUI."
-msgstr "WebUI用户的登录密码设置。"
-
-msgid "The listening port for WebUI."
-msgstr "WebUI的登录端口设置。默认端口:8080"
-
-msgid "CSRF Protection"
-msgstr "CSRF保护"
-
-msgid "Enable Cross-Site Request Forgery (CSRF) protection."
-msgstr "启用跨站点请求伪造(CSRF)保护。"
-
-msgid "Clickjacking Protection"
-msgstr "劫持保护"
-
-msgid "Enable clickjacking protection."
-msgstr "启用点击劫持保护。"
-
-msgid "Host Header Validation"
-msgstr "主机标头验证"
-
-msgid "Validate the host header."
-msgstr "启用主机标头验证."
-
-msgid "Local Host Authentication"
-msgstr "本地主机认证"
-
-msgid "Force authentication for clients on localhost."
-msgstr "强制对本地主机上的客户端进行身份验证。"
-
-msgid "Enable Subnet Whitelist"
-msgstr "使子网白名单"
-
-msgid "Subnet Whitelist"
-msgstr "输入IP地址"
-
-msgid "Skip authentication for clients in the IP subnet white list."
-msgstr "对IP子网白名单中的客户端跳过身份验证."
-
-msgid "Advance Settings"
-msgstr "高级设置"
-
-msgid "Anonymous Mode"
-msgstr "匿名模式"
-
-msgid "When enabled, qBittorrent will take certain measures to try"
-msgstr "启用后,qBittorrent将采取某些措施隐藏其身份。"
-
-msgid "Super Seeding"
-msgstr "超级种子"
-
-msgid "The super seeding mode."
-msgstr "超级种子模式。"
-
-msgid "Limit Overhead Usage"
-msgstr "开销限制"
-
-msgid "The overhead usage is been limitted."
-msgstr "对传送总开销进行速度限制。"
-
-msgid "Ignore LAN Limit"
-msgstr "LAN限制"
-
-msgid "Ignore the speed limit to LAN."
-msgstr "忽略对LAN的速度限制。"
-
-msgid "Use os Cache"
-msgstr "使用OS操作系统缓存管理"
-
-msgid "Max Outgoing Port"
-msgstr "端口设置"
-
-msgid The max outgoing port.""
-msgstr "最大输出端口。"
-
-msgid "Min Outgoing Port"
-msgstr "端口设置"
-
-msgid "The min outgoing port."
-msgstr "最小输出端口。"
-
-msgid "Choking Algorithm"
-msgstr "数据传输算法"
-
-msgid "The strategy of choking algorithm."
-msgstr "数据传输算法的策略。"
-
-msgid "Round Robin"
-msgstr "负载均衡"
-
-msgid "Fastest Upload"
-msgstr "最快上传"
-
-msgid "Anti-Leech"
-msgstr "反吸血"
-
-msgid "Announce To All Trackers"
-msgstr "对所有Trackers宣告"
-
-msgid "Announce To All Tiers"
-msgstr "对所有Tiers宣告"
-
-msgid "configuration file"
-msgstr "配置文件"
-
-msgid "Operation log"
-msgstr "运行日志"
-
-msgid "This page is the log document content of qbittorrent."
-msgstr "本页是qBittorrent的日志文档内容。"
-
-msgid "This page is the content of the configuration document under /etc/config/qbittorrent."
-msgstr "本页是/etc/config/qbittorrent下的配置文档内容。"
-
+msgstr "WEBUI监听端口"
diff --git a/package/lean/luci-app-qbittorrent/root/etc/config/qbittorrent b/package/lean/luci-app-qbittorrent/root/etc/config/qbittorrent
index 4ec138ff67..1de5a8ff05 100644
--- a/package/lean/luci-app-qbittorrent/root/etc/config/qbittorrent
+++ b/package/lean/luci-app-qbittorrent/root/etc/config/qbittorrent
@@ -1,19 +1,11 @@
+config basic
+ option program_dir '/usr/bin'
+ option library_dir '/usr/lib'
+ option profile_dir '/root'
+ option enable '0'
-config qbittorrent 'main'
- option user 'root'
- option Locale 'zh'
- option BTProtocol 'Both'
- option DisableAutoTMMByDefault 'true'
- option CategoryChanged 'false'
- option DefaultSavePathChanged 'true'
- option CategorySavePathChanged 'true'
- option Encryption '0'
- option MaxRatioAction '0'
- option CSRFProtection 'false'
- option SeedChokingAlgorithm 'FastestUpload'
- option Enabled 'false'
- option Port '8080'
- option profile '/opt'
- option enabled '0'
+config Preferences
+ option download_dir '/root/download'
+ option port '8080'
diff --git a/package/lean/luci-app-qbittorrent/root/etc/init.d/qbittorrent b/package/lean/luci-app-qbittorrent/root/etc/init.d/qbittorrent
index 274aa45719..f0ffe055ac 100755
--- a/package/lean/luci-app-qbittorrent/root/etc/init.d/qbittorrent
+++ b/package/lean/luci-app-qbittorrent/root/etc/init.d/qbittorrent
@@ -1,264 +1,79 @@
#!/bin/sh /etc/rc.common
-# Licensed to the public under the Apache License 2.0.
-# ubus call service list
-
START=99
-USE_PROCD=1
-
-NAME=qbittorrent
-args=/usr/bin/qbittorrent-nox
-
-QBT_PID_FILE=/var/run/qbittorrent.pid
-QBT_INI_FILE=/tmp/qBittorrent/config/qBittorrent.conf
-
-QBT_INSTANCE=""
-
-_info() {
- logger -p daemon.info -t "$NAME" "$*"
+get_config()
+{
+ config_get_bool enable $1 enable 0
}
-_err() {
- logger -p daemon.err -t "$NAME" "$*"
-}
+config_qbittorrent()
+{
+ local download_dir
+ local port
+ config_get download_dir $1 download_dir
+ config_get port $1 port
+ if [ -f $2/qBittorrent/config/qBittorrent.conf ]; then
+ sed -i 's/WebUI\\Port=[0-9]*/WebUI\\Port='"$port"'/g' $2/qBittorrent/config/qBittorrent.conf
+ sed -i 's/Downloads\\SavePath=[a-z,/]*//g' $2/qBittorrent/config/qBittorrent.conf
+ echo "Downloads\SavePath=$down" >> $2/qBittorrent/config/qBittorrent.conf
+ else
+ cat>$2/qBittorrent/config/qBittorrent.conf<"$QBT_INI_FILE"</dev/null 2>&1;
- return 1;
- }
-
- local confdir="qBittorrent"
- [ -n "$configuration" ] && {
- confdir="qBittorrent_$configuration"
- }
-
- [ -d "$profile/$confdir/config" ] || {
- mkdir -m 0755 -p "$profile/$confdir/config"
- }
-
- [ "$user" != "root" ] && {
- [ -d "$confdir" ] && {
- local groupnow="$(ls -l $profile | grep $confdir | awk '{print $3})"
- local usernow="$(ls -l $profile | grep $confdir | awk '{print $4})"
-
- [ "$usernow" != "$user" ] && { _err "Permission denied!"; return 1; }
- } || {
- chmod -R g+w "$profile/$confdir"
- chown -R "$user":"$user" "$profile/$confdir"
- }
- }
-
- [ "$AuthSubnetWhitelistEnabled" = true ] && {
- AuthSubnetWhitelist="$( echo $AuthSubnetWhitelist | sed 's/ /,/g')"
- } || {
- AuthSubnetWhitelist="@Invalid()"
- }
-
- QBT_INI_FILE="$profile/$confdir/config/qBittorrent.conf"
- config_QBT
-
- procd_open_instance $QBT_INSTANCE
- procd_set_param command $args
- procd_append_param command --profile="$profile"
-
- [ -n "$configuration" ] && {
- procd_append_param command --configuration="$configuration"
- }
-
- procd_set_param respawn
- procd_set_param user $user
- procd_set_param file $QBT_INI_FILE
- procd_set_param pidfile $QBT_PID_FILE
- procd_close_instance
-}
-
-service_triggers()
+
+run_qbittorrent()
{
- procd_add_reload_trigger "$NAME"
+ local enable
+ config_get_bool enable $1 enable
+
+ if [ $enable ]; then
+ local profile_dir
+ config_get profile_dir $1 profile_dir
+ config_foreach config_qbittorrent 'Preferences' $profile_dir
+ if [ "$profile_dir" != "" ]; then
+ mkdir -p $profile_dir/qBittorrent
+ ln -sf /etc/qBittorrent/ipfilter.dat $profile_dir/qBittorrent/ipfilter.dat
+ config_get library_dir $1 library_dir
+ config_get program_dir $1 program_dir
+ export PATH=$PATH:$program_dir
+ export LD_LIBRARY_PATH=$library_dir
+ qbittorrent-nox -d --profile=$profile_dir
+ else
+ echo "no profile_dir,stop!"
+ fi
+
+ fi
}
-start_service() {
- config_load "$NAME"
- config_foreach init_QBT "$NAME"
-}
-
-reload_service() {
- restart
-}
-
-restart() {
+start()
+{
stop
- sleep 2
- start
+ local profile_path
+ config_load 'qbittorrent'
+ config_foreach get_config basic
+ [ $enable -eq 0 ] && exit 0
+ config_foreach run_qbittorrent 'basic'
+}
+
+stop()
+{
+ killall qbittorrent-nox >/dev/null 2>&1
+ return 0
}
diff --git a/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/luci-qbittorrent b/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/luci-qbittorrent
deleted file mode 100644
index dd2c37d8d8..0000000000
--- a/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/luci-qbittorrent
+++ /dev/null
@@ -1,21 +0,0 @@
-#!/bin/sh
-
-uci -q batch <<-EOF >/dev/null
- delete ucitrack.@qbittorrent[-1]
- add ucitrack qbittorrent
- set ucitrack.@qbittorrent[-1].init=qbittorrent
- commit ucitrack
-EOF
-
-if [ ."$(uci -q get qbittorrent.main)" != ."qbittorrent" ]; then
- uci -q batch <<-EOF >/dev/null
- add qbittorrent qbittorrent
- rename qbittorrent.@qbittorrent[-1]="main"
- set qbittorrent.main.enabled=0
- set qbittorrent.main.profile="/tmp"
- commit qbittorrent
- EOF
-fi
-
-rm -f /tmp/luci-indexcache
-exit 0
diff --git a/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/qbittorrent b/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/qbittorrent
new file mode 100755
index 0000000000..c9995c1562
--- /dev/null
+++ b/package/lean/luci-app-qbittorrent/root/etc/uci-defaults/qbittorrent
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+uci -q batch <<-EOF >/dev/null
+ delete ucitrack.@qbittorrent[-1]
+ add ucitrack qbittorrent
+ set ucitrack.@qbittorrent[-1].init=qbittorrent
+ commit ucitrack
+EOF
+
+/etc/init.d/qbittorrent stop
+rm -f /tmp/luci-indexcache
+exit 0
diff --git a/package/lean/qBittorrent/Makefile b/package/lean/qBittorrent-Enhanced-Edition/Makefile
similarity index 66%
rename from package/lean/qBittorrent/Makefile
rename to package/lean/qBittorrent-Enhanced-Edition/Makefile
index 3bd02e2658..1aec416df2 100644
--- a/package/lean/qBittorrent/Makefile
+++ b/package/lean/qBittorrent-Enhanced-Edition/Makefile
@@ -1,14 +1,14 @@
include $(TOPDIR)/rules.mk
-PKG_NAME:=qbittorrent
-PKG_VERSION:=4.1.9
+PKG_NAME:=qBittorrent-Enhanced-Edition
+PKG_VERSION:=4.2.1.10
PKG_RELEASE=5
PKG_SOURCE:=$(PKG_NAME)-release-$(PKG_VERSION).tar.gz
-PKG_SOURCE_URL:=https://codeload.github.com/qbittorrent/qBittorrent/tar.gz/release-$(PKG_VERSION)?
-PKG_HASH:=620127f73f88ed3f2b2e4195cbc641f7c27f967d3b045e45f7916c0995fd61fe
+PKG_SOURCE_URL:=https://codeload.github.com/c0re100/qBittorrent-Enhanced-Edition/tar.gz/release-$(PKG_VERSION)?
+PKG_HASH:=78b0116c00d791328d2ad4f84f7447e2208bf0eb5798c4da2ae4404ac00cad2b
-PKG_BUILD_DIR:=$(BUILD_DIR)/qBittorrent-release-$(PKG_VERSION)
+PKG_BUILD_DIR:=$(BUILD_DIR)/qBittorrent-Enhanced-Edition-release-$(PKG_VERSION)
PKG_LICENSE:=GPL-2.0+
PKG_LICENSE_FILES:=COPYING
@@ -19,16 +19,16 @@ PKG_USE_MIPS16:=0
include $(INCLUDE_DIR)/package.mk
-define Package/qBittorrent
+define Package/$(PKG_NAME)
SUBMENU:=BitTorrent
SECTION:=net
CATEGORY:=Network
TITLE:=bittorrent client programmed in C++ / Qt
- URL:=https://www.qbittorrent.org/
+ URL:=https://github.com/c0re100/qBittorrent-Enhanced-Edition
DEPENDS:=+qt5-core +qt5-network +qt5-xml +rblibtorrent
endef
-define Package/qBittorrent/description
+define Package/$(PKG_NAME)/description
qBittorrent is a bittorrent client programmed in C++ / Qt that uses
libtorrent (sometimes called libtorrent-rasterbar) by Arvid Norberg.
It aims to be a good alternative to all other bittorrent clients out
@@ -49,11 +49,13 @@ define Build/Prepare
$(SED) '//{:a;N;/<\/context>/!ba;/\/gui\//d}' `ls $(PKG_BUILD_DIR)/src/lang/qbittorrent_*.ts`
endef
-define Package/qBittorrent/install
+define Package/$(PKG_NAME)/install
$(INSTALL_DIR) $(1)/usr/man/man1
$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/man/man1/qbittorrent-nox.1 $(1)/usr/man/man1/qbittorrent-nox.1
$(INSTALL_DIR) $(1)/usr/bin
$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/qbittorrent-nox $(1)/usr/bin
+ $(INSTALL_DIR) $(1)/etc/qBittorrent
+ $(INSTALL_DATA) ./files/ipfilter.dat $(1)/etc/qBittorrent/ipfilter.dat
endef
-$(eval $(call BuildPackage,qBittorrent))
+$(eval $(call BuildPackage,$(PKG_NAME)))
diff --git a/package/lean/qBittorrent-Enhanced-Edition/files/ipfilter.dat b/package/lean/qBittorrent-Enhanced-Edition/files/ipfilter.dat
new file mode 100644
index 0000000000..4cb41cd5db
--- /dev/null
+++ b/package/lean/qBittorrent-Enhanced-Edition/files/ipfilter.dat
@@ -0,0 +1,293 @@
+14.17.29.0 - 14.17.44.255 , 0 , Tencent Offline
+14.17.101.0 - 14.17.101.255 , 0 , Baidu Offline
+14.29.92.0 - 14.29.92.255 , 0 , Xunlei Offline
+14.215.177.0 - 14.215.177.255 , 0 , Baidu Offline
+23.3.68.0 - 23.3.68.255 , 0 , Tencent Offline
+27.221.20.0 - 27.221.21.255 , 0 , 360
+27.221.36.0 - 27.221.38.255 , 0 , Baidu Offline
+36.110.198.0 - 36.110.198.255 , 0 , Baidu Offline
+36.248.6.0 - 36.248.6.255 , 0 , Baidu Offline
+36.250.0.0 - 36.250.0.255 , 0 , Baidu Offline
+36.251.188.0 - 36.251.188.255 , 0 , Baidu Offline
+42.56.64.0 - 42.56.65.255 , 0 , Tencent Offline
+42.236.4.0 - 42.236.7.255 , 0 , Baidu Offline
+45.113.68.0 - 45.113.71.255 , 0 , Tencent Offline
+49.4.0.0 - 49.4.127.255 , 0 , HUAWEI
+49.51.0.0 - 49.51.31.255 , 0 , Tencent Offline
+58.48.212.0 - 58.48.212.255 , 0 , Tencent Offline
+58.51.144.0 - 58.51.144.255 , 0 , Xunlei Offline
+58.61.39.0 - 58.61.152.255 , 0 , Xunlei Offline
+58.67.137.0 - 58.67.137.255 , 0 , Xunlei Offline
+58.198.42.0 - 58.198.42.255 , 0 , Tencent Offline
+58.215.118.0 - 58.215.123.255 , 0 , Baidu Offline
+58.217.200.0 - 58.217.222.255 , 0 , Baidu Offline
+58.220.12.0 - 58.220.12.255 , 0 , Xunlei Offline
+58.222.18.0 - 58.222.25.255 , 0 , Baidu Offline
+58.251.57.0 - 58.251.61.255 , 0 , Xunlei Offline
+58.252.209.0 - 58.252.209.255 , 0 , Xunlei Offline
+58.254.134.0 - 58.254.134.255 , 0 , Xunlei Offline
+58.255.249.0 - 58.255.253.255 , 0 , Xunlei Offline
+59.45.75.0 - 59.45.75.255 , 0 , Baidu Offline
+59.51.81.0 - 59.51.81.255 , 0 , Baidu Offline
+59.53.69.0 - 59.53.69.255 , 0 , Baidu Offline
+59.53.86.0 - 59.53.86.255 , 0 , Tencent Offline
+59.74.44.0 - 59.74.45.255 , 0 , Tencent Offline
+60.2.237.0 - 60.2.237.255 , 0 , Tencent Offline
+60.18.146.0 - 60.18.147.255 , 0 , Xunlei Offline
+60.19.64.0 - 60.19.64.255 , 0 , Xunlei Offline
+60.21.219.0 - 60.21.219.255 , 0 , Xunlei Offline
+60.28.9.0 - 60.28.22.255 , 0 , Baidu Offline
+60.160.190.0 - 60.160.190.255 , 0 , Xunlei Offline
+60.211.226.0 - 60.211.226.255 , 0 , Baidu Offline
+60.214.64.0 - 60.214.64.255 , 0 , Xunlei Offline
+60.217.235.0 - 60.217.236.255 , 0 , Xunlei Offline
+60.220.197.0 - 60.220.197.255 , 0 , Xunlei Offline
+60.221.254.0 - 60.221.254.255 , 0 , Xunlei Offline
+61.54.12.0 - 61.54.24.255 , 0 , Xunlei Offline
+61.54.47.0 - 61.54.47.255 , 0 , Baidu Offline
+61.132.226.0 - 61.132.226.255 , 0 , Baidu Offline
+61.135.145.0 - 61.135.191.255 , 0 , Baidu Offline
+61.137.90.0 - 61.137.90.255 , 0 , MNDISK Offline
+61.137.191.0 - 61.137.191.255 , 0 , Xunlei Offline
+61.138.131.0 - 61.138.131.255 , 0 , Tencent Offline
+61.138.177.0 - 61.138.177.255 , 0 , Xunlei Offline
+61.139.103.0 - 61.139.103.255 , 0 , Xunlei Offline
+61.147.76.0 - 61.147.94.255 , 0 , Xunlei Offline
+61.152.105.0 - 61.152.105.255 , 0 , Xunlei Offline
+61.153.56.0 - 61.153.56.255 , 0 , Baidu Offline
+61.155.149.0 - 61.155.165.255 , 0 , Baidu Offline
+61.155.183.0 - 61.155.183.255 , 0 , Xunlei Offline
+61.155.220.0 - 61.155.220.255 , 0 , Tencent Offline
+61.160.224.0 - 61.160.224.255 , 0 , 360
+61.160.230.0 - 61.160.231.255 , 0 , Tencent Offline
+61.160.253.0 - 61.160.253.255 , 0 , Tencent Offline
+61.164.120.0 - 61.164.120.255 , 0 , Tencent Offline
+61.164.155.0 - 61.164.155.255 , 0 , Baidu Offline
+61.173.85.0 - 61.173.85.255 , 0 , Xunlei Offline
+61.178.227.0 - 61.178.227.255 , 0 , Xunlei Offline
+61.179.109.0 - 61.179.109.255 , 0 , Baidu Offline
+61.182.137.0 - 61.182.137.255 , 0 , Baidu Offline
+61.183.55.0 - 61.183.55.255 , 0 , Xunlei Offline
+61.188.190.0 - 61.188.190.255 , 0 , Xunlei Offline
+61.235.71.0 - 61.235.71.255 , 0 , Xunlei Offline
+61.240.144.0 - 61.240.144.255 , 0 , 360
+64.251.96.0 - 64.251.111.255 , 0 , 360
+101.4.60.0 - 101.4.61.255 , 0 , 360
+101.64.181.0 - 101.64.181.255 , 0 , Baidu Offline
+101.69.162.0 - 101.69.162.255 , 0 , Baidu Offline
+101.71.56.0 - 101.71.56.255 , 0 , Baidu Offline
+101.198.0.0 - 101.199.255.255 , 0 , 360
+101.226.4.0 - 101.226.4.255 , 0 , 360
+101.226.63.0 - 101.226.76.255 , 0 , Tencent Offline
+101.226.180.0 - 101.226.180.255 , 0 , Xunlei Offline
+101.227.130.0 - 101.227.143.255 , 0 , Tencent Offline
+103.7.28.0 - 103.7.31.255 , 0 , Tencent Offline
+103.28.8.0 - 103.28.11.255 , 0 , 360
+103.31.200.0 - 103.31.203.255 , 0 , HUAWEI
+106.38.179.0 - 106.38.179.255 , 0 , Baidu Offline
+106.120.159.0 - 106.120.159.255 , 0 , Baidu Offline
+110.18.246.0 - 110.18.246.255 , 0 , Baidu Offline
+110.188.3.0 - 110.188.3.255 , 0 , Tencent Offline
+111.13.12.0 - 111.13.113.255 , 0 , Baidu Offline
+111.30.135.0 - 111.30.135.255 , 0 , Tencent Offline
+111.161.24.0 - 111.161.24.255 , 0 , Xunlei Offline
+111.206.36.0 - 111.206.76.255 , 0 , Baidu Offline
+112.25.34.0 - 112.25.34.255 , 0 , 115 Offline
+112.25.60.0 - 112.25.60.255 , 0 , 360
+112.80.23.0 - 112.80.23.255 , 0 , Xunlei Offline
+112.80.248.0 - 112.80.255.255 , 0 , Baidu Offline
+112.87.43.0 - 112.87.43.227 , 0 , Xunlei Offline
+112.90.17.0 - 112.90.17.255 , 0 , Xunlei Offline
+112.117.217.0 - 112.117.217.255 , 0 , Xunlei Offline
+112.253.12.0 - 112.253.12.255 , 0 , Baidu Offline
+113.105.143.0 - 113.105.143.255 , 0 , 115 Offline
+113.105.148.81 - 113.105.148.255 , 0 , Baidu Offline
+113.107.248.0 - 113.107.248.255 , 0 , Baidu Offline
+113.108.29.0 - 113.108.29.255 , 0 , Tencent Offline
+113.115.10.0 - 113.115.10.255 , 0 , Tencent Offline
+113.142.0.0 - 113.142.31.255 , 0 , Tencent Offline
+113.200.90.0 - 113.200.90.255 , 0 , Tencent Offline
+114.80.183.0 - 114.80.255.255 , 0 , Xunlei Offline
+114.112.202.0 - 114.112.202.255 , 0 , Xunlei Offline
+115.159.0.0 - 115.159.255.255 , 0 , Tencent Offline
+115.231.38.0 - 115.231.45.255 , 0 , Xunlei Offline
+115.236.96.0 - 115.236.153.255 , 0 , Tencent Offline
+115.238.230.0 - 115.238.243.255 , 0 , UC Offline
+115.239.210.0 - 115.239.212.255 , 0 , Baidu Offline
+116.10.186.0 - 116.10.186.255 , 0 , Xunlei Offline
+116.31.127.0 - 116.31.127.255 , 0 , Baidu Offline
+116.55.230.0 - 116.55.255.255 , 0 , Xunlei Offline
+116.57.183.0 - 116.57.255.255 , 0 , Tencent Offline
+116.211.117.0 - 116.211.117.255 , 0 , Baidu Offline
+116.253.190.0 - 116.253.190.255 , 0 , Tencent Offline
+117.21.185.0 - 117.21.185.255 , 0 , Tencent Offline
+117.25.132.0 - 117.25.132.255 , 0 , Tencent Offline
+117.27.148.0 - 117.27.149.255 , 0 , Baidu Offline
+117.34.6.0 - 117.34.6.255 , 0 , Tencent Offline
+117.34.28.0 - 117.34.37.255 , 0 , Baidu Offline
+117.34.91.0 - 117.34.91.255 , 0 , Xunlei Offline
+117.34.112.0 - 117.34.112.255 , 0 , Baidu Offline
+117.78.0.0 - 117.78.23.255 , 0 , HUAWEI
+118.122.36.0 - 118.122.88.255 , 0 , Xunlei Offline
+118.123.97.0 - 118.123.97.255 , 0 , Tencent Offline
+118.123.116.0 - 118.123.223.255 , 0 , Baidu Offline
+118.180.6.0 - 118.180.6.255 , 0 , Baidu Offline
+119.75.208.0 - 119.75.223.255 , 0 , Baidu Offline
+119.84.11.0 - 119.84.11.255 , 0 , Xunlei Offline
+119.84.72.0 - 119.84.72.255 , 0 , Tencent Offline
+119.84.110.0 - 119.84.114.255 , 0 , Xunlei Offline
+119.97.178.0 - 119.97.183.255 , 0 , Xunlei Offline
+119.120.94.0 - 119.120.94.255 , 0 , Xunlei Offline
+119.134.253.0 - 119.134.253.255 , 0 , Baidu Offline
+119.144.9.0 - 119.144.9.255 , 0 , Xunlei Offline
+119.147.15.0 - 119.147.41.255 , 0 , Tencent Offline
+119.147.99.0 - 119.147.249.255 , 0 , 115 Offline
+119.167.241.0 - 119.167.241.255 , 0 , Tencent Offline
+119.167.246.0 - 119.167.246.255 , 0 , Baidu Offline
+119.178.12.0 - 119.178.12.255 , 0 , Xunlei Offline
+119.188.11.0 - 119.188.132.255 , 0 , Xunlei Offline
+119.189.1.0 - 119.189.1.255 , 0 , Xunlei Offline
+120.52.114.0 - 120.52.114.255 , 0 , Baidu Offline
+121.9.209.0 - 121.9.255.255 , 0 , Xunlei Offline
+121.10.24.0 - 121.10.137.255 , 0 , Xunlei Offline
+121.11.68.0 - 121.11.68.255 , 0 , Tencent Offline
+121.12.94.0 - 121.12.94.255 , 0 , Baidu Offline
+121.14.35.0 - 121.14.35.255 , 0 , Baidu Offline
+121.14.82.0 - 121.14.97.255 , 0 , Xunlei Offline
+121.14.131.0 - 121.14.131.255 , 0 , Tencent Offline
+121.14.222.0 - 121.14.228.255 , 0 , Xunlei Offline
+122.70.142.0 - 122.70.142.255 , 0 , Baidu Offline
+122.136.46.0 - 122.136.46.255 , 0 , Baidu Offline
+122.141.227.0 - 122.141.235.255 , 0 , Xunlei Offline
+122.143.1.0 - 122.143.6.255 , 0 , Xunlei Offline
+122.143.15.0 - 122.143.15.255 , 0 , 360
+122.192.32.0 - 122.192.32.255 , 0 , Tencent Offline
+122.193.41.0 - 122.193.41.255 , 0 , Baidu Offline
+122.224.10.0 - 122.224.10.255 , 0 , Baidu Offline
+122.227.15.0 - 122.227.15.255 , 0 , Tencent Offline
+122.228.218.0 - 122.228.234.255 , 0 , Baidu Offline
+122.228.241.0 - 122.228.255.255 , 0 , Xunlei Offline
+123.66.33.0 - 123.66.33.255 , 0 , Xunlei Offline
+123.125.64.0 - 123.125.115.255 , 0 , Baidu Offline
+123.125.160.0 - 123.125.161.255 , 0 , 360
+123.129.219.0 - 123.129.255.255 , 0 , Xunlei Offline
+123.138.102.0 - 123.138.239.255 , 0 , Tencent Offline
+123.151.44.0 - 123.151.138.255 , 0 , Tencent Offline
+123.162.190.0 - 123.162.191.255 , 0 , Xunlei Offline
+123.183.223.0 - 123.183.223.255 , 0 , Xunlei Offline
+124.89.102.0 - 124.89.103.255 , 0 , Tencent Offline
+124.95.156.0 - 124.95.174.255 , 0 , Xunlei Offline
+124.115.1.0 - 124.115.14.255 , 0 , Tencent Offline
+124.115.215.0 - 124.115.215.255 , 0 , Baidu Offline
+124.160.163.0 - 124.160.171.255 , 0 , Tencent Offline
+124.161.23.0 - 124.161.23.255 , 0 , Tencent Offline
+124.165.216.0 - 124.165.216.255 , 0 , Baidu Offline
+124.193.227.0 - 124.193.227.255 , 0 , Baidu Offline
+124.225.122.0 - 124.225.122.255 , 0 , Tencent Offline
+124.228.42.0 - 124.228.42.255 , 0 , Tencent Offline
+124.232.148.0 - 124.232.148.255 , 0 , Xunlei Offline
+124.238.238.0 - 124.238.238.255 , 0 , Baidu Offline
+125.39.72.0 - 125.39.79.255 , 0 , Xunlei Offline
+125.39.126.0 - 125.39.255.255 , 0 , Tencent Offline
+125.46.42.0 - 125.46.42.255 , 0 , Xunlei Offline
+125.78.242.0 - 125.78.247.255 , 0 , Xunlei Offline
+125.218.29.0 - 125.218.29.255 , 0 , Tencent Offline
+125.221.46.0 - 125.221.46.255 , 0 , Xunlei Offline
+140.206.165.0 - 140.206.165.255 , 0 , Tencent Offline
+159.226.50.0 - 159.226.50.255 , 0 , Baidu Offline
+162.105.207.0 - 162.105.207.255 , 0 , Baidu Offline
+171.111.152.0 - 171.112.96.255 , 0 , Baidu Offline
+175.155.115.0 - 175.155.116.255 , 0 , Tencent Offline
+180.76.0.0 - 180.76.255.255 , 0 , Baidu Offline
+180.96.0.0 - 180.96.1.255 , 0 , Tencent Offline
+180.97.7.0 - 180.97.7.255 , 0 , Tencent Offline
+180.97.33.0 - 180.97.34.255 , 0 , Baidu Offline
+180.97.151.0 - 180.97.152.255 , 0 , Xunlei Offline
+180.149.131.0 - 180.149.145.255 , 0 , Baidu Offline
+180.153.91.0 - 180.153.115.255 , 0 , Xunlei Offline
+180.153.235.0 - 180.153.235.255 , 0 , 360
+182.86.197.0 - 182.86.197.255 , 0 , Baidu Offline
+182.118.13.0 - 182.118.125.255 , 0 , Xunlei Offline
+182.130.10.0 - 182.130.11.255 , 0 , Tencent Offline
+182.131.8.0 - 182.131.11.255 , 0 , Tencent Offline
+182.140.134.0 - 182.140.177.255 , 0 , Tencent Offline
+182.140.227.0 - 182.140.227.255 , 0 , 360
+182.150.1.0 - 182.150.1.255 , 0 , Baidu Offline
+182.247.251.0 - 182.247.251.255 , 0 , Xunlei Offline
+182.254.0.0 - 182.254.255.255 , 0 , Tencent Offline
+183.60.15.0 - 183.60.15.255 , 0 , Tencent Offline
+183.60.131.0 - 183.60.131.255 , 0 , Baidu Offline
+183.60.139.0 - 183.60.139.255 , 0 , 115 Offline
+183.60.208.0 - 183.60.209.255 , 0 , Xunlei Offline
+183.60.211.0 - 183.60.211.255 , 0 , 360
+183.60.235.0 - 183.60.235.255 , 0 , Baidu Offline
+183.61.49.0 - 183.61.49.255 , 0 , Tencent Offline
+183.61.133.0 - 183.61.133.255 , 0 , Baidu Offline
+183.63.33.0 - 183.63.33.255 , 0 , Xunlei Offline
+183.94.216.0 - 183.94.239.255 , 0 , Xunlei Offline
+183.131.32.0 - 183.131.39.255 , 0 , Baidu Offline
+183.136.133.0 - 183.136.133.255 , 0 , 360
+183.136.156.0 - 183.136.158.255 , 0 , Xunlei Offline
+183.136.218.0 - 183.136.218.255 , 0 , Baidu Offline
+183.157.36.0 - 183.157.36.255 , 0 , Xunlei Offline
+183.221.245.0 - 183.221.245.255 , 0 , Baidu Offline
+183.232.22.0 - 183.232.22.255 , 0 , Baidu Offline
+202.38.194.0 - 202.38.194.255 , 0 , Tencent Offline
+202.100.78.0 - 202.100.78.255 , 0 , Tencent Offline
+202.105.139.0 - 202.105.139.255 , 0 , Xunlei Offline
+202.105.182.0 - 202.105.182.255 , 0 , Tencent Offline
+202.108.11.0 - 202.108.250.255 , 0 , Baidu Offline
+203.195.64.0 - 203.195.95.255 , 0 , Tencent Offline
+203.195.128.0 - 203.195.255.255 , 0 , Tencent Offline
+203.205.128.0 - 203.205.255.255 , 0 , Tencent Offline
+210.38.3.0 - 210.38.3.255 , 0 , Tencent Offline
+210.39.2.0 - 210.39.2.255 , 0 , Tencent Offline
+211.90.25.0 - 211.90.25.255 , 0 , Baidu Offline
+211.98.168.0 - 211.98.171.255 , 0 , Xunlei Offline
+211.137.100.0 - 211.137.100.255 , 0 , Xunlei Offline
+211.151.210.0 - 211.151.210.255 , 0 , 115 Offline
+211.162.73.0 - 211.162.73.255 , 0 , Xunlei Offline
+218.6.13.0 - 218.6.13.255 , 0 , Xunlei Offline
+218.8.242.0 - 218.8.242.255 , 0 , Tencent Offline
+218.21.68.0 - 218.21.68.255 , 0 , Xunlei Offline
+218.22.90.0 - 218.22.90.255 , 0 , Tencent Offline
+218.26.232.0 - 218.26.232.255 , 0 , Xunlei Offline
+218.30.73.0 - 218.30.73.255 , 0 , Tencent Offline
+218.59.144.0 - 218.59.144.255 , 0 , Xunlei Offline
+218.60.11.0 - 218.60.11.255 , 0 , Tencent Offline
+218.75.140.0 - 218.75.140.255 , 0 , Baidu Offline
+218.75.172.0 - 218.75.172.255 , 0 , Xunlei Offline
+218.199.46.0 - 218.199.46.255 , 0 , Tencent Offline
+219.129.83.0 - 219.129.83.255 , 0 , Xunlei Offline
+219.134.132.0 - 219.134.132.255 , 0 , Xunlei Offline
+219.151.4.0 - 219.151.4.255 , 0 , Tencent Offline
+219.159.248.0 - 219.159.248.255 , 0 , MNDISK Offline
+220.113.9.0 - 220.113.9.255 , 0 , Xunlei Offline
+220.115.240.0 - 220.115.240.255 , 0 , Xunlei Offline
+220.161.209.0 - 220.161.209.255 , 0 , Baidu Offline
+220.170.192.0 - 220.170.192.255 , 0 , Tencent Offline
+220.181.5.0 - 220.181.167.255 , 0 , Baidu Offline
+220.249.103.0 - 220.249.103.255 , 0 , Xunlei Offline
+221.4.246.0 - 221.4.246.255 , 0 , Xunlei Offline
+221.5.8.0 - 221.5.8.255 , 0 , Xunlei Offline
+221.203.176.0 - 221.204.232.255 , 0 , Xunlei Offline
+221.215.87.0 - 221.215.87.255 , 0 , Xunlei Offline
+221.233.79.0 - 221.233.79.255 , 0 , Baidu Offline
+221.235.189.0 - 221.235.205.255 , 0 , Xunlei Offline
+221.236.21.0 - 221.236.30.255 , 0 , Tencent Offline
+221.238.25.0 - 221.238.25.255 , 0 , Xunlei Offline
+222.24.133.0 - 222.24.133.255 , 0 , Tencent Offline
+222.28.155.0 - 222.28.155.255 , 0 , Tencent Offline
+222.73.49.0 - 222.73.133.255 , 0 , Xunlei Offline
+222.73.183.0 - 222.73.183.255 , 0 , Tencent Offline
+222.133.46.0 - 222.133.46.255 , 0 , Baidu Offline
+222.141.53.0 - 222.141.53.255 , 0 , Xunlei Offline
+222.141.220.0 - 222.141.220.255 , 0 , Tencent Offline
+222.161.212.0 - 222.161.255.255 , 0 , Xunlei Offline
+222.186.17.0 - 222.186.19.255 , 0 , Xunlei Offline
+222.186.55.0 - 222.186.55.255 , 0 , Baidu Offline
+222.199.144.0 - 222.199.191.255 , 0 , Baidu Offline
+222.211.64.0 - 222.211.64.255 , 0 , Baidu Offline
+222.215.119.0 - 222.215.119.255 , 0 , Tencent Offline
+222.216.190.0 - 222.216.190.255 , 0 , Baidu Offline
+222.218.45.0 - 222.218.45.255 , 0 , Baidu Offline
diff --git a/package/lean/qBittorrent/patches/001-remove-ico-not-for-webui.patch b/package/lean/qBittorrent/patches/001-remove-ico-not-for-webui.patch
deleted file mode 100644
index ee27bbaca4..0000000000
--- a/package/lean/qBittorrent/patches/001-remove-ico-not-for-webui.patch
+++ /dev/null
@@ -1,126 +0,0 @@
---- a/src/icons/icons.qrc
-+++ b/src/icons/icons.qrc
-@@ -250,38 +250,16 @@
- flags/zm.svg
- flags/zw.svg
- L.gif
-- loading.png
- qbt-theme/application-exit.svg
-- qbt-theme/application-rss+xml.svg
-- qbt-theme/application-x-mswinurl.svg
- qbt-theme/checked.svg
- qbt-theme/configure.svg
-- qbt-theme/dialog-cancel.svg
-- qbt-theme/dialog-information.svg
-- qbt-theme/dialog-warning.svg
- qbt-theme/document-edit-verify.svg
- qbt-theme/document-edit.svg
-- qbt-theme/document-encrypt.svg
-- qbt-theme/document-import.svg
-- qbt-theme/document-new.svg
-- qbt-theme/document-properties.svg
-- qbt-theme/document-save.svg
-- qbt-theme/download.svg
-- qbt-theme/edit-clear-history.svg
- qbt-theme/edit-clear.svg
- qbt-theme/edit-copy.svg
-- qbt-theme/edit-cut.svg
- qbt-theme/edit-delete.svg
-- qbt-theme/edit-find-user.svg
- qbt-theme/edit-find.svg
-- qbt-theme/edit-paste.svg
- qbt-theme/edit-rename.svg
-- qbt-theme/folder-documents.svg
-- qbt-theme/folder-download.svg
-- qbt-theme/folder-new.svg
-- qbt-theme/folder-remote.svg
-- qbt-theme/gear.svg
-- qbt-theme/gear32.svg
- qbt-theme/go-bottom.svg
- qbt-theme/go-down.svg
- qbt-theme/go-top.svg
-@@ -295,43 +273,15 @@
- qbt-theme/kt-set-max-upload-speed.png
- qbt-theme/list-add.svg
- qbt-theme/list-remove.svg
-- qbt-theme/mail-folder-inbox.svg
-- qbt-theme/mail-mark-read.svg
- qbt-theme/media-playback-pause.svg
- qbt-theme/media-playback-start.svg
- qbt-theme/media-seek-forward.svg
-- qbt-theme/network-server.svg
-- qbt-theme/network-wired.svg
-- qbt-theme/object-locked.svg
-- qbt-theme/office-chart-line.svg
-- qbt-theme/preferences-desktop.svg
-- qbt-theme/preferences-other.svg
-- qbt-theme/preferences-system-network.svg
-- qbt-theme/preferences-web-browser-cookies.svg
-- qbt-theme/rss-config.png
- qbt-theme/security-high.svg
- qbt-theme/security-low.svg
-- qbt-theme/services.svg
-- qbt-theme/speedometer.svg
- qbt-theme/system-log-out.svg
-- qbt-theme/tab-close.svg
-- qbt-theme/task-attention.svg
-- qbt-theme/task-complete.png
-- qbt-theme/task-ongoing.png
-- qbt-theme/task-reject.png
-- qbt-theme/text-plain.svg
-- qbt-theme/tools-report-bug.svg
-- qbt-theme/unavailable.svg
-- qbt-theme/user-group-delete.svg
-- qbt-theme/user-group-new.svg
-- qbt-theme/view-calendar-journal.svg
- qbt-theme/view-categories.svg
-- qbt-theme/view-filter.svg
-- qbt-theme/view-preview.svg
-- qbt-theme/view-refresh.svg
- qbt-theme/view-statistics.svg
- qbt-theme/wallet-open.svg
-- qbt-theme/webui.svg
- skin/arrow-right.gif
- skin/bg-dropdown.gif
- skin/bg-handle-horizontal.gif
-@@ -342,7 +292,6 @@
- skin/completed.svg
- skin/connected.svg
- skin/disconnected.svg
-- skin/dock-tabs.gif
- skin/download.svg
- skin/downloading.svg
- skin/error.svg
-@@ -353,14 +302,11 @@
- skin/handle-icon-horizontal.gif
- skin/handle-icon.gif
- skin/knob.gif
-- skin/logo-blank.gif
- skin/logo.gif
- skin/logo2.gif
- skin/mascot.png
- skin/paused.svg
- skin/qbittorrent-tray.svg
-- skin/qbittorrent-tray-dark.svg
-- skin/qbittorrent-tray-light.svg
- skin/qbittorrent32.png
- skin/queued.svg
- skin/ratio.svg
-@@ -370,17 +316,12 @@
- skin/spacer.gif
- skin/spinner-placeholder.gif
- skin/spinner.gif
-- skin/splash.png
- skin/stalledDL.svg
- skin/stalledUP.svg
- skin/tabs.gif
- skin/toolbox-divider.gif
-- skin/toolbox-divider2.gif
- skin/uploading.svg
- slow.png
- slow_off.png
-- sphere.png
-- sphere2.png
-- url.png
-
-
diff --git a/package/lean/qBittorrent/patches/002-add-autoban-function.patch b/package/lean/qBittorrent/patches/002-add-autoban-function.patch
deleted file mode 100644
index 8de0f1e47b..0000000000
--- a/package/lean/qBittorrent/patches/002-add-autoban-function.patch
+++ /dev/null
@@ -1,807 +0,0 @@
---- a/src/base/bittorrent/peerinfo.cpp
-+++ b/src/base/bittorrent/peerinfo.cpp
-@@ -186,11 +186,26 @@ PeerAddress PeerInfo::address() const
- m_nativeInfo.ip.port());
- }
-
-+int PeerInfo::port() const
-+{
-+ return m_nativeInfo.ip.port();
-+}
-+
- QString PeerInfo::client() const
- {
- return QString::fromStdString(m_nativeInfo.client);
- }
-
-+QString PeerInfo::pid() const
-+{
-+ return QString::fromStdString(m_nativeInfo.pid.to_string());
-+}
-+
-+QString PeerInfo::pidtoclient() const
-+{
-+ return QString::fromStdString(libt::identify_client(m_nativeInfo.pid));
-+}
-+
- qreal PeerInfo::progress() const
- {
- return m_nativeInfo.progress;
---- a/src/base/bittorrent/peerinfo.h
-+++ b/src/base/bittorrent/peerinfo.h
-@@ -34,6 +34,7 @@
- #include
-
- #include
-+#include
-
- namespace BitTorrent
- {
-@@ -85,7 +86,10 @@ namespace BitTorrent
- bool isPlaintextEncrypted() const;
-
- PeerAddress address() const;
-+ int port() const;
- QString client() const;
-+ QString pid() const;
-+ QString pidtoclient() const;
- qreal progress() const;
- int payloadUpSpeed() const;
- int payloadDownSpeed() const;
---- a/src/base/bittorrent/session.cpp
-+++ b/src/base/bittorrent/session.cpp
-@@ -69,6 +69,7 @@
- #endif
-
- #include "base/algorithm.h"
-+#include "base/bittorrent/peerinfo.h"
- #include "base/exceptions.h"
- #include "base/global.h"
- #include "base/logger.h"
-@@ -335,6 +336,8 @@ Session::Session(QObject *parent)
- , m_isAltGlobalSpeedLimitEnabled(BITTORRENT_SESSION_KEY("UseAlternativeGlobalSpeedLimit"), false)
- , m_isBandwidthSchedulerEnabled(BITTORRENT_SESSION_KEY("BandwidthSchedulerEnabled"), false)
- , m_saveResumeDataInterval(BITTORRENT_SESSION_KEY("SaveResumeDataInterval"), 60)
-+ , m_autoBanUnknownPeer(BITTORRENT_SESSION_KEY("AutoBanUnknownPeer"), true)
-+ , m_showTrackerAuthWindow(BITTORRENT_SESSION_KEY("ShowTrackerAuthWindow"), true)
- , m_port(BITTORRENT_SESSION_KEY("Port"), 8999)
- , m_useRandomPort(BITTORRENT_SESSION_KEY("UseRandomPort"), false)
- , m_networkInterface(BITTORRENT_SESSION_KEY("Interface"))
-@@ -502,6 +505,7 @@ Session::Session(QObject *parent)
- libt::ip_filter filter;
- processBannedIPs(filter);
- m_nativeSession->set_ip_filter(filter);
-+ loadOfflineFilter();
- }
-
- m_categories = map_cast(m_storedCategories);
-@@ -518,6 +522,17 @@ Session::Session(QObject *parent)
- connect(m_refreshTimer, &QTimer::timeout, this, &Session::refresh);
- m_refreshTimer->start();
-
-+ // Unban Timer
-+ m_unbanTimer = new QTimer(this);
-+ m_unbanTimer->setInterval(500);
-+ connect(m_unbanTimer, &QTimer::timeout, this, &Session::processUnbanRequest);
-+
-+ // Ban Timer
-+ m_banTimer = new QTimer(this);
-+ m_banTimer->setInterval(500);
-+ connect(m_banTimer, &QTimer::timeout, this, &Session::autoBanBadClient);
-+ m_banTimer->start();
-+
- m_statistics = new Statistics(this);
-
- updateSeedingLimitTimer();
-@@ -1077,6 +1092,7 @@ void Session::configure()
- enableIPFilter();
- else
- disableIPFilter();
-+ loadOfflineFilter();
- m_IPFilteringChanged = false;
- }
-
-@@ -1905,6 +1921,95 @@ void Session::banIP(const QString &ip)
- }
- }
-
-+bool Session::checkAccessFlags(const QString &ip)
-+{
-+ libt::ip_filter filter = m_nativeSession->get_ip_filter();
-+ boost::system::error_code ec;
-+ libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
-+ Q_ASSERT(!ec);
-+ if (ec) return false;
-+ return filter.access(addr);
-+}
-+
-+void Session::tempblockIP(const QString &ip)
-+{
-+ libt::ip_filter filter = m_nativeSession->get_ip_filter();
-+ boost::system::error_code ec;
-+ libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
-+ Q_ASSERT(!ec);
-+ if (ec) return;
-+ filter.add_rule(addr, addr, libt::ip_filter::blocked);
-+ m_nativeSession->set_ip_filter(filter);
-+ insertQueue(ip);
-+}
-+
-+void Session::removeBlockedIP(const QString &ip)
-+{
-+ libt::ip_filter filter = m_nativeSession->get_ip_filter();
-+ boost::system::error_code ec;
-+ libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
-+ Q_ASSERT(!ec);
-+ if (ec) return;
-+ filter.add_rule(addr, addr, 0);
-+ m_nativeSession->set_ip_filter(filter);
-+}
-+
-+void Session::eraseIPFilter()
-+{
-+ q_bannedIPs.clear();
-+ q_unbanTime.clear();
-+ if (isIPFilteringEnabled()) {
-+ enableIPFilter();
-+ } else {
-+ disableIPFilter();
-+ loadOfflineFilter();
-+ }
-+}
-+
-+void Session::autoBanBadClient()
-+{
-+ const BitTorrent::SessionStatus tStatus = BitTorrent::Session::instance()->status();
-+ if (tStatus.peersCount > 0) {
-+ bool m_AutoBan = BitTorrent::Session::instance()->isAutoBanUnknownPeerEnabled();
-+ foreach (BitTorrent::TorrentHandle *const torrent, BitTorrent::Session::instance()->torrents()) {
-+ QList peers = torrent->peers();
-+ foreach (const BitTorrent::PeerInfo &peer, peers) {
-+ BitTorrent::PeerAddress addr = peer.address();
-+ if (addr.ip.isNull()) continue;
-+ QString ip = addr.ip.toString();
-+ int port = peer.port();
-+ QString client = peer.client();
-+ QString ptoc = peer.pidtoclient();
-+ QString pid = peer.pid().left(8);
-+ QString country = peer.country();
-+
-+ QRegExp IDFilter("-(XL|SD|XF|QD|BN|DL)(\\d+)-");
-+ QRegExp UAFilter("\\d+.\\d+.\\d+.\\d+");
-+ if (IDFilter.exactMatch(pid) || UAFilter.exactMatch(client)) {
-+ qDebug("Auto Banning bad Peer %s...", ip.toLocal8Bit().data());
-+ Logger::instance()->addMessage(tr("Auto banning bad Peer '%1'...'%2'...'%3'...'%4'").arg(ip).arg(pid).arg(ptoc).arg(country));
-+ tempblockIP(ip);
-+ continue;
-+ }
-+
-+ if(m_AutoBan) {
-+ if (client.contains("Unknown") && country == "CN") {
-+ qDebug("Auto Banning Unknown Peer %s...", ip.toLocal8Bit().data());
-+ Logger::instance()->addMessage(tr("Auto banning Unknown Peer '%1'...'%2'...'%3'...'%4'").arg(ip).arg(pid).arg(ptoc).arg(country));
-+ tempblockIP(ip);
-+ continue;
-+ }
-+ if (port >= 65000 && country == "CN" && client.contains("Transmission")) {
-+ qDebug("Auto Banning Offline Downloader %s...", ip.toLocal8Bit().data());
-+ Logger::instance()->addMessage(tr("Auto banning Offline Downloader '%1:%2'...'%3'...'%4'...'%5'").arg(ip).arg(port).arg(pid).arg(ptoc).arg(country));
-+ tempblockIP(ip);
-+ }
-+ }
-+ }
-+ }
-+ }
-+}
-+
- // Delete a torrent from the session, given its hash
- // deleteLocalFiles = true means that the torrent will be removed from the hard-drive too
- bool Session::deleteTorrent(const QString &hash, bool deleteLocalFiles)
-@@ -2787,6 +2892,30 @@ void Session::setSaveResumeDataInterval(
- }
- }
-
-+bool Session::isAutoBanUnknownPeerEnabled() const
-+{
-+ return m_autoBanUnknownPeer;
-+}
-+
-+void Session::setAutoBanUnknownPeer(bool value)
-+{
-+ if (value != isAutoBanUnknownPeerEnabled()) {
-+ m_autoBanUnknownPeer = value;
-+ }
-+}
-+
-+bool Session::isShowTrackerAuthWindow() const
-+{
-+ return m_showTrackerAuthWindow;
-+}
-+
-+void Session::setShowTrackerAuthWindow(bool value)
-+{
-+ if (value != isShowTrackerAuthWindow()) {
-+ m_showTrackerAuthWindow = value;
-+ }
-+}
-+
- int Session::port() const
- {
- static int randomPort = Utils::Random::rand(1024, 65535);
-@@ -3877,6 +4006,220 @@ void Session::disableIPFilter()
- m_nativeSession->set_ip_filter(filter);
- }
-
-+// Insert banned IP to Queue
-+void Session::insertQueue(QString ip)
-+{
-+ q_bannedIPs.enqueue(ip);
-+ q_unbanTime.enqueue(QDateTime::currentMSecsSinceEpoch() + 60 * 60 * 1000);
-+
-+ if (!m_unbanTimer->isActive()) {
-+ m_unbanTimer->start();
-+ }
-+}
-+
-+// Process Unban Queue
-+void Session::processUnbanRequest()
-+{
-+ if (q_bannedIPs.isEmpty() && q_unbanTime.isEmpty()) {
-+ m_unbanTimer->stop();
-+ }
-+ else if (m_isActive) {
-+ return;
-+ }
-+ else {
-+ m_isActive = true;
-+ int64_t currentTime = QDateTime::currentMSecsSinceEpoch();
-+ int64_t nextTime = q_unbanTime.dequeue();
-+ int delayTime = int(nextTime - currentTime);
-+ QString nextIP = q_bannedIPs.dequeue();
-+ if (delayTime < 0) {
-+ QTimer::singleShot(0, [=] { BitTorrent::Session::instance()->removeBlockedIP(nextIP); m_isActive = false; });
-+ }
-+ else {
-+ QTimer::singleShot(delayTime, [=] { BitTorrent::Session::instance()->removeBlockedIP(nextIP); m_isActive = false; });
-+ }
-+ }
-+}
-+
-+// Handle ipfilter.dat
-+int trim(char* const data, int start, int end)
-+{
-+ if (start >= end) return start;
-+ int newStart = start;
-+
-+ for (int i = start; i <= end; ++i) {
-+ if (isspace(data[i]) != 0) {
-+ data[i] = '\0';
-+ }
-+ else {
-+ newStart = i;
-+ break;
-+ }
-+ }
-+
-+ for (int i = end; i >= start; --i) {
-+ if (isspace(data[i]) != 0)
-+ data[i] = '\0';
-+ else
-+ break;
-+ }
-+
-+ return newStart;
-+}
-+
-+int findAndNullDelimiter(char *const data, char delimiter, int start, int end)
-+{
-+ for (int i = start; i <= end; ++i) {
-+ if (data[i] == delimiter) {
-+ data[i] = '\0';
-+ return i;
-+ }
-+ }
-+
-+ return -1;
-+}
-+
-+int Session::parseOfflineFilterFile(QString ipDat, libt::ip_filter &filter)
-+{
-+ int ruleCount = 0;
-+ QFile file(ipDat);
-+ if (!file.exists()) return ruleCount;
-+
-+ if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
-+ LogMsg(tr("I/O Error: Could not open IP filter file in read mode."), Log::CRITICAL);
-+ return ruleCount;
-+ }
-+
-+ std::vector buffer(2 * 1024 * 1024, 0); // seems a bit faster than QVector
-+ qint64 bytesRead = 0;
-+ int offset = 0;
-+ int start = 0;
-+ int endOfLine = -1;
-+ int nbLine = 0;
-+
-+ while (true) {
-+ bytesRead = file.read(buffer.data() + offset, 2 * 1024 * 1024 - offset - 1);
-+ if (bytesRead < 0)
-+ break;
-+ int dataSize = bytesRead + offset;
-+ if (bytesRead == 0 && dataSize == 0)
-+ break;
-+
-+ for (start = 0; start < dataSize; ++start) {
-+ endOfLine = -1;
-+ // The file might have ended without the last line having a newline
-+ if (!(bytesRead == 0 && dataSize > 0)) {
-+ for (int i = start; i < dataSize; ++i) {
-+ if (buffer[i] == '\n') {
-+ endOfLine = i;
-+ // We need to NULL the newline in case the line has only an IP range.
-+ // In that case the parser won't work for the end IP, because it ends
-+ // with the newline and not with a number.
-+ buffer[i] = '\0';
-+ break;
-+ }
-+ }
-+ }
-+ else {
-+ endOfLine = dataSize;
-+ buffer[dataSize] = '\0';
-+ }
-+
-+ if (endOfLine == -1) {
-+ // read the next chunk from file
-+ // but first move(copy) the leftover data to the front of the buffer
-+ offset = dataSize - start;
-+ memmove(buffer.data(), buffer.data() + start, offset);
-+ break;
-+ }
-+ else {
-+ ++nbLine;
-+ }
-+
-+ if ((buffer[start] == '#')
-+ || ((buffer[start] == '/') && ((start + 1 < dataSize) && (buffer[start + 1] == '/')))) {
-+ start = endOfLine;
-+ continue;
-+ }
-+
-+ // Each line should follow this format:
-+ // 001.009.096.105 - 001.009.096.105 , 000 , Some organization
-+ // The 3rd entry is access level and if above 127 the IP range isn't blocked.
-+ int firstComma = findAndNullDelimiter(buffer.data(), ',', start, endOfLine);
-+ if (firstComma != -1)
-+ findAndNullDelimiter(buffer.data(), ',', firstComma + 1, endOfLine);
-+
-+ // Check if there is an access value (apparently not mandatory)
-+ if (firstComma != -1) {
-+ // There is possibly one
-+ const long int nbAccess = strtol(buffer.data() + firstComma + 1, nullptr, 10);
-+ // Ignoring this rule because access value is too high
-+ if (nbAccess > 127L) {
-+ start = endOfLine;
-+ continue;
-+ }
-+ }
-+
-+ // IP Range should be split by a dash
-+ int endOfIPRange = ((firstComma == -1) ? (endOfLine - 1) : (firstComma - 1));
-+ int delimIP = findAndNullDelimiter(buffer.data(), '-', start, endOfIPRange);
-+ if (delimIP == -1) {
-+ start = endOfLine;
-+ continue;
-+ }
-+
-+ boost::system::error_code ec;
-+ int newStart = trim(buffer.data(), start, delimIP - 1);
-+ libt::address startAddr = libt::address::from_string(buffer.data() + newStart, ec);
-+ Q_ASSERT(!ec);
-+ if (ec) {
-+ start = endOfLine;
-+ continue;
-+ }
-+
-+ newStart = trim(buffer.data(), delimIP + 1, endOfIPRange);
-+ libt::address endAddr = libt::address::from_string(buffer.data() + newStart, ec);
-+ Q_ASSERT(!ec);
-+ if (ec) {
-+ start = endOfLine;
-+ continue;
-+ }
-+
-+ if ((startAddr.is_v4() != endAddr.is_v4())
-+ || (startAddr.is_v6() != endAddr.is_v6())) {
-+ start = endOfLine;
-+ continue;
-+ }
-+
-+ start = endOfLine;
-+
-+ filter.add_rule(startAddr, endAddr, libt::ip_filter::blocked);
-+ ++ruleCount;
-+ }
-+
-+ if (start >= dataSize)
-+ offset = 0;
-+ }
-+
-+ return ruleCount;
-+}
-+
-+void Session::loadOfflineFilter() {
-+ int Count = 0;
-+ libt::ip_filter offlineFilter = m_nativeSession->get_ip_filter();
-+
-+#if defined(Q_OS_WIN)
-+ Count = parseOfflineFilterFile("./ipfilter.dat", offlineFilter);
-+#endif
-+
-+#if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC))
-+ Count = parseOfflineFilterFile(QDir::home().absoluteFilePath(".config")+"/qBittorrent/ipfilter.dat", offlineFilter);
-+#endif
-+
-+ m_nativeSession->set_ip_filter(offlineFilter);
-+ Logger::instance()->addMessage(tr("Successfully parsed the offline downloader IP filter: %1 rules were applied.", "%1 is a number").arg(Count));
-+}
-+
- void Session::recursiveTorrentDownload(const InfoHash &hash)
- {
- TorrentHandle *const torrent = m_torrents.value(hash);
-@@ -4063,6 +4406,7 @@ void Session::handleIPFilterParsed(int r
- }
- Logger::instance()->addMessage(tr("Successfully parsed the provided IP filter: %1 rules were applied.", "%1 is a number").arg(ruleCount));
- emit IPFilterParsed(false, ruleCount);
-+ loadOfflineFilter();
- }
-
- void Session::handleIPFilterError()
---- a/src/base/bittorrent/session.h
-+++ b/src/base/bittorrent/session.h
-@@ -40,8 +40,10 @@
- #include
- #include
- #include
-+#include
- #include
- #include
-+#include
- #include
- #include
-
-@@ -341,6 +343,10 @@ namespace BitTorrent
-
- uint saveResumeDataInterval() const;
- void setSaveResumeDataInterval(uint value);
-+ bool isAutoBanUnknownPeerEnabled() const;
-+ void setAutoBanUnknownPeer(bool value);
-+ bool isShowTrackerAuthWindow() const;
-+ void setShowTrackerAuthWindow(bool value);
- int port() const;
- void setPort(int port);
- bool useRandomPort() const;
-@@ -467,6 +473,19 @@ namespace BitTorrent
- void setMaxRatioAction(MaxRatioAction act);
-
- void banIP(const QString &ip);
-+ bool checkAccessFlags(const QString &ip);
-+ void tempblockIP(const QString &ip);
-+ void removeBlockedIP(const QString &ip);
-+ void eraseIPFilter();
-+ void autoBanBadClient();
-+
-+ // Unban Timer
-+ bool m_isActive = false;
-+ QQueue q_bannedIPs;
-+ QQueue q_unbanTime;
-+ QTimer *m_unbanTimer;
-+ QTimer *m_banTimer;
-+ void insertQueue(QString ip);
-
- bool isKnownTorrent(const InfoHash &hash) const;
- bool addTorrent(QString source, const AddTorrentParams ¶ms = AddTorrentParams());
-@@ -546,6 +565,9 @@ namespace BitTorrent
- void tagAdded(const QString &tag);
- void tagRemoved(const QString &tag);
-
-+ public slots:
-+ void processUnbanRequest();
-+
- private slots:
- void configureDeferred();
- void readAlerts();
-@@ -601,6 +623,8 @@ namespace BitTorrent
- void populateAdditionalTrackers();
- void enableIPFilter();
- void disableIPFilter();
-+ int parseOfflineFilterFile(QString ipDat, libtorrent::ip_filter &filter);
-+ void loadOfflineFilter();
-
- bool addTorrent_impl(CreateTorrentParams params, const MagnetUri &magnetUri,
- TorrentInfo torrentInfo = TorrentInfo(),
-@@ -713,6 +737,8 @@ namespace BitTorrent
- CachedSettingValue m_isAltGlobalSpeedLimitEnabled;
- CachedSettingValue m_isBandwidthSchedulerEnabled;
- CachedSettingValue m_saveResumeDataInterval;
-+ CachedSettingValue m_autoBanUnknownPeer;
-+ CachedSettingValue m_showTrackerAuthWindow;
- CachedSettingValue m_port;
- CachedSettingValue m_useRandomPort;
- CachedSettingValue m_networkInterface;
---- a/src/base/bittorrent/torrenthandle.cpp
-+++ b/src/base/bittorrent/torrenthandle.cpp
-@@ -1561,7 +1561,8 @@ void TorrentHandle::handleTrackerErrorAl
- m_trackerInfos[trackerUrl].lastMessage = message;
-
- if (p->status_code == 401)
-- m_session->handleTorrentTrackerAuthenticationRequired(this, trackerUrl);
-+ if (Preferences::instance()->getShowTrackerAuthWindow())
-+ m_session->handleTorrentTrackerAuthenticationRequired(this, trackerUrl);
-
- m_session->handleTorrentTrackerError(this, trackerUrl);
- }
---- a/src/base/preferences.cpp
-+++ b/src/base/preferences.cpp
-@@ -1090,6 +1090,26 @@ void Preferences::setTrayIconStyle(TrayI
- }
- #endif
-
-+bool Preferences::getAutoBanUnknownPeer() const
-+{
-+ return value("Preferences/Advanced/AutoBanUnknownPeer", false).toBool();
-+}
-+
-+void Preferences::setAutoBanUnknownPeer(const bool checked)
-+{
-+ setValue("Preferences/Advanced/AutoBanUnknownPeer", checked);
-+}
-+
-+bool Preferences::getShowTrackerAuthWindow() const
-+{
-+ return value("Preferences/Advanced/ShowTrackerAuthWindow", true).toBool();
-+}
-+
-+void Preferences::setShowTrackerAuthWindow(const bool checked)
-+{
-+ setValue("Preferences/Advanced/ShowTrackerAuthWindow", checked);
-+}
-+
- // Stuff that don't appear in the Options GUI but are saved
- // in the same file.
-
---- a/src/base/preferences.h
-+++ b/src/base/preferences.h
-@@ -300,6 +300,10 @@ public:
- TrayIcon::Style trayIconStyle() const;
- void setTrayIconStyle(TrayIcon::Style style);
- #endif // Q_OS_MAC
-+ bool getAutoBanUnknownPeer() const;
-+ void setAutoBanUnknownPeer(const bool checked);
-+ bool getShowTrackerAuthWindow() const;
-+ void setShowTrackerAuthWindow(const bool checked);
-
- // Stuff that don't appear in the Options GUI but are saved
- // in the same file.
---- a/src/base/settingsstorage.cpp
-+++ b/src/base/settingsstorage.cpp
-@@ -91,6 +91,8 @@ namespace
- {"BitTorrent/Session/InterfaceName", "Preferences/Connection/InterfaceName"},
- {"BitTorrent/Session/InterfaceAddress", "Preferences/Connection/InterfaceAddress"},
- {"BitTorrent/Session/SaveResumeDataInterval", "Preferences/Downloads/SaveResumeDataInterval"},
-+ {"BitTorrent/Session/AutoBanUnknownPeer", "Preferences/Advanced/AutoBanUnknownPeer"},
-+ {"BitTorrent/Session/ShowTrackerAuthWindow", "Preferences/Advanced/ShowTrackerAuthWindow"},
- {"BitTorrent/Session/Encryption", "Preferences/Bittorrent/Encryption"},
- {"BitTorrent/Session/ForceProxy", "Preferences/Connection/ProxyForce"},
- {"BitTorrent/Session/ProxyPeerConnections", "Preferences/Connection/ProxyPeerConnections"},
---- a/src/gui/advancedsettings.cpp
-+++ b/src/gui/advancedsettings.cpp
-@@ -60,6 +60,8 @@ enum AdvSettingsRows
- NETWORK_LISTEN_IPV6,
- // behavior
- SAVE_RESUME_DATA_INTERVAL,
-+ CONFIRM_AUTO_BAN,
-+ SHOW_TRACKER_AUTH_WINDOW,
- CONFIRM_RECHECK_TORRENT,
- RECHECK_COMPLETED,
- #if defined(Q_OS_WIN) || defined(Q_OS_MAC)
-@@ -215,6 +217,10 @@ void AdvancedSettings::saveAdvancedSetti
- // Announce IP
- QHostAddress addr(lineEditAnnounceIP.text().trimmed());
- session->setAnnounceIP(addr.isNull() ? "" : addr.toString());
-+ // Auto ban Unknown Peer
-+ session->setAutoBanUnknownPeer(cb_auto_ban_unknown_peer.isChecked());
-+ // Show Tracker Authenticaion Window
-+ session->setShowTrackerAuthWindow(cb_show_tracker_auth_window.isChecked());
-
- // Program notification
- MainWindow *const mainWindow = static_cast(QCoreApplication::instance())->mainWindow();
-@@ -465,6 +471,12 @@ void AdvancedSettings::loadAdvancedSetti
- // Announce IP
- lineEditAnnounceIP.setText(session->announceIP());
- addRow(ANNOUNCE_IP, tr("IP Address to report to trackers (requires restart)"), &lineEditAnnounceIP);
-+ // Auto Ban Unknown Peer from China
-+ cb_auto_ban_unknown_peer.setChecked(session->isAutoBanUnknownPeerEnabled());
-+ addRow(CONFIRM_AUTO_BAN, tr("Auto Ban Unknown Peer from China"), &cb_auto_ban_unknown_peer);
-+ // Show Tracker Authenticaion Window
-+ cb_show_tracker_auth_window.setChecked(session->isShowTrackerAuthWindow());
-+ addRow(SHOW_TRACKER_AUTH_WINDOW, tr("Show Tracker Authenticaion Window"), &cb_show_tracker_auth_window);
-
- // Program notifications
- const MainWindow *const mainWindow = static_cast(QCoreApplication::instance())->mainWindow();
---- a/src/gui/advancedsettings.h
-+++ b/src/gui/advancedsettings.h
-@@ -65,7 +65,8 @@ private:
- QCheckBox checkBoxOsCache, checkBoxRecheckCompleted, checkBoxResolveCountries, checkBoxResolveHosts, checkBoxSuperSeeding,
- checkBoxProgramNotifications, checkBoxTorrentAddedNotifications, checkBoxTrackerFavicon, checkBoxTrackerStatus,
- checkBoxConfirmTorrentRecheck, checkBoxConfirmRemoveAllTags, checkBoxListenIPv6, checkBoxAnnounceAllTrackers, checkBoxAnnounceAllTiers,
-- checkBoxGuidedReadCache, checkBoxMultiConnectionsPerIp, checkBoxSuggestMode, checkBoxCoalesceRW, checkBoxSpeedWidgetEnabled;
-+ checkBoxGuidedReadCache, checkBoxMultiConnectionsPerIp, checkBoxSuggestMode, checkBoxCoalesceRW, checkBoxSpeedWidgetEnabled,
-+ cb_auto_ban_unknown_peer, cb_show_tracker_auth_window;
- QComboBox comboBoxInterface, comboBoxInterfaceAddress, comboBoxUtpMixedMode, comboBoxChokingAlgorithm, comboBoxSeedChokingAlgorithm;
- QLineEdit lineEditAnnounceIP;
-
---- a/src/gui/mainwindow.cpp
-+++ b/src/gui/mainwindow.cpp
-@@ -73,6 +73,7 @@
- #include "addnewtorrentdialog.h"
- #include "application.h"
- #include "autoexpandabledialog.h"
-+#include "base/bittorrent/peerinfo.h"
- #include "cookiesdialog.h"
- #include "downloadfromurldialog.h"
- #include "executionlogwidget.h"
---- a/src/gui/properties/peerlistdelegate.h
-+++ b/src/gui/properties/peerlistdelegate.h
-@@ -49,6 +49,7 @@ public:
- CONNECTION,
- FLAGS,
- CLIENT,
-+ PEERID,
- PROGRESS,
- DOWN_SPEED,
- UP_SPEED,
---- a/src/gui/properties/peerlistwidget.cpp
-+++ b/src/gui/properties/peerlistwidget.cpp
-@@ -75,6 +75,7 @@ PeerListWidget::PeerListWidget(Propertie
- m_listModel->setHeaderData(PeerListDelegate::FLAGS, Qt::Horizontal, tr("Flags"));
- m_listModel->setHeaderData(PeerListDelegate::CONNECTION, Qt::Horizontal, tr("Connection"));
- m_listModel->setHeaderData(PeerListDelegate::CLIENT, Qt::Horizontal, tr("Client", "i.e.: Client application"));
-+ m_listModel->setHeaderData(PeerListDelegate::PEERID, Qt::Horizontal, tr("Peer ID", "i.e.: Client Peer ID"));
- m_listModel->setHeaderData(PeerListDelegate::PROGRESS, Qt::Horizontal, tr("Progress", "i.e: % downloaded"));
- m_listModel->setHeaderData(PeerListDelegate::DOWN_SPEED, Qt::Horizontal, tr("Down Speed", "i.e: Download speed"));
- m_listModel->setHeaderData(PeerListDelegate::UP_SPEED, Qt::Horizontal, tr("Up Speed", "i.e: Upload speed"));
-@@ -288,8 +289,13 @@ void PeerListWidget::banSelectedPeers()
- for (const QModelIndex &index : selectedIndexes) {
- int row = m_proxyModel->mapToSource(index).row();
- QString ip = m_listModel->data(m_listModel->index(row, PeerListDelegate::IP_HIDDEN)).toString();
-+ QString client = m_listModel->data(m_listModel->index(row, PeerListDelegate::CLIENT)).toString();
-+ QString peerid = m_listModel->data(m_listModel->index(row, PeerListDelegate::PEERID)).toString();
-+ QHostAddress host;
-+ host.setAddress(ip);
-+ const QString countryName = Net::GeoIPManager::CountryName(Net::GeoIPManager::instance()->lookup(host));
- qDebug("Banning peer %s...", ip.toLocal8Bit().data());
-- Logger::instance()->addMessage(tr("Manually banning peer '%1'...").arg(ip));
-+ Logger::instance()->addMessage(tr("Manually banning peer '%1'...'%2'...'%3'...'%4'").arg(ip).arg(peerid).arg(client).arg(countryName));
- BitTorrent::Session::instance()->banIP(ip);
- }
- // Refresh list
-@@ -398,6 +404,7 @@ QStandardItem *PeerListWidget::addPeer(c
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::FLAGS), peer.flags());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::FLAGS), peer.flagsDescription(), Qt::ToolTipRole);
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::CLIENT), peer.client().toHtmlEscaped());
-+ m_listModel->setData(m_listModel->index(row, PeerListDelegate::PEERID), peer.pid().left(8).toHtmlEscaped());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::PROGRESS), peer.progress());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::DOWN_SPEED), peer.payloadDownSpeed());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::UP_SPEED), peer.payloadUpSpeed());
-@@ -429,6 +436,7 @@ void PeerListWidget::updatePeer(const QS
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::FLAGS), peer.flags());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::FLAGS), peer.flagsDescription(), Qt::ToolTipRole);
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::CLIENT), peer.client().toHtmlEscaped());
-+ m_listModel->setData(m_listModel->index(row, PeerListDelegate::PEERID), peer.pid().left(8).toHtmlEscaped());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::PROGRESS), peer.progress());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::DOWN_SPEED), peer.payloadDownSpeed());
- m_listModel->setData(m_listModel->index(row, PeerListDelegate::UP_SPEED), peer.payloadUpSpeed());
---- a/src/webui/api/appcontroller.cpp
-+++ b/src/webui/api/appcontroller.cpp
-@@ -153,6 +153,7 @@ void AppController::preferencesAction()
- data["ip_filter_path"] = Utils::Fs::toNativePath(session->IPFilterFile());
- data["ip_filter_trackers"] = session->isTrackerFilteringEnabled();
- data["banned_IPs"] = session->bannedIPs().join("\n");
-+ data["auto_ban_unknown_peer"] = session->isAutoBanUnknownPeerEnabled();
-
- // Speed
- // Global Rate Limits
-@@ -401,6 +402,8 @@ void AppController::setPreferencesAction
- session->setTrackerFilteringEnabled(m["ip_filter_trackers"].toBool());
- if (m.contains("banned_IPs"))
- session->setBannedIPs(m["banned_IPs"].toString().split('\n'));
-+ if (m.contains("auto_ban_unknown_peer"))
-+ session->setAutoBanUnknownPeer(m["auto_ban_unknown_peer"].toBool());
-
- // Speed
- // Global Rate Limits
---- a/src/webui/api/transfercontroller.cpp
-+++ b/src/webui/api/transfercontroller.cpp
-@@ -30,6 +30,7 @@
-
- #include
-
-+#include "base/logger.h"
- #include "base/bittorrent/session.h"
-
- const char KEY_TRANSFER_DLSPEED[] = "dl_info_speed";
-@@ -111,3 +112,37 @@ void TransferController::speedLimitsMode
- {
- setResult(QString::number(BitTorrent::Session::instance()->isAltGlobalSpeedLimitEnabled()));
- }
-+
-+void TransferController::tempblockPeerAction()
-+{
-+ checkParams({"ip"});
-+ QString ip = params()["ip"];
-+ boost::system::error_code ec;
-+ boost::asio::ip::address addr = boost::asio::ip::address::from_string(ip.toStdString(), ec);
-+ bool isBanned = BitTorrent::Session::instance()->checkAccessFlags(QString::fromStdString(addr.to_string()));
-+
-+ if (ip.isEmpty()) {
-+ setResult(QLatin1String("IP field should not be empty."));
-+ return;
-+ }
-+
-+ if (ec) {
-+ setResult(QLatin1String("The given IP address is not valid."));
-+ return;
-+ }
-+
-+ if (isBanned) {
-+ setResult(QLatin1String("The given IP address already exists."));
-+ return;
-+ }
-+
-+ BitTorrent::Session::instance()->tempblockIP(ip);
-+ Logger::instance()->addMessage(tr("Peer '%1' banned via Web API.").arg(ip));
-+ setResult(QLatin1String("Done."));
-+}
-+
-+void TransferController::resetIPFilterAction()
-+{
-+ BitTorrent::Session::instance()->eraseIPFilter();
-+ setResult(QLatin1String("Erased."));
-+}
---- a/src/webui/api/transfercontroller.h
-+++ b/src/webui/api/transfercontroller.h
-@@ -46,4 +46,6 @@ private slots:
- void downloadLimitAction();
- void setUploadLimitAction();
- void setDownloadLimitAction();
-+ void tempblockPeerAction();
-+ void resetIPFilterAction();
- };
---- a/src/webui/www/private/preferences_content.html
-+++ b/src/webui/www/private/preferences_content.html
-@@ -377,6 +377,8 @@
-
-
-
-+
-+ QBT_TR(Auto Ban Unknown Client From China)QBT_TR[CONTEXT=OptionsDialog]
-
-
-
-@@ -1252,6 +1254,7 @@
- $('ipfilter_text').setProperty('value', pref.ip_filter_path);
- $('ipfilter_trackers_checkbox').setProperty('checked', pref.ip_filter_trackers);
- $('banned_IPs_textarea').setProperty('value', pref.banned_IPs);
-+ $('auto_ban_unknown_peer_checkbox').setProperty('checked', pref.auto_ban_unknown_peer);
- updateFilterSettings();
-
- // Speed tab
-@@ -1502,6 +1505,7 @@
- settings.set('ip_filter_path', $('ipfilter_text').getProperty('value'));
- settings.set('ip_filter_trackers', $('ipfilter_trackers_checkbox').getProperty('checked'));
- settings.set('banned_IPs', $('banned_IPs_textarea').getProperty('value'));
-+ settings.set('auto_ban_unknown_peer', $('auto_ban_unknown_peer_checkbox').getProperty('checked'));
-
- // Speed tab
- // Global Rate Limits
diff --git a/package/lean/rblibtorrent/Makefile b/package/lean/rblibtorrent/Makefile
index d2709c7bb5..4911783225 100644
--- a/package/lean/rblibtorrent/Makefile
+++ b/package/lean/rblibtorrent/Makefile
@@ -1,13 +1,13 @@
include $(TOPDIR)/rules.mk
PKG_NAME:=rblibtorrent
-PKG_VERSION:=1.1.13
+PKG_VERSION:=1.2.3
PKG_RELEASE=2
PKG_SOURCE_PROTO:=git
PKG_SOURCE_URL:=https://github.com/arvidn/libtorrent.git
PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION)
-PKG_SOURCE_VERSION:=6f1250c6535730897909240ea0f4f2a81937d21a
+PKG_SOURCE_VERSION:=078f7b956ef0d992948852a801e626b1118a1fc5
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
PKG_LICENSE:=BSD
@@ -24,7 +24,7 @@ define Package/rblibtorrent
CATEGORY:=Libraries
TITLE:=Rasterbar BitTorrent library
URL:=https://www.libtorrent.org/
- DEPENDS:=+libstdcpp +libopenssl +boost +boost-system +boost-chrono +boost-random
+ DEPENDS:=+libstdcpp +libopenssl +boost +boost-system +boost-chrono +boost-random $(ICONV_DEPENDS)
MAINTAINER:=Arvid Norberg
endef