Do not format messages before they are logged

Change-Id: Ia645c9eca47b7f404d9b987f68a96b4744031e9d
Signed-off-by: Peter Portante <peter.portante@redhat.com>
This commit is contained in:
Peter Portante 2013-11-20 16:43:40 -05:00
parent 6b189e8ea9
commit a410730a2b
2 changed files with 18 additions and 15 deletions

View File

@ -99,7 +99,7 @@ class KeystoneAuth(object):
return self.app(environ, start_response) return self.app(environ, start_response)
if identity: if identity:
self.logger.debug('Using identity: %r' % (identity)) self.logger.debug('Using identity: %r', identity)
environ['keystone.identity'] = identity environ['keystone.identity'] = identity
environ['REMOTE_USER'] = identity.get('tenant') environ['REMOTE_USER'] = identity.get('tenant')
environ['swift.authorize'] = self.authorize environ['swift.authorize'] = self.authorize
@ -199,7 +199,7 @@ class KeystoneAuth(object):
# role. # role.
if self.reseller_admin_role in user_roles: if self.reseller_admin_role in user_roles:
msg = 'User %s has reseller admin authorizing' msg = 'User %s has reseller admin authorizing'
self.logger.debug(msg % tenant_id) self.logger.debug(msg, tenant_id)
req.environ['swift_owner'] = True req.environ['swift_owner'] = True
return return
@ -208,7 +208,7 @@ class KeystoneAuth(object):
if not container and not obj and req.method == 'DELETE': if not container and not obj and req.method == 'DELETE':
# User is not allowed to issue a DELETE on its own account # User is not allowed to issue a DELETE on its own account
msg = 'User %s:%s is not allowed to delete its own account' msg = 'User %s:%s is not allowed to delete its own account'
self.logger.debug(msg % (tenant_name, user_name)) self.logger.debug(msg, tenant_name, user_name)
return self.denied_response(req) return self.denied_response(req)
# cross-tenant authorization # cross-tenant authorization
@ -216,8 +216,8 @@ class KeystoneAuth(object):
tenant_id, tenant_name, tenant_id, tenant_name,
roles) roles)
if matched_acl is not None: if matched_acl is not None:
log_msg = 'user %s allowed in ACL authorizing.' % matched_acl log_msg = 'user %s allowed in ACL authorizing.'
self.logger.debug(log_msg) self.logger.debug(log_msg, matched_acl)
return return
acl_authorized = self._authorize_unconfirmed_identity(req, obj, acl_authorized = self._authorize_unconfirmed_identity(req, obj,
@ -229,8 +229,8 @@ class KeystoneAuth(object):
# Check if a user tries to access an account that does not match their # Check if a user tries to access an account that does not match their
# token # token
if not self._reseller_check(account, tenant_id): if not self._reseller_check(account, tenant_id):
log_msg = 'tenant mismatch: %s != %s' % (account, tenant_id) log_msg = 'tenant mismatch: %s != %s'
self.logger.debug(log_msg) self.logger.debug(log_msg, account, tenant_id)
return self.denied_response(req) return self.denied_response(req)
# Check the roles the user is belonging to. If the user is # Check the roles the user is belonging to. If the user is
@ -240,8 +240,8 @@ class KeystoneAuth(object):
for role in self.operator_roles.split(','): for role in self.operator_roles.split(','):
role = role.strip() role = role.strip()
if role in user_roles: if role in user_roles:
log_msg = 'allow user with role %s as account admin' % (role) log_msg = 'allow user with role %s as account admin'
self.logger.debug(log_msg) self.logger.debug(log_msg, role)
req.environ['swift_owner'] = True req.environ['swift_owner'] = True
return return
@ -260,8 +260,8 @@ class KeystoneAuth(object):
for user_role in user_roles: for user_role in user_roles:
if user_role in (r.lower() for r in roles): if user_role in (r.lower() for r in roles):
log_msg = 'user %s:%s allowed in ACL: %s authorizing' log_msg = 'user %s:%s allowed in ACL: %s authorizing'
self.logger.debug(log_msg % (tenant_name, user_name, self.logger.debug(log_msg, tenant_name, user_name,
user_role)) user_role)
return return
return self.denied_response(req) return self.denied_response(req)
@ -306,15 +306,15 @@ class KeystoneAuth(object):
and (req.environ['swift_sync_key'] == and (req.environ['swift_sync_key'] ==
req.headers.get('x-container-sync-key', None)) req.headers.get('x-container-sync-key', None))
and 'x-timestamp' in req.headers): and 'x-timestamp' in req.headers):
log_msg = 'allowing proxy %s for container-sync' % req.remote_addr log_msg = 'allowing proxy %s for container-sync'
self.logger.debug(log_msg) self.logger.debug(log_msg, req.remote_addr)
return True return True
# Check if referrer is allowed. # Check if referrer is allowed.
if swift_acl.referrer_allowed(req.referer, referrers): if swift_acl.referrer_allowed(req.referer, referrers):
if obj or '.rlistings' in roles: if obj or '.rlistings' in roles:
log_msg = 'authorizing %s via referer ACL' % req.referrer log_msg = 'authorizing %s via referer ACL'
self.logger.debug(log_msg) self.logger.debug(log_msg, req.referrer)
return True return True
return False return False

View File

@ -18,6 +18,7 @@ import unittest
from swift.common.middleware import keystoneauth from swift.common.middleware import keystoneauth
from swift.common.swob import Request, Response from swift.common.swob import Request, Response
from swift.common.http import HTTP_FORBIDDEN from swift.common.http import HTTP_FORBIDDEN
from test.unit import FakeLogger
class FakeApp(object): class FakeApp(object):
@ -42,6 +43,7 @@ class FakeApp(object):
class SwiftAuth(unittest.TestCase): class SwiftAuth(unittest.TestCase):
def setUp(self): def setUp(self):
self.test_auth = keystoneauth.filter_factory({})(FakeApp()) self.test_auth = keystoneauth.filter_factory({})(FakeApp())
self.test_auth.logger = FakeLogger()
def _make_request(self, path=None, headers=None, **kwargs): def _make_request(self, path=None, headers=None, **kwargs):
if not path: if not path:
@ -174,6 +176,7 @@ class SwiftAuth(unittest.TestCase):
class TestAuthorize(unittest.TestCase): class TestAuthorize(unittest.TestCase):
def setUp(self): def setUp(self):
self.test_auth = keystoneauth.filter_factory({})(FakeApp()) self.test_auth = keystoneauth.filter_factory({})(FakeApp())
self.test_auth.logger = FakeLogger()
def _make_request(self, path, **kwargs): def _make_request(self, path, **kwargs):
return Request.blank(path, **kwargs) return Request.blank(path, **kwargs)