Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

If one tracker is connected successfully, then do not display timed out/failed ones #1342

Open
airi019 opened this issue Dec 18, 2024 · 5 comments

Comments

@airi019
Copy link

airi019 commented Dec 18, 2024

this message is displayed
image

but here on the details a few trackers were successful
image

is this intentional or what

@kannibalox
Copy link
Contributor

Currently the logic is "last tracker result wins", so if one tracker succeeds quickly, but the other takes a while to time out, you'll get an error message. I'm not sure how intentional that is, but my personal opinion is that it's the least worst option. rTorrent has only one line to convey error information in the TUI, with no way for it to know which failures you care about and which you don't.

If you want to disable the broken tracker, you can toggle it in the detail view with *.

@rakshasa
Copy link
Owner

It's the easiest to implement, and not big enough an issue that I've felt the need to improve the UI.

@jgiszczak
Copy link

Can the tracker error include the URL with the error? There are still many broken trackers in the world which fail NAT traversal, leading to multiple failures per torrent. It would be nice to see up front which tracker to disable when there's a persistent error visible in the UI, rather than having to carefully inspect the tracker list.

@kannibalox
Copy link
Contributor

It's possible to just script the whole affair, e.g. here's a basic python script using pyrosimple that disables all trackers that have only had failures:

import pyrosimple

proxy = pyrosimple.connect().open()
resp = proxy.d.multicall2(
    "",
    "main",
    "d.hash=",
    "t.multicall=,t.success_counter=,t.failed_counter=,t.is_enabled=",
)
for r in resp:
    rhash, rtracker_data = r
    for tindex, tdata in enumerate(rtracker_data):
        success, failed, enabled = tdata
        if enabled == 1 and success == 0 and failed > 0:
            proxy.t.disable(f"{rhash}:t{tindex}")

@jgiszczak
Copy link

That script is so useful it should be added to pyrosimple's docs/examples.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants