]> git.mxchange.org Git - quix0rs-apt-p2p.git/blobdiff - apt_dht/HTTPServer.py
Lots of log messages and blocked non-local access to server.
[quix0rs-apt-p2p.git] / apt_dht / HTTPServer.py
index f5e969ccfc81c8565c77d56c56b3d60ea8662803..1e049c392a789a0f4250bf6a05ef8664e8f00709 100644 (file)
@@ -1,5 +1,6 @@
 import os.path, time
 
 import os.path, time
 
+from twisted.python import log
 from twisted.web2 import server, http, resource, channel
 from twisted.web2 import static, http_headers, responsecode
 
 from twisted.web2 import server, http, resource, channel
 from twisted.web2 import static, http_headers, responsecode
 
@@ -10,13 +11,17 @@ class FileDownloader(static.File):
         super(FileDownloader, self).__init__(path, defaultType, ignoredExts, processors, indexNames)
         
     def render(self, req):
         super(FileDownloader, self).__init__(path, defaultType, ignoredExts, processors, indexNames)
         
     def render(self, req):
+        log.msg('Got request for %s from %s' % (req.uri, req.remoteAddr))
         resp = super(FileDownloader, self).render(req)
         resp = super(FileDownloader, self).render(req)
+        log.msg('Initial response to %s: %r' % (req.uri, resp))
         
         if self.manager:
             path = 'http:/' + req.uri
             if resp != responsecode.NOT_FOUND:
         
         if self.manager:
             path = 'http:/' + req.uri
             if resp != responsecode.NOT_FOUND:
+                log.msg('Checking freshness of %s' % req.uri)
                 return self.manager.check_freshness(path, resp.headers.getHeader('Last-Modified'), resp)
             
                 return self.manager.check_freshness(path, resp.headers.getHeader('Last-Modified'), resp)
             
+            log.msg('Not found, trying other methods for %s' % req.uri)
             return self.manager.get_resp(path)
         
         return resp
             return self.manager.get_resp(path)
         
         return resp
@@ -24,6 +29,8 @@ class FileDownloader(static.File):
     def createSimilarFile(self, path):
         return self.__class__(path, self.manager, self.defaultType, self.ignoredExts,
                               self.processors, self.indexNames[:])
     def createSimilarFile(self, path):
         return self.__class__(path, self.manager, self.defaultType, self.ignoredExts,
                               self.processors, self.indexNames[:])
+        
+        
 class TopLevel(resource.Resource):
     addSlash = True
     
 class TopLevel(resource.Resource):
     addSlash = True
     
@@ -55,13 +62,20 @@ class TopLevel(resource.Resource):
             try:
                 loc = int(name[1:])
             except:
             try:
                 loc = int(name[1:])
             except:
+                log.msg('Not found: %s from %s' % (request.uri, request.remoteAddr))
                 return None, ()
             
             if loc >= 0 and loc < len(self.subdirs) and self.subdirs[loc]:
                 return None, ()
             
             if loc >= 0 and loc < len(self.subdirs) and self.subdirs[loc]:
+                log.msg('Sharing %s with %s' % (request.uri, request.remoteAddr))
                 return static.File(self.subdirs[loc]), segments[1:]
             else:
                 return static.File(self.subdirs[loc]), segments[1:]
             else:
+                log.msg('Not found: %s from %s' % (request.uri, request.remoteAddr))
                 return None, ()
         
                 return None, ()
         
+        if request.remoteAddr.host != "127.0.0.1":
+            log.msg('Blocked illegal access to %s from %s' % (request.uri, request.remoteAddr))
+            return None, ()
+            
         if len(name) > 1:
             return FileDownloader(self.directory, self.manager), segments[0:]
         else:
         if len(name) > 1:
             return FileDownloader(self.directory, self.manager), segments[0:]
         else: