qBittorrent: bump to new version

This commit is contained in:
CN_SZTL 2020-01-28 16:01:30 +08:00
parent 9ac9db22e8
commit b4058b6ecf
No known key found for this signature in database
GPG Key ID: 6850B6345C862176
13 changed files with 413 additions and 2112 deletions

View File

@ -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

View File

@ -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
end

View File

@ -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="<br /><br /><input class=\"cbi-button cbi-button-apply\" type=\"button\" value=\" "..translate("Open Web Interface").." \" onclick=\"window.open('http://'+window.location.hostname+':"..o.."')\"/>"
end
function titlesplit(Value)
return "<p style=\"font-size:20px;font-weight:bold;color: DodgerBlue\">" .. translate(Value) .. "</p>"
t="<br /><br /><input class=\"cbi-button cbi-button-apply\" type=\"submit\" value=\" "..translate("Open Web Interface").." \" onclick=\"window.open('http://'+window.location.hostname+':"..o.."')\"/>"
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 "
.. "<a href='https://en.wikipedia.org/wiki/Port_forwarding' target='_blank'>wiki</a>."))
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 <a href='https://github.com/qbittorrent/qBittorrent/wiki/Anonymous-Mode' target='_blank'>wiki</a>"))
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

View File

@ -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: <b>--profile [PATH]</b>."
msgstr "配置文件的保存路径,默认的配置文件夹在/tmp下。例如<code>/etc/config</code>"
msgid "Profile Folder Suffix"
msgstr "配置目录后缀"
msgid "Suffix for profile folder, for example, <b>qBittorrent_[NAME]</b>."
msgstr "配置文件文件夹的后缀。例如: <b>qBittorrent_[NAME]</b>"
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 "为不完整的文件添加后缀名<code>!qB</code>"
msgid "Save Path"
msgstr "文件保存路径"
msgid "The path to save the download file. For example:<code>/mnt/sda1/download</code>"
msgstr "下载文件的保存路径。例如:<code>/mnt/sda1/download</code>"
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 "种子文件将被复制到目标目录。例如:<code>/etc/config</code>"
msgid "Finished Torrent Export Dir"
msgstr "复制种子文件"
msgid "The .torrent files for finished downloads will be copied to the target directory."
msgstr "将已下载完成的种子文件复制到目标目录。例如:<code>/etc/config</code>"
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监听端口"

View File

@ -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'

View File

