Comments (8)
There are no current plans. I believe it's quite straightforward. It can be done via a connection hook. All writing and reading on the wire are done via connection.rw
. That's already a series of hooks that take care of protocol encryption, TCP vs. uTP, as well as deadlines. You could add a hook either before any handshaking occurs (client.{incoming,outgoing}Connection
), or during the message exchange loop (client.connectionLoop
) as you see fit. Rate limiting on downloads would result in the peer doing the appropriate things with the protocol. Rate limiting on upload is a little harder. Currently connection.writeOptimizer
will help significantly applying backpressure from inability to write due to rate limiting back to the client. There's probably some improvements that could be done there, but it's not necessary to get the basics working.
I tried to link to areas of the code via https://sourcegraph.com/github.com/anacrolix/torrent but it didn't work very well.
from torrent.
Passing a facade connection.rw
sounds like a good idea. Could newConnection()
become newConnection(nc net.Conn)
? Could then move c.conn = nc
and c.rw = nc
inside the constructor.
Then before you call newConnection
:
type ConnectionHook func(nc net.Conn) net.Conn
func (cl *client) SetDownloadHook(hook ConnectionHook) {
}
func (cl *client) SetUploadHook(hook ConnectionHook) {
}
//outgoing
if cl.hookUpload != nil {
nc = cl.HookUpload(nc)
}
c := newConnection(nc)
//incoming
if cl.hookDownload != nil {
nc = cl.hookDownload(nc)
}
c := newConnection(nc)
Or hooks could just be public, and you set them directly.
I can try my hand at a PR if needed
from torrent.
I believe newConnection
did take a bunch of arguments previously to completely instantiate itself in one go. I removed a lot of assumptions from it (like that it had to be connected immediately) so as to allow manipulating a lot of its optional state, and installing hooks as required. If you see in receiveHandshakes
and initiateHandshakes
that connection fields are then further manipulated, I thought it best not to give people the false assumption that fields like rw
and conn
were necessarily only assigned to in newConnection
.
I think since connections can exist before torrents are even added, that perhaps the hooks could come in via the client Config. I see no reason to allow modifying the hooks once a client is already created via NewClient. This will let us simplify our management of the hooks. A PR would be great. When/where to install the hooks is up to you. That is whether you want them before or after handshakes, above or below the encryption/BitTorrent protocol or directly on top of the transport.
I'm also not sure if it's necessary to separate the ReadWriter into separate parts (ie by having Upload/Download separate). I'm not sure what's gained/lost from this. At least presently it's rw io.ReadWriter
, but the read/write parts are used separately. Whatever works best.
from torrent.
Hey @anacrolix sorry, haven't had time to look into this for a while. I've started my torrent client and I've got a ways to go, though rate limiting still will be needed.
Check out the planned features https://github.com/jpillora/cloud-torrent and let me know if it's something you'd use or if you have any ideas - comment on the issues - we'll leave this issue just for rate limiting.
from torrent.
I have a similar private project. anacrolix/torrent is designed with supporting the features you require for that project in mind.
from torrent.
Alrighty, well if you ever want to combine forces - let me know
from torrent.
@jpillora Note this was fixed in d4cbdc5 and 836bb34.
from torrent.
from torrent.
Related Issues (20)
- Does this anacrolix/torrent support storage permission? HOT 2
- About holepunching test HOT 5
- Reinstate torrentfs on CI using fuse-t?
- x/exp: breaking changes support HOT 8
- Cannot `go get` this library HOT 3
- Inferring reasons for stopped transfer? HOT 3
- Race from peerconn on data read of closed torrent with [email protected] HOT 4
- Clean up ClientConfig HTTP options HOT 3
- error bootstrapping during bucket refresh: getting starting nodes: nothing resolved [dht 0.0.0.0:42069 github.com/anacrolix/dht/v2 server.go:1395] HOT 7
- Webseed download extremely slow HOT 1
- Count the number of bytes uploaded or downloaded. HOT 6
- Peer Selection Algorithm
- undefined: sync.OnceFunc HOT 7
- Support passing context to `torrent.Reader` HOT 1
- How to config DHT listen port? HOT 4
- Add global semaphore to limit amount of pieceHashers
- Problem getting magnet metadata on large files HOT 6
- Client requests indefinitely on storage write errors HOT 42
- More than 3 times slow download speed over sqllite storage HOT 9
- Prioritize the use of local peers HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from torrent.