Skip to content

Commit

Permalink
fix: wrong hook name in debug output (#262)
Browse files Browse the repository at this point in the history
  • Loading branch information
ocervell authored Apr 10, 2024
1 parent 9bb0be5 commit f2ee367
Showing 1 changed file with 33 additions and 5 deletions.
38 changes: 33 additions & 5 deletions secator/runners/_base.py
Original file line number Diff line number Diff line change
Expand Up @@ -159,12 +159,12 @@ def __init__(self, config, targets, results=[], run_opts={}, hooks={}, context={
for key in self.hooks:

# Register class specific hooks
instance_func = getattr(self, key, None)
if instance_func:
class_hook = getattr(self, key, None)
if class_hook:
name = f'{self.__class__.__name__}.{key}'
fun = f'{instance_func.__module__}.{instance_func.__name__}'
fun = self.get_func_path(class_hook)
debug('', obj={name + ' [dim yellow]->[/] ' + fun: 'registered'}, sub='hooks', level=3)
self.hooks[key].append(instance_func)
self.hooks[key].append(class_hook)

# Register user hooks
user_hooks = hooks.get(self.__class__, {}).get(key, [])
Expand Down Expand Up @@ -356,7 +356,7 @@ def run_hooks(self, hook_type, *args):
return result
for hook in self.hooks[hook_type]:
name = f'{self.__class__.__name__}.{hook_type}'
fun = f'{hook.__module__}.{hook.__name__}'
fun = self.get_func_path(hook)
try:
_id = self.context.get('task_id', '') or self.context.get('workflow_id', '') or self.context.get('scan_id', '')
debug('', obj={name + ' [dim yellow]->[/] ' + fun: 'started'}, id=_id, sub='hooks', level=3)
Expand Down Expand Up @@ -871,3 +871,31 @@ def get_repr(self, item=None):
elif isinstance(item, OutputType):
item = repr(item)
return item

@classmethod
def get_func_path(cls, func):
"""
Get the full symbolic path of a function or method, including staticmethods,
using function and method attributes.
Args:
func (function, method, or staticmethod): A function or method object.
"""
if hasattr(func, '__self__'):
if func.__self__ is not None:
# It's a method bound to an instance
class_name = func.__self__.__class__.__name__
return f"{func.__module__}.{class_name}.{func.__name__}"
else:
# It's a method bound to a class (class method)
class_name = func.__qualname__.rsplit('.', 1)[0]
return f"{func.__module__}.{class_name}.{func.__name__}"
else:
# Handle static and regular functions
if '.' in func.__qualname__:
# Static method or a function defined inside a class
class_name, func_name = func.__qualname__.rsplit('.', 1)
return f"{func.__module__}.{class_name}.{func_name}"
else:
# Regular function not attached to a class
return f"{func.__module__}.{func.__name__}"

0 comments on commit f2ee367

Please sign in to comment.