@ -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<<EOF
[AutoRun]
enabled=false
program=
validate_QBT () {
uci_validate_section "$NAME" vlmcsd "$1" \
'enabled:bool:1' \
'user:string:root' \
'profile:string:/tmp' \
'configuration:string' \
'DHT:or("true","false"):true' \
'Encryption:or("0","1","2"):0' \
'LSD:or("true","false"):true' \
'MaxConnecs:integer' \
'MaxConnecsPerTorrent:integer' \
'MaxRatio:float' \
'MaxRatioAction:or("0","1")' \
'MaxUploads:integer' \
'MaxUploadsPerTorrent:integer' \
'PeX:or("true","false"):true' \
'uTP_rate_limited:or("true","false"):true' \
'PortRangeMin:port' \
'InetAddress:string' \
'UPnP:or("true","false"):true' \
'GlobalDLLimit:float' \
'GlobalDLLimitAlt:float' \
'GlobalUPLimit:float' \
'GlobalUPLimitAlt:float' \
'DiskWriteCacheSize:integer' \
'DiskWriteCacheTTL:integer' \
'FinishedTorrentExportDir:string' \
'PreAllocation:or("true","false"):false' \
'SavePath:string:/tmp/download' \
'StartInPause:or("true","false"):false' \
'TempPathEnabled:or("true","false"):true' \
'TempPath:string:temp/' \
'UseIncompleteExtension:or("true","false"):false' \
'TorrentExportDir:string' \
'Locale:string:en' \
'UseRandomPort:or("true","false"):true' \
'IgnoreSlowTorrents:or("true","false")' \
'MaxActiveDownloads:integer' \
'MaxActiveTorrents:integer' \
'MaxActiveUploads:integer' \
'QueueingEnabled:or("true","false")' \
'AuthSubnetWhitelist:string' \
'AuthSubnetWhitelistEnabled:or("true","false"):false' \
'ClickjackingProtection:or("true","false"):true' \
'CSRFProtection:or("true","false"):true' \
'HostHeaderValidation:or("true","false"):true' \
'LocalHostAuth:or("true","false"):true' \
'Password:string' \
'Port:port:8080' \
'Username:string' \
'UseUPnP:or("true","false"):true' \
'AnonymousMode:or("true","false"):true' \
'AnnounceToAllTrackers:or("true","false")' \
'IgnoreLimitsLAN:or("true","false"):true' \
'IncludeOverhead:or("true","false"):false' \
'osCache:or("true","false")' \
'OutgoingPortsMax:port' \
'OutgoingPortsMin:port' \
'AnnounceToAllTiers:or("true","false")' \
'BTProtocol:or("Both","TCP","UTP")' \
'CreateTorrentSubfolder:or("true","false"):true' \
'DisableAutoTMMByDefault:or("true","false"):true' \
'SuperSeeding:or("true","false"):false' \
'GlobalMaxSeedingMinutes:integer' \
'SeedChokingAlgorithm:or("RoundRobin","FastestUpload","AntiLeech")' \
'SlowTorrentsDownloadRate:integer' \
'SlowTorrentsInactivityTimer:integer' \
'SlowTorrentsUploadRate:integer' \
'CategoryChanged:or("true","false"):false' \
'CategorySavePathChanged:or("true","false"):true' \
'DefaultSavePathChanged:or("true","false"):true' \
'AutoDeleteAddedTorrentFile:or("Never","IfAdded"):Never' \
'Enabled:or("true","false")' \
'Path:string' \
'Backup:or("true","false")' \
'DeleteOld:or("true","false")' \
'MaxSizeBytes:integer' \
'SaveTime:string'
}
sed_options () {
local Anchor=$1
local category=$( echo $2 | sed 's/\s/\\\\/g' )
shift
shift
if [ $( sed -n '/^\['"$Anchor"'\]/p' $QBT_INI_FILE | wc -l ) -lt 1 ]; then
sed -i '$a\\n\['"$Anchor"'\]' "$QBT_INI_FILE"
fi
local o; local v; local ol
for o in "$@"; do
v=$( echo "$(eval echo "\$$o")" | sed 's/[\/\.]/\\&/g' )
[ -n "$category" ] && ol="$category\\\\$o" || ol="$o"
[ -n "$v" ] && {
if [ $( sed -n '/^'"$ol"'=/p' $QBT_INI_FILE | wc -l ) -lt 1 ]; then
sed -i '/'"$Anchor"'/a'"$ol"'='"$v" "$QBT_INI_FILE"
else
sed -i 's/'"$ol"'=.*/'"$ol"'='"$v"'/g' "$QBT_INI_FILE"
fi
} || {
sed -i '/'"$ol"'=.*/d' "$QBT_INI_FILE"
}
done
}
config_QBT () {
local Password_ha1="";local Age="";local AgeType=""
[ -n "$Password" ] && \
Password_ha1="@ByteArray($(echo -n $Password|md5sum|grep -oE '[a-z0-9]{32}'))"
[ -n "$SaveTime" ] && {
[ -n "$(echo $SaveTime | sed 's/[0-9dmyDMY]//g')" ] && { _err "Error save time setted."; return 1; }
Age="$(echo $SaveTime | sed 's/[dmyDMY]//g')"
AgeType="$(echo $SaveTime | sed 's/[0-9]//g' | sed 's/[dD]/0/g' | sed 's/[mM]/1/g' | sed 's/[yY]/2/g')"
}
[ -f "$QBT_INI_FILE" ] || {
cat>"$QBT_INI_FILE"<<EOF
[LegalNotice]
Accepted=true
[Network]
Cookies=@Invalid()
[Preferences]
General\Locale=zh
Downloads\SavePath=$download_dir
General\Locale=zh
WebUI\Port=$port
WebUI\CSRFProtection=false
EOF
}
sed_options "Core" "" \
"AutoDeleteAddedTorrentFile"
sed_options "BitTorrent" "Session DisableAutoTMMTriggers" \
"CategoryChanged" "CategorySavePathChanged" "DefaultSavePathChanged"
sed_options "BitTorrent" "Session" \
"AnnounceToAllTiers" "BTProtocol" "CreateTorrentSubfolder" "DisableAutoTMMByDefault" "GlobalMaxSeedingMinutes" \
"SeedChokingAlgorithm" "SlowTorrentsDownloadRate" "SlowTorrentsInactivityTimer" "SlowTorrentsUploadRate"
sed_options "Preferences" "WebUI" \
"AuthSubnetWhitelistEnabled" "AuthSubnetWhitelist" "CSRFProtection" \
"ClickjackingProtection" "HostHeaderValidation" "LocalHostAuth" \
"Password_ha1" "Port" "Username" "UseUPnP"
sed_options "Preferences" "Queueing" \
"IgnoreSlowTorrents" "MaxActiveDownloads" "MaxActiveTorrents" "MaxActiveUploads" \
"QueueingEnabled"
sed_options "Preferences" "General" \
"Locale" "UseRandomPort"
sed_options "Preferences" "Downloads" \
"DiskWriteCacheSize" "DiskWriteCacheTTL" "FinishedTorrentExportDir" "PreAllocation" \
"SavePath" "StartInPause" "TempPathEnabled" "TempPath" "TorrentExportDir" \
"UseIncompleteExtension"
sed_options "Preferences" "Connection" \
"GlobalDLLimit" "GlobalDLLimitAlt" "GlobalUPLimit" "GlobalUPLimitAlt" \
"PortRangeMin" "InetAddress" "UPnP"
sed_options "Preferences" "Bittorrent" \
"DHT" "Encryption" "LSD" "MaxConnecs" "MaxConnecsPerTorrent" "MaxRatio" \
"MaxRatioAction" "MaxUploads" "MaxUploadsPerTorrent" "PeX" "uTP_rate_limited"
sed_options "Preferences" "Advanced" \
"AnnounceToAllTrackers" "AnonymousMode" "IgnoreLimitsLAN" "IncludeOverhead" "osCache" "OutgoingPortsMax" \
"OutgoingPortsMin" "SuperSeeding"
sed_options "Application" "FileLogger" \
"Enabled" "Path" "Backup" "DeleteOld" "MaxSizeBytes" "Age" "AgeType"
fi
}
init_QBT(){
local section="$1"
QBT_INSTANCE="${NAME}.${section}"
validate_QBT "$section" || { _err "Validation failed."; return 1; }
[ x"$enabled" = x0 ] && {
_info "Instance \"${section}\" disabled.";
procd_kill "$NAME" "$QBT_INSTANCE" >/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
}

View File

@ -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

View File

@ -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

View File

@ -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) '/<context>/{: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)))

