]> Sergey Matveev's repositories - btrtrc.git/log
btrtrc.git
3 months agoDisable writeChunk perf timer
Matt Joiner [Sun, 18 Feb 2024 01:59:59 +0000 (12:59 +1100)]
Disable writeChunk perf timer

3 months agoSwitch to xxHash for smartban cache
Matt Joiner [Sun, 18 Feb 2024 01:59:42 +0000 (12:59 +1100)]
Switch to xxHash for smartban cache

3 months agoInclude smart ban block recording in BenchmarkConnectionMainReadLoop
Matt Joiner [Sun, 18 Feb 2024 01:18:54 +0000 (12:18 +1100)]
Include smart ban block recording in BenchmarkConnectionMainReadLoop

3 months agoAdd smart ban hash benchmarks and reduce allocations
Matt Joiner [Sun, 18 Feb 2024 01:21:11 +0000 (12:21 +1100)]
Add smart ban hash benchmarks and reduce allocations

3 months agoOptimize request strategy for torrent storage with unlimited capacity
Matt Joiner [Thu, 8 Feb 2024 13:15:18 +0000 (00:15 +1100)]
Optimize request strategy for torrent storage with unlimited capacity

3 months agoGetRequestablePieces: remove runtime correctness check (#902)
Oleg Guba [Fri, 9 Feb 2024 04:44:09 +0000 (20:44 -0800)]
GetRequestablePieces: remove runtime correctness check (#902)

3 months agoMisc tidying
Matt Joiner [Thu, 8 Feb 2024 13:11:33 +0000 (00:11 +1100)]
Misc tidying

3 months agoRemove unused request strategy chunk iter types
Matt Joiner [Thu, 8 Feb 2024 08:51:57 +0000 (19:51 +1100)]
Remove unused request strategy chunk iter types

3 months agoStay interested when the peer has pieces we don't have
Matt Joiner [Thu, 8 Feb 2024 07:07:32 +0000 (18:07 +1100)]
Stay interested when the peer has pieces we don't have

3 months agoRestore request strategy Torrent.Piece use, without a heap allocation
Matt Joiner [Thu, 8 Feb 2024 06:58:12 +0000 (17:58 +1100)]
Restore request strategy Torrent.Piece use, without a heap allocation

3 months agoSave extra http Request alloc in webseed request
Matt Joiner [Wed, 7 Feb 2024 02:56:49 +0000 (13:56 +1100)]
Save extra http Request alloc in webseed request

4 months agoRename exported Peer and PeerConn receivers
Matt Joiner [Tue, 16 Jan 2024 09:15:14 +0000 (20:15 +1100)]
Rename exported Peer and PeerConn receivers

4 months agoFix race in ExportStatusWriter
Matt Joiner [Fri, 19 Jan 2024 05:35:36 +0000 (16:35 +1100)]
Fix race in ExportStatusWriter

4 months agotorrent.KnownSwarm: keep client lock when iterating over connections (#893)
Oleg Guba [Wed, 17 Jan 2024 11:06:31 +0000 (03:06 -0800)]
torrent.KnownSwarm: keep client lock when iterating over connections (#893)

4 months agoRetract versions affected by indefinite outgoing requests bug
Matt Joiner [Mon, 15 Jan 2024 06:03:05 +0000 (17:03 +1100)]
Retract versions affected by indefinite outgoing requests bug

4 months agoFix anacrolix/torrent version detection
Matt Joiner [Mon, 15 Jan 2024 03:51:13 +0000 (14:51 +1100)]
Fix anacrolix/torrent version detection

Still doesn't work for devel builds of main however.

https://github.com/anacrolix/torrent/issues/889#issuecomment-1891242553

4 months agoAdd missing return to avoiding filling slow write buffer
Matt Joiner [Mon, 15 Jan 2024 02:26:07 +0000 (13:26 +1100)]
Add missing return to avoiding filling slow write buffer

4 months agoBreak up long condition expression
Matt Joiner [Mon, 15 Jan 2024 01:44:33 +0000 (12:44 +1100)]
Break up long condition expression

4 months agoExpect cancel acknowledgement from Transmission v4 clients
Matt Joiner [Mon, 15 Jan 2024 01:43:55 +0000 (12:43 +1100)]
Expect cancel acknowledgement from Transmission v4 clients

4 months agoFix requests still being made when downloading is disallowed
Matt Joiner [Mon, 15 Jan 2024 01:55:04 +0000 (12:55 +1100)]
Fix requests still being made when downloading is disallowed

https://github.com/anacrolix/torrent/issues/889

4 months agoUpdate anacrolix/log
Matt Joiner [Mon, 15 Jan 2024 01:23:04 +0000 (12:23 +1100)]
Update anacrolix/log

4 months agoRearrange a few methods on the correct receivers
Matt Joiner [Tue, 9 Jan 2024 04:51:23 +0000 (15:51 +1100)]
Rearrange a few methods on the correct receivers

4 months agoBump golang.org/x/crypto from 0.5.0 to 0.17.0 (#885)
dependabot[bot] [Sat, 23 Dec 2023 11:25:13 +0000 (22:25 +1100)]
Bump golang.org/x/crypto from 0.5.0 to 0.17.0 (#885)

Bumps [golang.org/x/crypto](https://github.com/golang/crypto) from 0.5.0 to 0.17.0.
- [Commits](https://github.com/golang/crypto/compare/v0.5.0...v0.17.0)

---
updated-dependencies:
- dependency-name: golang.org/x/crypto
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
5 months agoUse fixed width for example commands
Matt Joiner [Sun, 10 Dec 2023 12:32:25 +0000 (23:32 +1100)]
Use fixed width for example commands

5 months agoAdd more downstream projects
Matt Joiner [Sun, 10 Dec 2023 12:32:03 +0000 (23:32 +1100)]
Add more downstream projects

5 months agoTorrent.WebseedPeerConns() method (#883)
Alex Sharov [Mon, 4 Dec 2023 11:31:34 +0000 (18:31 +0700)]
Torrent.WebseedPeerConns() method (#883)

7 months agoDrop support for go 1.20 master
Matt Joiner [Tue, 10 Oct 2023 08:49:39 +0000 (19:49 +1100)]
Drop support for go 1.20

7 months agoDon't run fs tests on Windows
Matt Joiner [Tue, 10 Oct 2023 08:28:50 +0000 (19:28 +1100)]
Don't run fs tests on Windows

7 months agogo mod tidy
Matt Joiner [Mon, 9 Oct 2023 11:53:34 +0000 (22:53 +1100)]
go mod tidy

7 months agoUpdate to multiple-blobs-per-value squirrel
Matt Joiner [Fri, 29 Sep 2023 04:48:11 +0000 (14:48 +1000)]
Update to multiple-blobs-per-value squirrel

7 months agogorond
Matt Joiner [Tue, 26 Sep 2023 12:20:46 +0000 (22:20 +1000)]
gorond

7 months agoAdd testdata/The-Fanimatrix-(DivX-5.1-HQ).avi.torrent
Matt Joiner [Tue, 26 Sep 2023 12:20:34 +0000 (22:20 +1000)]
Add testdata/The-Fanimatrix-(DivX-5.1-HQ).avi.torrent

It's such a classic torrent. It should be integrated into some tests.

7 months agoSupport scraping from HTTP trackers
Matt Joiner [Tue, 26 Sep 2023 12:19:51 +0000 (22:19 +1000)]
Support scraping from HTTP trackers

7 months agoMerge fs module back into the root module
Matt Joiner [Mon, 25 Sep 2023 11:34:22 +0000 (21:34 +1000)]
Merge fs module back into the root module

It was a dumb idea. Go doesn't want to be modularized anyway.

7 months agoRaise log level for failure to mark piece complete
Matt Joiner [Mon, 25 Sep 2023 11:30:07 +0000 (21:30 +1000)]
Raise log level for failure to mark piece complete

7 months agoDon't do client transfer tests in parallel
Matt Joiner [Mon, 25 Sep 2023 11:29:08 +0000 (21:29 +1000)]
Don't do client transfer tests in parallel

This should make them a lot less flaky.

8 months agoBuffer metainfo loads from files
Matt Joiner [Sat, 16 Sep 2023 03:48:36 +0000 (13:48 +1000)]
Buffer metainfo loads from files

8 months agoBump CI 1.19 go versions to 1.21
Matt Joiner [Thu, 14 Sep 2023 12:58:31 +0000 (22:58 +1000)]
Bump CI 1.19 go versions to 1.21

8 months agoAlso change go requirement for fs module
Matt Joiner [Thu, 14 Sep 2023 12:57:46 +0000 (22:57 +1000)]
Also change go requirement for fs module

8 months agoChange go requirement to 1.20 from 1.21
Matt Joiner [Thu, 14 Sep 2023 12:49:32 +0000 (22:49 +1000)]
Change go requirement to 1.20 from 1.21

Should implement https://github.com/anacrolix/torrent/pull/868 effectively.

8 months agoConfigurable hashers amount per torrent (#867)
Alex Sharov [Wed, 13 Sep 2023 11:15:36 +0000 (18:15 +0700)]
Configurable hashers amount per torrent (#867)

8 months agoFix request heap pop bug
Matt Joiner [Mon, 11 Sep 2023 00:10:13 +0000 (10:10 +1000)]
Fix request heap pop bug

Missed in the changed interface from 613470861e67fdb11c9661930f3490cba0aa19b2. Caused very poor performance. Thanks to @AskAlexSharov for raising the flag in https://github.com/anacrolix/torrent/issues/859#issuecomment-1706059960.

8 months agoUpdate logger usage for received reject messages
Matt Joiner [Sun, 10 Sep 2023 11:29:43 +0000 (21:29 +1000)]
Update logger usage for received reject messages

8 months agoDrop anacrolix/squirrel cache blob usage
Matt Joiner [Mon, 11 Sep 2023 00:04:30 +0000 (10:04 +1000)]
Drop anacrolix/squirrel cache blob usage

8 months agoHandle torrentfs failure in test.sh
Matt Joiner [Fri, 8 Sep 2023 02:41:20 +0000 (12:41 +1000)]
Handle torrentfs failure in test.sh

8 months agoStop benchmark timer before initial run
Matt Joiner [Fri, 8 Sep 2023 01:47:00 +0000 (11:47 +1000)]
Stop benchmark timer before initial run

8 months agoMerge branch 'fuse-t'
Matt Joiner [Tue, 5 Sep 2023 09:03:24 +0000 (19:03 +1000)]
Merge branch 'fuse-t'

8 months agoSwitch to github.com/go-llsqlite/adapter
Matt Joiner [Tue, 5 Sep 2023 08:19:21 +0000 (18:19 +1000)]
Switch to github.com/go-llsqlite/adapter

8 months agoUpdate file_handle.go (#860)
Frederick Robinson [Wed, 23 Aug 2023 21:59:32 +0000 (14:59 -0700)]
Update file_handle.go (#860)

8 months agoFix race in webseed requester sleep duration calculation
Matt Joiner [Tue, 22 Aug 2023 02:45:24 +0000 (12:45 +1000)]
Fix race in webseed requester sleep duration calculation

8 months agoAdd ClientConfig.WebTransport
Matt Joiner [Tue, 22 Aug 2023 02:44:49 +0000 (12:44 +1000)]
Add ClientConfig.WebTransport

9 months agoNote that torrent.Reader is not concurrent-safe
Matt Joiner [Thu, 17 Aug 2023 08:14:46 +0000 (18:14 +1000)]
Note that torrent.Reader is not concurrent-safe

9 months agoDitch lispad/go-generics-tools for anacrolix/generics/heap
Matt Joiner [Wed, 16 Aug 2023 10:51:52 +0000 (20:51 +1000)]
Ditch lispad/go-generics-tools for anacrolix/generics/heap

Fixes https://github.com/anacrolix/torrent/issues/859

9 months agofs: Use a new torrent file reader per handled request
Matt Joiner [Wed, 16 Aug 2023 06:47:54 +0000 (16:47 +1000)]
fs: Use a new torrent file reader per handled request

FUSE-T reuses file handles and issues multiple concurrent reads

9 months agofs/cmd/torrentfs: Mount read-only
Matt Joiner [Wed, 16 Aug 2023 06:38:58 +0000 (16:38 +1000)]
fs/cmd/torrentfs: Mount read-only

9 months agofs: Return file permissions for root node
Matt Joiner [Wed, 16 Aug 2023 06:38:04 +0000 (16:38 +1000)]
fs: Return file permissions for root node

FUSE-T doesn't imply them like other backends.

9 months agofs/cmd/torrentfs: Add main logger
Matt Joiner [Wed, 16 Aug 2023 06:37:28 +0000 (16:37 +1000)]
fs/cmd/torrentfs: Add main logger

9 months agoRemove unnecessary use of SO_REUSEPORT
Matt Joiner [Mon, 14 Aug 2023 01:38:47 +0000 (11:38 +1000)]
Remove unnecessary use of SO_REUSEPORT

Fixes https://github.com/anacrolix/torrent/discussions/856.

9 months agoAdd cove to downstream projects
Matt Joiner [Mon, 14 Aug 2023 04:39:24 +0000 (14:39 +1000)]
Add cove to downstream projects

9 months agoRemove torrentfs-macos job from CI
Matt Joiner [Sun, 23 Jul 2023 06:09:21 +0000 (16:09 +1000)]
Remove torrentfs-macos job from CI

9 months agoIgnore torrentfs-macos CI errors
Matt Joiner [Sun, 23 Jul 2023 06:08:19 +0000 (16:08 +1000)]
Ignore torrentfs-macos CI errors

9 months agofix: torrent file real time completed bytes
liwei [Sat, 22 Jul 2023 16:30:45 +0000 (00:30 +0800)]
fix: torrent file real time completed bytes

9 months agoGet go-libutp fix for go1.21
Matt Joiner [Sun, 23 Jul 2023 06:05:51 +0000 (16:05 +1000)]
Get go-libutp fix for go1.21

10 months agofix: udp tracker panic
liwei [Tue, 4 Jul 2023 10:45:40 +0000 (18:45 +0800)]
fix: udp tracker panic

10 months agochore: remove refs to deprecated io/ioutil
guoguangwu [Sun, 9 Jul 2023 05:29:02 +0000 (13:29 +0800)]
chore: remove refs to deprecated io/ioutil

10 months agochore: unnecessary use of fmt.Sprintf
guoguangwu [Sun, 9 Jul 2023 05:33:05 +0000 (13:33 +0800)]
chore: unnecessary use of fmt.Sprintf

10 months agoAdd sqlite storage build conditions to sqlite storage closed test
Matt Joiner [Tue, 27 Jun 2023 01:36:54 +0000 (11:36 +1000)]
Add sqlite storage build conditions to sqlite storage closed test

Should fix test build failure to build when CGO is disabled.

10 months agoFix error unmarshalling bad metainfo nodes field
Matt Joiner [Mon, 26 Jun 2023 09:48:23 +0000 (19:48 +1000)]
Fix error unmarshalling bad metainfo nodes field

10 months agoTest and fix closed sqlite storage panicking during piece hashing
Matt Joiner [Mon, 26 Jun 2023 00:24:06 +0000 (10:24 +1000)]
Test and fix closed sqlite storage panicking during piece hashing

10 months agoFix UseSources panicking when sqlite storage is closed
Matt Joiner [Fri, 23 Jun 2023 12:14:38 +0000 (22:14 +1000)]
Fix UseSources panicking when sqlite storage is closed

11 months agoLog bad tracker URL error
Matt Joiner [Tue, 6 Jun 2023 00:40:15 +0000 (10:40 +1000)]
Log bad tracker URL error

11 months agoFix incorrect EOF when decoding some peer protocol message types
Matt Joiner [Mon, 29 May 2023 09:01:01 +0000 (19:01 +1000)]
Fix incorrect EOF when decoding some peer protocol message types

Hooray for pedantic fuzz tests. This was found through peer_protocol/FuzzDecoder, when I wrote a go-fuzz-all wrapper.

It probably never caused a problem in production, as EOF would be handled as stream termination anyway, but it isn't clean.

11 months agoReintroduce torrent-wide PEX throttling
Matt Joiner [Wed, 24 May 2023 02:11:10 +0000 (12:11 +1000)]
Reintroduce torrent-wide PEX throttling

https://github.com/anacrolix/torrent/discussions/836

11 months agoRun torrentfs CI on macos
Matt Joiner [Sun, 28 May 2023 03:51:16 +0000 (13:51 +1000)]
Run torrentfs CI on macos

11 months agoAttribute accepted connection to holepunching when connect message is late
Matt Joiner [Sun, 28 May 2023 03:34:58 +0000 (13:34 +1000)]
Attribute accepted connection to holepunching when connect message is late

Also perform holepunch metric adjustments sooner to reduce timing issues in tests.

11 months agofs/test.sh: Handle torrentfs failures synchronously
Matt Joiner [Sun, 28 May 2023 03:52:50 +0000 (13:52 +1000)]
fs/test.sh: Handle torrentfs failures synchronously

11 months agogorond
Matt Joiner [Sun, 28 May 2023 02:04:57 +0000 (12:04 +1000)]
gorond

11 months agoFix logging reported in #841
Matt Joiner [Sun, 28 May 2023 02:04:49 +0000 (12:04 +1000)]
Fix logging reported in #841

11 months agoFix filecache issues on Windows
Matt Joiner [Sat, 27 May 2023 12:11:56 +0000 (22:11 +1000)]
Fix filecache issues on Windows

11 months agofs: Update path to torrentfs
Matt Joiner [Sat, 27 May 2023 10:54:46 +0000 (20:54 +1000)]
fs: Update path to torrentfs

11 months agofs: go mod tidy
Matt Joiner [Sat, 27 May 2023 10:53:59 +0000 (20:53 +1000)]
fs: go mod tidy

11 months agoFix addrPortOrZero for unix sockets on Windows
Matt Joiner [Sat, 27 May 2023 10:36:17 +0000 (20:36 +1000)]
Fix addrPortOrZero for unix sockets on Windows

11 months agoTimeout torrentfs CI after 5 minutes
Matt Joiner [Sat, 27 May 2023 10:10:16 +0000 (20:10 +1000)]
Timeout torrentfs CI after 5 minutes

11 months agoMore Windows test fixes
Matt Joiner [Sat, 27 May 2023 10:13:56 +0000 (20:13 +1000)]
More Windows test fixes

11 months agogo1.19 compat
Matt Joiner [Sat, 27 May 2023 05:05:23 +0000 (15:05 +1000)]
go1.19 compat

11 months agoTest fixes for Windows
Matt Joiner [Sat, 27 May 2023 04:57:41 +0000 (14:57 +1000)]
Test fixes for Windows

11 months agoFixes for storage tests on Windows
Matt Joiner [Sat, 27 May 2023 04:47:25 +0000 (14:47 +1000)]
Fixes for storage tests on Windows

11 months agoAdd check that torrent data cleanup works in TestIssue335
Matt Joiner [Sat, 27 May 2023 02:40:15 +0000 (12:40 +1000)]
Add check that torrent data cleanup works in TestIssue335

I'm seeing a lot of leaked directories on Windows I think. This might be silently failing.

11 months agoFix test failure using missinggo filecache on Windows
Matt Joiner [Sat, 27 May 2023 02:39:28 +0000 (12:39 +1000)]
Fix test failure using missinggo filecache on Windows

11 months agoMake fs a separate module
Matt Joiner [Sat, 27 May 2023 02:10:38 +0000 (12:10 +1000)]
Make fs a separate module

11 months agoAlso run Go CI test job on 1.19
Matt Joiner [Sat, 27 May 2023 00:58:29 +0000 (10:58 +1000)]
Also run Go CI test job on 1.19

11 months agoRun Go CI test job on macos and windows
Matt Joiner [Sat, 27 May 2023 00:46:24 +0000 (10:46 +1000)]
Run Go CI test job on macos and windows

11 months agoAdd WebRTC ICE servers config (#824)
Marco Vidonis [Sat, 27 May 2023 10:27:24 +0000 (11:27 +0100)]
Add WebRTC ICE servers config (#824)

* add ICEServers config

* remove unnecessary check

11 months agoFix ClientConfig.Logger.SetHandlers being clobbered
Matt Joiner [Wed, 24 May 2023 01:58:57 +0000 (11:58 +1000)]
Fix ClientConfig.Logger.SetHandlers being clobbered

Fixes https://github.com/anacrolix/torrent/issues/837.

11 months agoRemove PEX todo
Matt Joiner [Tue, 23 May 2023 11:25:36 +0000 (21:25 +1000)]
Remove PEX todo

11 months agogo1.19 compatibility
Matt Joiner [Tue, 23 May 2023 10:55:30 +0000 (20:55 +1000)]
go1.19 compatibility

12 months agoInclude holepunch message protocol family in metrics
Matt Joiner [Mon, 22 May 2023 05:28:28 +0000 (15:28 +1000)]
Include holepunch message protocol family in metrics

12 months agoAdd holepunch message fuzzing
Matt Joiner [Mon, 22 May 2023 05:27:06 +0000 (15:27 +1000)]
Add holepunch message fuzzing

12 months agoAdd a bunch of holepunch metrics
Matt Joiner [Sun, 21 May 2023 09:33:10 +0000 (19:33 +1000)]
Add a bunch of holepunch metrics

12 months agoPrint peer ID in ASCII-only
Matt Joiner [Sun, 21 May 2023 09:30:39 +0000 (19:30 +1000)]
Print peer ID in ASCII-only