mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-12 12:34:43 +00:00
[Core] Add support for new lt settings_pack
This commit is contained in:
parent
05566894ad
commit
7f24a1a42d
@ -38,14 +38,18 @@ class AlertManager(component.Component):
|
|||||||
self.alert_queue_size = 10000
|
self.alert_queue_size = 10000
|
||||||
self.set_alert_queue_size(self.alert_queue_size)
|
self.set_alert_queue_size(self.alert_queue_size)
|
||||||
|
|
||||||
self.session.set_alert_mask(
|
alert_mask = (lt.alert.category_t.error_notification |
|
||||||
lt.alert.category_t.error_notification |
|
lt.alert.category_t.port_mapping_notification |
|
||||||
lt.alert.category_t.port_mapping_notification |
|
lt.alert.category_t.storage_notification |
|
||||||
lt.alert.category_t.storage_notification |
|
lt.alert.category_t.tracker_notification |
|
||||||
lt.alert.category_t.tracker_notification |
|
lt.alert.category_t.status_notification |
|
||||||
lt.alert.category_t.status_notification |
|
lt.alert.category_t.ip_block_notification |
|
||||||
lt.alert.category_t.ip_block_notification |
|
lt.alert.category_t.performance_warning)
|
||||||
lt.alert.category_t.performance_warning)
|
|
||||||
|
try:
|
||||||
|
self.session.apply_settings("alert_mask", alert_mask)
|
||||||
|
except AttributeError:
|
||||||
|
self.session.set_alert_mask(alert_mask)
|
||||||
|
|
||||||
# handlers is a dictionary of lists {"alert_type": [handler1,h2,..]}
|
# handlers is a dictionary of lists {"alert_type": [handler1,h2,..]}
|
||||||
self.handlers = {}
|
self.handlers = {}
|
||||||
@ -120,6 +124,4 @@ class AlertManager(component.Component):
|
|||||||
"""Sets the maximum size of the libtorrent alert queue"""
|
"""Sets the maximum size of the libtorrent alert queue"""
|
||||||
log.info("Alert Queue Size set to %s", queue_size)
|
log.info("Alert Queue Size set to %s", queue_size)
|
||||||
self.alert_queue_size = queue_size
|
self.alert_queue_size = queue_size
|
||||||
settings = self.session.get_settings()
|
component.get("Core").apply_session_setting("alert_queue_size", self.alert_queue_size)
|
||||||
settings["alert_queue_size"] = self.alert_queue_size
|
|
||||||
self.session.set_settings(settings)
|
|
||||||
|
@ -65,17 +65,18 @@ class Core(component.Component):
|
|||||||
# Load the session state if available
|
# Load the session state if available
|
||||||
self.__load_session_state()
|
self.__load_session_state()
|
||||||
|
|
||||||
# --- Set session settings ---
|
# Apply session settings
|
||||||
settings = self.session.get_settings()
|
self.apply_session_setting(
|
||||||
settings["user_agent"] = "Deluge/%(deluge_version)s libtorrent/%(lt_version)s" % {
|
"user_agent",
|
||||||
'deluge_version': deluge.common.get_version(),
|
"Deluge/%(deluge_version)s libtorrent/%(lt_version)s" % {
|
||||||
'lt_version': self.get_libtorrent_version().rpartition(".")[0]
|
'deluge_version': deluge.common.get_version(),
|
||||||
}
|
'lt_version': self.get_libtorrent_version().rpartition(".")[0]}
|
||||||
# No SSL torrent support in code so disable the listen port.
|
)
|
||||||
settings["ssl_listen"] = 0
|
|
||||||
self.session.set_settings(settings)
|
|
||||||
|
|
||||||
# --- libtorrent plugins ---
|
# No SSL torrent support in code so disable the listen port.
|
||||||
|
self.apply_session_setting("ssl_listen", 0)
|
||||||
|
|
||||||
|
# Enable libtorrent extensions
|
||||||
# Allows peers to download the metadata from the swarm directly
|
# Allows peers to download the metadata from the swarm directly
|
||||||
self.session.add_extension("ut_metadata")
|
self.session.add_extension("ut_metadata")
|
||||||
# Ban peers that sends bad data
|
# Ban peers that sends bad data
|
||||||
@ -137,6 +138,22 @@ class Core(component.Component):
|
|||||||
def shutdown(self):
|
def shutdown(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
def apply_session_setting(self, key, value):
|
||||||
|
self.apply_session_settings({key: value})
|
||||||
|
|
||||||
|
def apply_session_settings(self, settings):
|
||||||
|
"""Apply libtorrent session settings.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
settings (dict): A dict of lt session settings to apply.
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
self.session.apply_settings(settings)
|
||||||
|
except AttributeError:
|
||||||
|
self.session.set_settings(settings)
|
||||||
|
|
||||||
def __save_session_state(self):
|
def __save_session_state(self):
|
||||||
"""Saves the libtorrent session state"""
|
"""Saves the libtorrent session state"""
|
||||||
filename = "session.state"
|
filename = "session.state"
|
||||||
@ -389,6 +406,7 @@ class Core(component.Component):
|
|||||||
|
|
||||||
"""
|
"""
|
||||||
status = {}
|
status = {}
|
||||||
|
# TODO: libtorrent DEPRECATED for session_stats http://libtorrent.org/manual-ref.html#session-statistics
|
||||||
session_status = self.session.status()
|
session_status = self.session.status()
|
||||||
for key in keys:
|
for key in keys:
|
||||||
status[key] = getattr(session_status, key)
|
status[key] = getattr(session_status, key)
|
||||||
@ -404,7 +422,7 @@ class Core(component.Component):
|
|||||||
:rtype: dict
|
:rtype: dict
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
# TODO: libtorrent DEPRECATED for session_stats: disk.num_blocks_cache_hits etc...
|
||||||
status = self.session.get_cache_status()
|
status = self.session.get_cache_status()
|
||||||
cache = {}
|
cache = {}
|
||||||
for attr in dir(status):
|
for attr in dir(status):
|
||||||
@ -559,7 +577,7 @@ class Core(component.Component):
|
|||||||
@export
|
@export
|
||||||
def get_i2p_proxy(self):
|
def get_i2p_proxy(self):
|
||||||
"""Returns the active listen port"""
|
"""Returns the active listen port"""
|
||||||
i2p_settings = self.session.i2p_proxy()
|
i2p_settings = self.session.i2p_proxy() # Deprecated, moved to proxy types
|
||||||
i2p_dict = {"hostname": i2p_settings.hostname, "port": i2p_settings.port}
|
i2p_dict = {"hostname": i2p_settings.hostname, "port": i2p_settings.port}
|
||||||
return i2p_dict
|
return i2p_dict
|
||||||
|
|
||||||
|
@ -158,9 +158,19 @@ class PreferencesManager(component.Component):
|
|||||||
on_set_func(key, value)
|
on_set_func(key, value)
|
||||||
|
|
||||||
def session_set_setting(self, key, value):
|
def session_set_setting(self, key, value):
|
||||||
settings = self.session.get_settings()
|
try:
|
||||||
settings[key] = value
|
self.session.apply_settings({key: value})
|
||||||
self.session.set_settings(settings)
|
except AttributeError:
|
||||||
|
# Deprecated in libtorrent 1.1
|
||||||
|
if key in ("enable_lsd", "enable_upnp", "enable_natpmp", "enable_dht"):
|
||||||
|
start_stop = key.replace("enable", "start") if value else key.replace("enable", "stop")
|
||||||
|
getattr(self.session, start_stop)()
|
||||||
|
elif key == "dht_bootstrap_nodes":
|
||||||
|
self.session.add_dht_router("router.bittorrent.com", 6881)
|
||||||
|
self.session.add_dht_router("router.utorrent.com", 6881)
|
||||||
|
self.session.add_dht_router("router.bitcomet.com", 6881)
|
||||||
|
else:
|
||||||
|
self.session.set_settings({key: value})
|
||||||
|
|
||||||
def _on_config_value_change(self, key, value):
|
def _on_config_value_change(self, key, value):
|
||||||
if self.get_state() == "Started":
|
if self.get_state() == "Started":
|
||||||
@ -193,22 +203,28 @@ class PreferencesManager(component.Component):
|
|||||||
self.config["listen_random_port"] = None
|
self.config["listen_random_port"] = None
|
||||||
listen_ports = self.config["listen_ports"]
|
listen_ports = self.config["listen_ports"]
|
||||||
|
|
||||||
# If a single port range then always enable re-use port flag.
|
|
||||||
reuse_port = True if listen_ports[0] == listen_ports[1] else self.config["listen_reuse_port"]
|
|
||||||
flags = ((lt.listen_on_flags_t.listen_no_system_port
|
|
||||||
if not self.config["listen_use_sys_port"] else 0) |
|
|
||||||
(lt.listen_on_flags_t.listen_reuse_address
|
|
||||||
if reuse_port else 0))
|
|
||||||
interface = str(self.config["listen_interface"].strip())
|
interface = str(self.config["listen_interface"].strip())
|
||||||
|
|
||||||
log.debug("Listen Interface: %s, Ports: %s with reuse_port: %s, use_sys_port: %s",
|
log.debug("Listen Interface: %s, Ports: %s with use_sys_port: %s",
|
||||||
interface, listen_ports, reuse_port, self.config["listen_use_sys_port"])
|
interface, listen_ports, self.config["listen_use_sys_port"])
|
||||||
try:
|
try:
|
||||||
self.session.listen_on(listen_ports[0], listen_ports[1], interface, flags)
|
interfaces = ["%s:%s" % (interface, port) for port in range(listen_ports[0], listen_ports[1]+1)]
|
||||||
except RuntimeError as ex:
|
self.session.apply_setting({"listen_system_port_fallback", self.config["listen_use_sys_port"]})
|
||||||
if ex.message == "Invalid Argument":
|
self.session.apply_setting({"listen_interfaces", interfaces})
|
||||||
log.error("Error setting listen interface (must be IP Address): %s %s-%s",
|
except AttributeError:
|
||||||
interface, listen_ports[0], listen_ports[1])
|
# Deprecated in libtorrent 1.1
|
||||||
|
# If a single port range then always enable re-use port flag.
|
||||||
|
reuse_port = True if listen_ports[0] == listen_ports[1] else self.config["listen_reuse_port"]
|
||||||
|
flags = ((lt.listen_on_flags_t.listen_no_system_port
|
||||||
|
if not self.config["listen_use_sys_port"] else 0) |
|
||||||
|
(lt.listen_on_flags_t.listen_reuse_address
|
||||||
|
if reuse_port else 0))
|
||||||
|
try:
|
||||||
|
self.session.listen_on(listen_ports[0], listen_ports[1], interface, flags)
|
||||||
|
except RuntimeError as ex:
|
||||||
|
if ex.message == "Invalid Argument":
|
||||||
|
log.error("Error setting listen interface (must be IP Address): %s %s-%s",
|
||||||
|
interface, listen_ports[0], listen_ports[1])
|
||||||
|
|
||||||
def _on_set_outgoing_ports(self, key, value):
|
def _on_set_outgoing_ports(self, key, value):
|
||||||
self.__set_outgoing_ports()
|
self.__set_outgoing_ports()
|
||||||
@ -231,34 +247,21 @@ class PreferencesManager(component.Component):
|
|||||||
|
|
||||||
def _on_set_dht(self, key, value):
|
def _on_set_dht(self, key, value):
|
||||||
log.debug("dht value set to %s", value)
|
log.debug("dht value set to %s", value)
|
||||||
if value:
|
dht_bootstraps = "router.bittorrent.com:6881,router.utorrent.com:6881,router.bitcomet.com:6881"
|
||||||
self.session.start_dht()
|
self.session_set_setting("dht_bootstrap_nodes", dht_bootstraps)
|
||||||
self.session.add_dht_router("router.bittorrent.com", 6881)
|
self.session_set_setting("enable_dht", value)
|
||||||
self.session.add_dht_router("router.utorrent.com", 6881)
|
|
||||||
self.session.add_dht_router("router.bitcomet.com", 6881)
|
|
||||||
else:
|
|
||||||
self.session.stop_dht()
|
|
||||||
|
|
||||||
def _on_set_upnp(self, key, value):
|
def _on_set_upnp(self, key, value):
|
||||||
log.debug("upnp value set to %s", value)
|
log.debug("upnp value set to %s", value)
|
||||||
if value:
|
self.session_set_setting("enable_upnp", value)
|
||||||
self.session.start_upnp()
|
|
||||||
else:
|
|
||||||
self.session.stop_upnp()
|
|
||||||
|
|
||||||
def _on_set_natpmp(self, key, value):
|
def _on_set_natpmp(self, key, value):
|
||||||
log.debug("natpmp value set to %s", value)
|
log.debug("natpmp value set to %s", value)
|
||||||
if value:
|
self.session_set_setting("enable_natpmp", value)
|
||||||
self.session.start_natpmp()
|
|
||||||
else:
|
|
||||||
self.session.stop_natpmp()
|
|
||||||
|
|
||||||
def _on_set_lsd(self, key, value):
|
def _on_set_lsd(self, key, value):
|
||||||
log.debug("lsd value set to %s", value)
|
log.debug("lsd value set to %s", value)
|
||||||
if value:
|
self.session_set_setting("enable_lsd", value)
|
||||||
self.session.start_lsd()
|
|
||||||
else:
|
|
||||||
self.session.stop_lsd()
|
|
||||||
|
|
||||||
def _on_set_utpex(self, key, value):
|
def _on_set_utpex(self, key, value):
|
||||||
log.debug("utpex value set to %s", value)
|
log.debug("utpex value set to %s", value)
|
||||||
@ -276,22 +279,28 @@ class PreferencesManager(component.Component):
|
|||||||
|
|
||||||
def _on_set_encryption(self, key, value):
|
def _on_set_encryption(self, key, value):
|
||||||
log.debug("encryption value %s set to %s..", key, value)
|
log.debug("encryption value %s set to %s..", key, value)
|
||||||
|
# Convert Deluge enc_level values to libtorrent enc_level values.
|
||||||
pe_enc_level = {0: lt.enc_level.plaintext, 1: lt.enc_level.rc4, 2: lt.enc_level.both}
|
pe_enc_level = {0: lt.enc_level.plaintext, 1: lt.enc_level.rc4, 2: lt.enc_level.both}
|
||||||
|
try:
|
||||||
pe_settings = lt.pe_settings()
|
self.session.apply_setting("out_enc_policy", lt.enc_policy(self.config["enc_out_policy"]))
|
||||||
pe_settings.out_enc_policy = \
|
self.session.apply_setting("in_enc_policy", lt.enc_policy(self.config["enc_in_policy"]))
|
||||||
lt.enc_policy(self.config["enc_out_policy"])
|
self.session.apply_setting("allowed_enc_level", lt.enc_level(pe_enc_level[self.config["enc_level"]]))
|
||||||
pe_settings.in_enc_policy = lt.enc_policy(self.config["enc_in_policy"])
|
self.session.apply_setting("prefer_rc4", True)
|
||||||
pe_settings.allowed_enc_level = lt.enc_level(pe_enc_level[self.config["enc_level"]])
|
except AttributeError:
|
||||||
pe_settings.prefer_rc4 = True
|
# Deprecated in libtorrent 1.1
|
||||||
self.session.set_pe_settings(pe_settings)
|
pe_settings = lt.pe_settings()
|
||||||
pe_sess_settings = self.session.get_pe_settings()
|
pe_settings.out_enc_policy = lt.enc_policy(self.config["enc_out_policy"])
|
||||||
log.debug("encryption settings:\n\t\t\tout_policy: %s\n\t\t\
|
pe_settings.in_enc_policy = lt.enc_policy(self.config["enc_in_policy"])
|
||||||
in_policy: %s\n\t\t\tlevel: %s\n\t\t\tprefer_rc4: %s",
|
pe_settings.allowed_enc_level = lt.enc_level(pe_enc_level[self.config["enc_level"]])
|
||||||
pe_sess_settings.out_enc_policy,
|
pe_settings.prefer_rc4 = True
|
||||||
pe_sess_settings.in_enc_policy,
|
self.session.set_pe_settings(pe_settings)
|
||||||
pe_sess_settings.allowed_enc_level,
|
pe_sess_settings = self.session.get_pe_settings()
|
||||||
pe_sess_settings.prefer_rc4)
|
log.debug("encryption settings:\n\t\t\tout_policy: %s\n\t\t\
|
||||||
|
in_policy: %s\n\t\t\tlevel: %s\n\t\t\tprefer_rc4: %s",
|
||||||
|
pe_sess_settings.out_enc_policy,
|
||||||
|
pe_sess_settings.in_enc_policy,
|
||||||
|
pe_sess_settings.allowed_enc_level,
|
||||||
|
pe_sess_settings.prefer_rc4)
|
||||||
|
|
||||||
def _on_set_max_connections_global(self, key, value):
|
def _on_set_max_connections_global(self, key, value):
|
||||||
log.debug("max_connections_global set to %s..", value)
|
log.debug("max_connections_global set to %s..", value)
|
||||||
@ -300,20 +309,14 @@ class PreferencesManager(component.Component):
|
|||||||
def _on_set_max_upload_speed(self, key, value):
|
def _on_set_max_upload_speed(self, key, value):
|
||||||
log.debug("max_upload_speed set to %s..", value)
|
log.debug("max_upload_speed set to %s..", value)
|
||||||
# We need to convert Kb/s to B/s
|
# We need to convert Kb/s to B/s
|
||||||
if value < 0:
|
value = -1 if value < 0 else int(value * 1024)
|
||||||
_value = -1
|
self.session_set_setting("upload_rate_limit", value)
|
||||||
else:
|
|
||||||
_value = int(value * 1024)
|
|
||||||
self.session_set_setting("upload_rate_limit", _value)
|
|
||||||
|
|
||||||
def _on_set_max_download_speed(self, key, value):
|
def _on_set_max_download_speed(self, key, value):
|
||||||
log.debug("max_download_speed set to %s..", value)
|
log.debug("max_download_speed set to %s..", value)
|
||||||
# We need to convert Kb/s to B/s
|
# We need to convert Kb/s to B/s
|
||||||
if value < 0:
|
value = -1 if value < 0 else int(value * 1024)
|
||||||
_value = -1
|
self.session_set_setting("download_rate_limit", value)
|
||||||
else:
|
|
||||||
_value = int(value * 1024)
|
|
||||||
self.session_set_setting("download_rate_limit", _value)
|
|
||||||
|
|
||||||
def _on_set_max_upload_slots_global(self, key, value):
|
def _on_set_max_upload_slots_global(self, key, value):
|
||||||
log.debug("max_upload_slots_global set to %s..", value)
|
log.debug("max_upload_slots_global set to %s..", value)
|
||||||
@ -407,25 +410,42 @@ class PreferencesManager(component.Component):
|
|||||||
|
|
||||||
def _on_set_proxy(self, key, value):
|
def _on_set_proxy(self, key, value):
|
||||||
log.debug("Setting proxy to: %s", value)
|
log.debug("Setting proxy to: %s", value)
|
||||||
proxy_settings = lt.proxy_settings()
|
try:
|
||||||
proxy_settings.type = lt.proxy_type(value["type"])
|
if key == "i2p_proxy":
|
||||||
proxy_settings.username = value["username"]
|
self.session.apply_settings("proxy_type", lt.proxy_type("i2p_proxy"))
|
||||||
proxy_settings.password = value["password"]
|
self.session.apply_settings("i2p_hostname", value["hostname"])
|
||||||
proxy_settings.hostname = value["hostname"]
|
self.session.apply_settings("i2p_port", value["port"])
|
||||||
proxy_settings.port = value["port"]
|
else:
|
||||||
proxy_settings.proxy_hostnames = value["proxy_hostnames"]
|
self.session.apply_settings("proxy_type", lt.proxy_type(value["type"]))
|
||||||
proxy_settings.proxy_peer_connections = value["proxy_peer_connections"]
|
self.session.apply_settings("proxy_hostname", value["hostname"])
|
||||||
self.session.set_proxy(proxy_settings)
|
self.session.apply_settings("proxy_port", value["port"])
|
||||||
|
self.session.apply_settings("proxy_username", value["username"])
|
||||||
|
self.session.apply_settings("proxy_password", value["password"])
|
||||||
|
self.session.apply_settings("proxy_hostnames", value["proxy_hostnames"])
|
||||||
|
self.session.apply_settings("proxy_peer_connections", value["proxy_peer_connections"])
|
||||||
|
self.session.apply_settings("proxy_tracker_connections", value["proxy_tracker_connections"])
|
||||||
|
except AttributeError:
|
||||||
|
proxy_settings = lt.proxy_settings()
|
||||||
|
proxy_settings.hostname = value["hostname"]
|
||||||
|
proxy_settings.port = value["port"]
|
||||||
|
if key == "i2p_proxy":
|
||||||
|
try:
|
||||||
|
self.session.set_i2p_proxy(proxy_settings)
|
||||||
|
except RuntimeError as ex:
|
||||||
|
log.error("Unable to set I2P Proxy: %s", ex)
|
||||||
|
else:
|
||||||
|
proxy_settings.type = lt.proxy_type(value["type"])
|
||||||
|
proxy_settings.username = value["username"]
|
||||||
|
proxy_settings.password = value["password"]
|
||||||
|
proxy_settings.hostname = value["hostname"]
|
||||||
|
proxy_settings.port = value["port"]
|
||||||
|
proxy_settings.proxy_hostnames = value["proxy_hostnames"]
|
||||||
|
proxy_settings.proxy_peer_connections = value["proxy_peer_connections"]
|
||||||
|
self.session.set_proxy(proxy_settings)
|
||||||
|
|
||||||
def _on_set_i2p_proxy(self, key, value):
|
def _on_set_i2p_proxy(self, key, value):
|
||||||
log.debug("Setting I2P proxy to: %s", value)
|
log.debug("Setting I2P proxy to: %s", value)
|
||||||
proxy_settings = lt.proxy_settings()
|
self._on_set_proxy(key, value)
|
||||||
proxy_settings.hostname = value["hostname"]
|
|
||||||
proxy_settings.port = value["port"]
|
|
||||||
try:
|
|
||||||
self.session.set_i2p_proxy(proxy_settings)
|
|
||||||
except RuntimeError as ex:
|
|
||||||
log.error("Unable to set I2P Proxy: %s", ex)
|
|
||||||
|
|
||||||
def _on_set_rate_limit_ip_overhead(self, key, value):
|
def _on_set_rate_limit_ip_overhead(self, key, value):
|
||||||
log.debug("%s: %s", key, value)
|
log.debug("%s: %s", key, value)
|
||||||
|
@ -1292,8 +1292,7 @@ class TorrentManager(component.Component):
|
|||||||
if send_buffer_watermark < max_send_buffer_watermark:
|
if send_buffer_watermark < max_send_buffer_watermark:
|
||||||
value = send_buffer_watermark + (500 * 1024)
|
value = send_buffer_watermark + (500 * 1024)
|
||||||
log.info("Increasing send_buffer_watermark from %s to %s Bytes", send_buffer_watermark, value)
|
log.info("Increasing send_buffer_watermark from %s to %s Bytes", send_buffer_watermark, value)
|
||||||
settings["send_buffer_watermark"] = value
|
component.get("Core").apply_session_setting("send_buffer_watermark", value)
|
||||||
self.session.set_settings(settings)
|
|
||||||
else:
|
else:
|
||||||
log.warning("send_buffer_watermark reached maximum value: %s Bytes", max_send_buffer_watermark)
|
log.warning("send_buffer_watermark reached maximum value: %s Bytes", max_send_buffer_watermark)
|
||||||
|
|
||||||
|
@ -120,14 +120,14 @@ class Core(CorePluginBase):
|
|||||||
self.__apply_set_functions()
|
self.__apply_set_functions()
|
||||||
elif state == "Yellow":
|
elif state == "Yellow":
|
||||||
# This is Yellow (Slow), so use the settings provided from the user
|
# This is Yellow (Slow), so use the settings provided from the user
|
||||||
session = component.get("Core").session
|
settings = {
|
||||||
session.set_download_rate_limit(int(self.config["low_down"] * 1024))
|
"active_limit": self.config["low_active"],
|
||||||
session.set_upload_rate_limit(int(self.config["low_up"] * 1024))
|
"active_downloads": self.config["low_active_down"],
|
||||||
settings = session.get_settings()
|
"active_seeds": self.config["low_active_up"],
|
||||||
settings["active_limit"] = self.config["low_active"]
|
"download_rate_limit": int(self.config["low_down"] * 1024),
|
||||||
settings["active_downloads"] = self.config["low_active_down"]
|
"upload_rate_limit": int(self.config["low_up"] * 1024)
|
||||||
settings["active_seeds"] = self.config["low_active_up"]
|
}
|
||||||
session.set_settings(settings)
|
component.get("Core").apply_session_settings(settings)
|
||||||
# Resume the session if necessary
|
# Resume the session if necessary
|
||||||
component.get("Core").resume_session()
|
component.get("Core").resume_session()
|
||||||
elif state == "Red":
|
elif state == "Red":
|
||||||
|
Loading…
x
Reference in New Issue
Block a user