View File

@ -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

View File

@ -1,126 +0,0 @@
--- a/src/icons/icons.qrc
+++ b/src/icons/icons.qrc
@@ -250,38 +250,16 @@
<file>flags/zm.svg</file>
<file>flags/zw.svg</file>
<file>L.gif</file>
- <file>loading.png</file>
<file>qbt-theme/application-exit.svg</file>
- <file>qbt-theme/application-rss+xml.svg</file>
- <file>qbt-theme/application-x-mswinurl.svg</file>
<file>qbt-theme/checked.svg</file>
<file>qbt-theme/configure.svg</file>
- <file>qbt-theme/dialog-cancel.svg</file>
- <file>qbt-theme/dialog-information.svg</file>
- <file>qbt-theme/dialog-warning.svg</file>
<file>qbt-theme/document-edit-verify.svg</file>
<file>qbt-theme/document-edit.svg</file>
- <file>qbt-theme/document-encrypt.svg</file>
- <file>qbt-theme/document-import.svg</file>
- <file>qbt-theme/document-new.svg</file>
- <file>qbt-theme/document-properties.svg</file>
- <file>qbt-theme/document-save.svg</file>
- <file>qbt-theme/download.svg</file>
- <file>qbt-theme/edit-clear-history.svg</file>
<file>qbt-theme/edit-clear.svg</file>
<file>qbt-theme/edit-copy.svg</file>
- <file>qbt-theme/edit-cut.svg</file>
<file>qbt-theme/edit-delete.svg</file>
- <file>qbt-theme/edit-find-user.svg</file>
<file>qbt-theme/edit-find.svg</file>
- <file>qbt-theme/edit-paste.svg</file>
<file>qbt-theme/edit-rename.svg</file>
- <file>qbt-theme/folder-documents.svg</file>
- <file>qbt-theme/folder-download.svg</file>
- <file>qbt-theme/folder-new.svg</file>
- <file>qbt-theme/folder-remote.svg</file>
- <file>qbt-theme/gear.svg</file>
- <file>qbt-theme/gear32.svg</file>
<file>qbt-theme/go-bottom.svg</file>
<file>qbt-theme/go-down.svg</file>
<file>qbt-theme/go-top.svg</file>
@@ -295,43 +273,15 @@
<file>qbt-theme/kt-set-max-upload-speed.png</file>
<file>qbt-theme/list-add.svg</file>
<file>qbt-theme/list-remove.svg</file>
- <file>qbt-theme/mail-folder-inbox.svg</file>
- <file>qbt-theme/mail-mark-read.svg</file>
<file>qbt-theme/media-playback-pause.svg</file>
<file>qbt-theme/media-playback-start.svg</file>
<file>qbt-theme/media-seek-forward.svg</file>
- <file>qbt-theme/network-server.svg</file>
- <file>qbt-theme/network-wired.svg</file>
- <file>qbt-theme/object-locked.svg</file>
- <file>qbt-theme/office-chart-line.svg</file>
- <file>qbt-theme/preferences-desktop.svg</file>
- <file>qbt-theme/preferences-other.svg</file>
- <file>qbt-theme/preferences-system-network.svg</file>
- <file>qbt-theme/preferences-web-browser-cookies.svg</file>
- <file>qbt-theme/rss-config.png</file>
<file>qbt-theme/security-high.svg</file>
<file>qbt-theme/security-low.svg</file>
- <file>qbt-theme/services.svg</file>
- <file>qbt-theme/speedometer.svg</file>
<file>qbt-theme/system-log-out.svg</file>
- <file>qbt-theme/tab-close.svg</file>
- <file>qbt-theme/task-attention.svg</file>
- <file>qbt-theme/task-complete.png</file>
- <file>qbt-theme/task-ongoing.png</file>
- <file>qbt-theme/task-reject.png</file>
- <file>qbt-theme/text-plain.svg</file>
- <file>qbt-theme/tools-report-bug.svg</file>
- <file>qbt-theme/unavailable.svg</file>
- <file>qbt-theme/user-group-delete.svg</file>
- <file>qbt-theme/user-group-new.svg</file>
- <file>qbt-theme/view-calendar-journal.svg</file>
<file>qbt-theme/view-categories.svg</file>
- <file>qbt-theme/view-filter.svg</file>
- <file>qbt-theme/view-preview.svg</file>
- <file>qbt-theme/view-refresh.svg</file>
<file>qbt-theme/view-statistics.svg</file>
<file>qbt-theme/wallet-open.svg</file>
- <file>qbt-theme/webui.svg</file>
<file>skin/arrow-right.gif</file>
<file>skin/bg-dropdown.gif</file>
<file>skin/bg-handle-horizontal.gif</file>
@@ -342,7 +292,6 @@
<file>skin/completed.svg</file>
<file>skin/connected.svg</file>
<file>skin/disconnected.svg</file>
- <file>skin/dock-tabs.gif</file>
<file>skin/download.svg</file>
<file>skin/downloading.svg</file>
<file>skin/error.svg</file>
@@ -353,14 +302,11 @@
<file>skin/handle-icon-horizontal.gif</file>
<file>skin/handle-icon.gif</file>
<file>skin/knob.gif</file>
- <file>skin/logo-blank.gif</file>
<file>skin/logo.gif</file>
<file>skin/logo2.gif</file>
<file>skin/mascot.png</file>
<file>skin/paused.svg</file>
<file>skin/qbittorrent-tray.svg</file>
- <file>skin/qbittorrent-tray-dark.svg</file>
- <file>skin/qbittorrent-tray-light.svg</file>
<file>skin/qbittorrent32.png</file>
<file>skin/queued.svg</file>
<file>skin/ratio.svg</file>
@@ -370,17 +316,12 @@
<file>skin/spacer.gif</file>
<file>skin/spinner-placeholder.gif</file>
<file>skin/spinner.gif</file>
- <file>skin/splash.png</file>
<file>skin/stalledDL.svg</file>
<file>skin/stalledUP.svg</file>
<file>skin/tabs.gif</file>
<file>skin/toolbox-divider.gif</file>
- <file>skin/toolbox-divider2.gif</file>
<file>skin/uploading.svg</file>
<file>slow.png</file>
<file>slow_off.png</file>
- <file>sphere.png</file>
- <file>sphere2.png</file>
- <file>url.png</file>
</qresource>
</RCC>

