Merge pull request #490 from exarkun/pending-deprecations

Avoid pending Twisted deprecations
This commit is contained in:
meejah 2018-05-01 11:07:09 -06:00 committed by GitHub
commit 5bbf0abe9d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 30 additions and 11 deletions

View File

@ -2,6 +2,10 @@ import re, time
from twisted.application import service, strports, internet from twisted.application import service, strports, internet
from twisted.web import http, static from twisted.web import http, static
from twisted.internet import defer from twisted.internet import defer
from twisted.internet.address import (
IPv4Address,
IPv6Address,
)
from nevow import appserver, inevow from nevow import appserver, inevow
from allmydata.util import log, fileutil from allmydata.util import log, fileutil
@ -114,8 +118,12 @@ class MyRequest(appserver.NevowRequest):
if self._tahoe_request_had_error: if self._tahoe_request_had_error:
error = " [ERROR]" error = " [ERROR]"
log.msg(format="web: %(clientip)s %(method)s %(uri)s %(code)s %(length)s%(error)s", log.msg(
clientip=self.getClientIP(), format=(
"web: %(clientip)s %(method)s %(uri)s %(code)s "
"%(length)s%(error)s"
),
clientip=_get_client_ip(self),
method=self.method, method=self.method,
uri=uri, uri=uri,
code=self.code, code=self.code,
@ -126,6 +134,18 @@ class MyRequest(appserver.NevowRequest):
) )
def _get_client_ip(request):
try:
get = request.getClientAddress
except AttributeError:
return request.getClientIP()
else:
client_addr = get()
if isinstance(client_addr, (IPv4Address, IPv6Address)):
return client_addr.host
return None
class WebishServer(service.MultiService): class WebishServer(service.MultiService):
name = "webish" name = "webish"
@ -218,4 +238,3 @@ class IntroducerWebishServer(WebishServer):
service.MultiService.__init__(self) service.MultiService.__init__(self)
self.root = introweb.IntroducerRoot(introducer) self.root = introweb.IntroducerRoot(introducer)
self.buildServer(webport, nodeurl_path, staticdir) self.buildServer(webport, nodeurl_path, staticdir)