From 79881b55b22f229afa46f1e71ee61358fa5a9f4b Mon Sep 17 00:00:00 2001 From: Cameron Dale Date: Mon, 31 Mar 2008 15:32:04 -0700 Subject: [PATCH] Only throttle uploads to peers, not to apt. --- apt_p2p/HTTPServer.py | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/apt_p2p/HTTPServer.py b/apt_p2p/HTTPServer.py index 03eea99..b12ca71 100644 --- a/apt_p2p/HTTPServer.py +++ b/apt_p2p/HTTPServer.py @@ -9,7 +9,7 @@ from twisted.internet import defer from twisted.web2 import server, http, resource, channel, stream from twisted.web2 import static, http_headers, responsecode -from policies import ThrottlingFactory +from policies import ThrottlingFactory, ThrottlingProtocol, ProtocolWrapper from apt_p2p_Khashmir.bencode import bencode class FileDownloader(static.File): @@ -127,6 +127,31 @@ class FileUploader(static.File): return response +class UploadThrottlingProtocol(ThrottlingProtocol): + """Protocol for throttling uploads. + + Determines whether or not to throttle the upload based on the type of stream. + Uploads use L{FileUploaderStream} or L{twisted.web2.stream.MemorySTream}, + apt uses L{CacheManager.ProxyFileStream} or L{twisted.web.stream.FileStream}. + """ + + def __init__(self, factory, wrappedProtocol): + ThrottlingProtocol.__init__(self, factory, wrappedProtocol) + self.throttle = False + + def write(self, data): + if self.throttle: + ThrottlingProtocol.write(self, data) + else: + ProtocolWrapper.write(self, data) + + def registerProducer(self, producer, streaming): + ThrottlingProtocol.registerProducer(self, producer, streaming) + streamType = getattr(producer, 'stream', None) + if isinstance(streamType, FileUploaderStream) or isinstance(streamType, stream.MemoryStream): + self.throttle = True + + class TopLevel(resource.Resource): """The HTTP server for all requests, both from peers and apt. @@ -164,6 +189,7 @@ class TopLevel(resource.Resource): **{'maxPipeline': 10, 'betweenRequestsTimeOut': 60}) self.factory = ThrottlingFactory(self.factory, writeLimit = 30*1024) + self.factory.protocol = UploadThrottlingProtocol return self.factory def render(self, ctx): -- 2.39.5