View File

@ -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 <QHostAddress>
#include <libtorrent/peer_info.hpp>
+#include <libtorrent/identify_client.hpp>
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<BitTorrent::PeerInfo> 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<char> 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 <QMap>
#include <QNetworkConfigurationManager>
#include <QPointer>
+#include <QQueue>
#include <QSet>
#include <QStringList>
+#include <QTimer>
#include <QVector>
#include <QWaitCondition>
@@ -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<QString> q_bannedIPs;
+ QQueue<int64_t> q_unbanTime;
+ QTimer *m_unbanTimer;
+ QTimer *m_banTimer;
+ void insertQueue(QString ip);
bool isKnownTorrent(const InfoHash &hash) const;
bool addTorrent(QString source, const AddTorrentParams &params = 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<bool> m_isAltGlobalSpeedLimitEnabled;
CachedSettingValue<bool> m_isBandwidthSchedulerEnabled;
CachedSettingValue<uint> m_saveResumeDataInterval;
+ CachedSettingValue<bool> m_autoBanUnknownPeer;
+ CachedSettingValue<bool> m_showTrackerAuthWindow;
CachedSettingValue<int> m_port;
CachedSettingValue<bool> m_useRandomPort;
CachedSettingValue<QString> 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<Application*>(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<Application*>(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 <QJsonObject>
+#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 @@
<textarea id="banned_IPs_textarea" rows="5" cols="70"></textarea>
</fieldset>
</div>
+ <input type="checkbox" id="auto_ban_unknown_peer_checkbox" />
+ <label for="auto_ban_unknown_peer_checkbox">QBT_TR(Auto Ban Unknown Client From China)QBT_TR[CONTEXT=OptionsDialog]</label>
</fieldset>
</div>
@@ -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

View File

@ -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 <arvid@libtorrent.org>
endef