*(minor): make better use of structured logging
This commit is contained in:
parent
c0df1f38b8
commit
0b86231a36
|
@ -22,6 +22,6 @@ class PassbookCoreConfig(AppConfig):
|
||||||
for factors_to_load in factors_to_load:
|
for factors_to_load in factors_to_load:
|
||||||
try:
|
try:
|
||||||
import_module(factors_to_load)
|
import_module(factors_to_load)
|
||||||
LOGGER.info("Loaded %s", factors_to_load)
|
LOGGER.info("Loaded factor", factor_class=factors_to_load)
|
||||||
except ImportError as exc:
|
except ImportError as exc:
|
||||||
LOGGER.debug(exc)
|
LOGGER.debug(exc)
|
||||||
|
|
|
@ -31,14 +31,14 @@ def authenticate(request, backends, **credentials):
|
||||||
signature = Signature.from_callable(backend.authenticate)
|
signature = Signature.from_callable(backend.authenticate)
|
||||||
signature.bind(request, **credentials)
|
signature.bind(request, **credentials)
|
||||||
except TypeError:
|
except TypeError:
|
||||||
LOGGER.debug("Backend %s doesn't accept our arguments", backend)
|
LOGGER.debug("Backend doesn't accept our arguments", backend=backend)
|
||||||
# This backend doesn't accept these credentials as arguments. Try the next one.
|
# This backend doesn't accept these credentials as arguments. Try the next one.
|
||||||
continue
|
continue
|
||||||
LOGGER.debug('Attempting authentication with %s...', backend)
|
LOGGER.debug('Attempting authentication...', backend=backend)
|
||||||
try:
|
try:
|
||||||
user = backend.authenticate(request, **credentials)
|
user = backend.authenticate(request, **credentials)
|
||||||
except PermissionDenied:
|
except PermissionDenied:
|
||||||
LOGGER.debug('Backend %r threw PermissionDenied', backend)
|
LOGGER.debug('Backend threw PermissionDenied', backend=backend)
|
||||||
# This backend says to stop in our tracks - this user should not be allowed in at all.
|
# This backend says to stop in our tracks - this user should not be allowed in at all.
|
||||||
break
|
break
|
||||||
if user is None:
|
if user is None:
|
||||||
|
@ -104,5 +104,5 @@ class PasswordFactor(FormView, AuthenticationFactor):
|
||||||
return self.form_invalid(form)
|
return self.form_invalid(form)
|
||||||
except PermissionDenied:
|
except PermissionDenied:
|
||||||
# User was found, but permission was denied (i.e. user is not active)
|
# User was found, but permission was denied (i.e. user is not active)
|
||||||
LOGGER.debug("Denied access to %s", kwargs)
|
LOGGER.debug("Denied access", **kwargs)
|
||||||
return self.authenticator.user_invalid()
|
return self.authenticator.user_invalid()
|
||||||
|
|
|
@ -100,17 +100,18 @@ class AuthenticationView(UserPassesTestMixin, View):
|
||||||
|
|
||||||
def get(self, request, *args, **kwargs):
|
def get(self, request, *args, **kwargs):
|
||||||
"""pass get request to current factor"""
|
"""pass get request to current factor"""
|
||||||
LOGGER.debug("Passing GET to %s", class_to_path(self._current_factor_class.__class__))
|
LOGGER.debug("Passing GET", view_class=class_to_path(self._current_factor_class.__class__))
|
||||||
return self._current_factor_class.get(request, *args, **kwargs)
|
return self._current_factor_class.get(request, *args, **kwargs)
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
def post(self, request, *args, **kwargs):
|
||||||
"""pass post request to current factor"""
|
"""pass post request to current factor"""
|
||||||
LOGGER.debug("Passing POST to %s", class_to_path(self._current_factor_class.__class__))
|
LOGGER.debug("Passing POST", view_class=class_to_path(self._current_factor_class.__class__))
|
||||||
return self._current_factor_class.post(request, *args, **kwargs)
|
return self._current_factor_class.post(request, *args, **kwargs)
|
||||||
|
|
||||||
def user_ok(self):
|
def user_ok(self):
|
||||||
"""Redirect to next Factor"""
|
"""Redirect to next Factor"""
|
||||||
LOGGER.debug("Factor %s passed", class_to_path(self._current_factor_class.__class__))
|
LOGGER.debug("Factor passed",
|
||||||
|
factor_class=class_to_path(self._current_factor_class.__class__))
|
||||||
# Remove passed factor from pending factors
|
# Remove passed factor from pending factors
|
||||||
current_factor_tuple = (self.current_factor.uuid.hex,
|
current_factor_tuple = (self.current_factor.uuid.hex,
|
||||||
class_to_path(self._current_factor_class.__class__))
|
class_to_path(self._current_factor_class.__class__))
|
||||||
|
@ -123,7 +124,7 @@ class AuthenticationView(UserPassesTestMixin, View):
|
||||||
self.request.session[AuthenticationView.SESSION_PENDING_FACTORS] = \
|
self.request.session[AuthenticationView.SESSION_PENDING_FACTORS] = \
|
||||||
self.pending_factors
|
self.pending_factors
|
||||||
self.request.session[AuthenticationView.SESSION_FACTOR] = next_factor
|
self.request.session[AuthenticationView.SESSION_FACTOR] = next_factor
|
||||||
LOGGER.debug("Rendering Factor is %s", next_factor)
|
LOGGER.debug("Rendering Factor", next_factor=next_factor)
|
||||||
return _redirect_with_qs('passbook_core:auth-process', self.request.GET)
|
return _redirect_with_qs('passbook_core:auth-process', self.request.GET)
|
||||||
# User passed all factors
|
# User passed all factors
|
||||||
LOGGER.debug("User passed all factors, logging in")
|
LOGGER.debug("User passed all factors, logging in")
|
||||||
|
@ -140,7 +141,7 @@ class AuthenticationView(UserPassesTestMixin, View):
|
||||||
"""User Successfully passed all factors"""
|
"""User Successfully passed all factors"""
|
||||||
backend = self.request.session[AuthenticationView.SESSION_USER_BACKEND]
|
backend = self.request.session[AuthenticationView.SESSION_USER_BACKEND]
|
||||||
login(self.request, self.pending_user, backend=backend)
|
login(self.request, self.pending_user, backend=backend)
|
||||||
LOGGER.debug("Logged in user %s", self.pending_user)
|
LOGGER.debug("Logged in", user=self.pending_user)
|
||||||
# Cleanup
|
# Cleanup
|
||||||
self.cleanup()
|
self.cleanup()
|
||||||
next_param = self.request.GET.get('next', None)
|
next_param = self.request.GET.get('next', None)
|
||||||
|
|
|
@ -279,8 +279,8 @@ class FieldMatcherPolicy(Policy):
|
||||||
if not hasattr(request.user, self.user_field):
|
if not hasattr(request.user, self.user_field):
|
||||||
raise ValueError("Field does not exist")
|
raise ValueError("Field does not exist")
|
||||||
user_field_value = getattr(request.user, self.user_field, None)
|
user_field_value = getattr(request.user, self.user_field, None)
|
||||||
LOGGER.debug("Checked '%s' %s with '%s'...",
|
LOGGER.debug("Checking field", value=user_field_value,
|
||||||
user_field_value, self.match_action, self.value)
|
action=self.match_action, should_be=self.value)
|
||||||
passes = False
|
passes = False
|
||||||
if self.match_action == FieldMatcherPolicy.MATCH_STARTSWITH:
|
if self.match_action == FieldMatcherPolicy.MATCH_STARTSWITH:
|
||||||
passes = user_field_value.startswith(self.value)
|
passes = user_field_value.startswith(self.value)
|
||||||
|
@ -293,8 +293,6 @@ class FieldMatcherPolicy(Policy):
|
||||||
passes = bool(pattern.match(user_field_value))
|
passes = bool(pattern.match(user_field_value))
|
||||||
if self.match_action == FieldMatcherPolicy.MATCH_EXACT:
|
if self.match_action == FieldMatcherPolicy.MATCH_EXACT:
|
||||||
passes = user_field_value == self.value
|
passes = user_field_value == self.value
|
||||||
|
|
||||||
LOGGER.debug("User got '%r'", passes)
|
|
||||||
return PolicyResult(passes)
|
return PolicyResult(passes)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -328,7 +326,6 @@ class PasswordPolicy(Policy):
|
||||||
if self.amount_symbols > 0:
|
if self.amount_symbols > 0:
|
||||||
filter_regex += r'[%s]{%d,}' % (self.symbol_charset, self.amount_symbols)
|
filter_regex += r'[%s]{%d,}' % (self.symbol_charset, self.amount_symbols)
|
||||||
result = bool(re.compile(filter_regex).match(password))
|
result = bool(re.compile(filter_regex).match(password))
|
||||||
LOGGER.debug("User got %r", result)
|
|
||||||
if not result:
|
if not result:
|
||||||
return PolicyResult(result, self.error_message)
|
return PolicyResult(result, self.error_message)
|
||||||
return PolicyResult(result)
|
return PolicyResult(result)
|
||||||
|
@ -387,7 +384,7 @@ class DebugPolicy(Policy):
|
||||||
def passes(self, request: PolicyRequest) -> PolicyResult:
|
def passes(self, request: PolicyRequest) -> PolicyResult:
|
||||||
"""Wait random time then return result"""
|
"""Wait random time then return result"""
|
||||||
wait = SystemRandom().randrange(self.wait_min, self.wait_max)
|
wait = SystemRandom().randrange(self.wait_min, self.wait_max)
|
||||||
LOGGER.debug("Policy '%s' waiting for %ds", self.name, wait)
|
LOGGER.debug("Policy waiting", policy=self, delay=wait)
|
||||||
sleep(wait)
|
sleep(wait)
|
||||||
return PolicyResult(self.result, 'Debugging')
|
return PolicyResult(self.result, 'Debugging')
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ def invalidate_policy_cache(sender, instance, **kwargs):
|
||||||
"""Invalidate Policy cache when policy is updated"""
|
"""Invalidate Policy cache when policy is updated"""
|
||||||
from passbook.core.models import Policy
|
from passbook.core.models import Policy
|
||||||
if isinstance(instance, Policy):
|
if isinstance(instance, Policy):
|
||||||
LOGGER.debug("Invalidating cache for %s", instance.pk)
|
LOGGER.debug("Invalidating policy cache", policy=instance)
|
||||||
keys = cache.keys("%s#*" % instance.pk)
|
keys = cache.keys("%s#*" % instance.pk)
|
||||||
cache.delete_many(keys)
|
cache.delete_many(keys)
|
||||||
LOGGER.debug("Deleted %d keys", len(keys))
|
LOGGER.debug("Deleted %d keys", len(keys))
|
||||||
|
|
|
@ -22,6 +22,6 @@ class PassbookOAuthClientConfig(AppConfig):
|
||||||
for source_type in source_types_to_load:
|
for source_type in source_types_to_load:
|
||||||
try:
|
try:
|
||||||
import_module(source_type)
|
import_module(source_type)
|
||||||
LOGGER.info("Loaded %s", source_type)
|
LOGGER.info("Loaded source_type", source_class=source_type)
|
||||||
except ImportError as exc:
|
except ImportError as exc:
|
||||||
LOGGER.debug(exc)
|
LOGGER.debug(exc)
|
||||||
|
|
|
@ -27,7 +27,7 @@ class SourceTypeManager:
|
||||||
self.__source_types[kind] = {}
|
self.__source_types[kind] = {}
|
||||||
self.__source_types[kind][name.lower()] = cls
|
self.__source_types[kind][name.lower()] = cls
|
||||||
self.__names.append(name)
|
self.__names.append(name)
|
||||||
LOGGER.debug("Registered source '%s' for '%s'", cls.__name__, kind)
|
LOGGER.debug("Registered source", source_class=cls.__name__, kind=kind)
|
||||||
return cls
|
return cls
|
||||||
return inner_wrapper
|
return inner_wrapper
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ for _passbook_app in get_apps():
|
||||||
_passbook_app.label),
|
_passbook_app.label),
|
||||||
namespace=_passbook_app.label))
|
namespace=_passbook_app.label))
|
||||||
urlpatterns.append(_path)
|
urlpatterns.append(_path)
|
||||||
LOGGER.debug("Loaded %s's URLs", _passbook_app.name)
|
LOGGER.debug("Mounted URLs", app_name=_passbook_app.name)
|
||||||
|
|
||||||
urlpatterns += [
|
urlpatterns += [
|
||||||
# Administration
|
# Administration
|
||||||
|
|
|
@ -22,6 +22,6 @@ class PassbookSAMLIDPConfig(AppConfig):
|
||||||
for source_type in source_types_to_load:
|
for source_type in source_types_to_load:
|
||||||
try:
|
try:
|
||||||
import_module(source_type)
|
import_module(source_type)
|
||||||
LOGGER.info("Loaded %s", source_type)
|
LOGGER.info("Loaded SAML Processor", processor_class=source_type)
|
||||||
except ImportError as exc:
|
except ImportError as exc:
|
||||||
LOGGER.debug(exc)
|
LOGGER.debug(exc)
|
||||||
|
|
|
@ -28,14 +28,14 @@ def update_score(request, username, amount):
|
||||||
ip_score, _ = IPScore.objects.update_or_create(ip=remote_ip)
|
ip_score, _ = IPScore.objects.update_or_create(ip=remote_ip)
|
||||||
ip_score.score += amount
|
ip_score.score += amount
|
||||||
ip_score.save()
|
ip_score.save()
|
||||||
LOGGER.debug("Added %s to score of IP %s", amount, remote_ip)
|
LOGGER.debug("Updated score", amount=amount, for_ip=remote_ip)
|
||||||
user = User.objects.filter(username=username)
|
user = User.objects.filter(username=username)
|
||||||
if not user.exists():
|
if not user.exists():
|
||||||
return
|
return
|
||||||
user_score, _ = UserScore.objects.update_or_create(user=user.first())
|
user_score, _ = UserScore.objects.update_or_create(user=user.first())
|
||||||
user_score.score += amount
|
user_score.score += amount
|
||||||
user_score.save()
|
user_score.save()
|
||||||
LOGGER.debug("Added %s to score of User %s", amount, username)
|
LOGGER.debug("Updated score", amount=amount, for_user=username)
|
||||||
|
|
||||||
@receiver(user_login_failed)
|
@receiver(user_login_failed)
|
||||||
def handle_failed_login(sender, request, credentials, **kwargs):
|
def handle_failed_login(sender, request, credentials, **kwargs):
|
||||||
|
|
Reference in a new issue