* refactor(chalice): upgraded dependencies * refactor(chalice): upgraded dependencies feat(chalice): support heatmaps * fix(chalice): fixed Math-operators validation refactor(chalice): search for sessions that have events for heatmaps * refactor(chalice): search for sessions that have at least 1 location event for heatmaps * refactor(chalice): upgraded dependencies * refactor(chalice): upgraded dependencies feat(chalice): support heatmaps * fix(chalice): fixed Math-operators validation refactor(chalice): search for sessions that have events for heatmaps * refactor(chalice): search for sessions that have at least 1 location event for heatmaps * refactor(chalice): upgraded dependencies refactor(crons): upgraded dependencies refactor(alerts): upgraded dependencies * feat(chalice): get top 10 values for autocomplete CH * refactor(chalice): cleaned code refactor(chalice): upgraded dependencies refactor(alerts): upgraded dependencies refactor(crons): upgraded dependencies * feat(chalice): autocomplete return top 10 with stats * refactor(chalice): refactored logger * fix(chalice): fixed autocomplete top 10 meta-filters
31 lines
1.3 KiB
Python
31 lines
1.3 KiB
Python
from functools import wraps
|
|
from time import time
|
|
import inspect
|
|
from chalicelib.utils import helper
|
|
import logging
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
def timed(f):
|
|
@wraps(f)
|
|
def wrapper(*args, **kwds):
|
|
if not helper.TRACK_TIME:
|
|
return f(*args, **kwds)
|
|
start = time()
|
|
result = f(*args, **kwds)
|
|
elapsed = time() - start
|
|
if inspect.stack()[1][3] == "_view_func":
|
|
logger.debug("%s: took %d s to finish" % (f.__name__, elapsed))
|
|
else:
|
|
call_stack = [i[3] for i in inspect.stack()[1:] if i[3] != "wrapper"]
|
|
call_stack = [c for c in call_stack if
|
|
c not in ['__init__', '__call__', 'finish_request', 'process_request_thread',
|
|
'handle_request', '_generic_handle', 'handle', '_bootstrap_inner', 'run',
|
|
'_bootstrap', '_main_rest_api_handler', '_user_handler',
|
|
'_get_view_function_response', 'wrapped_event', 'handle_one_request',
|
|
'_global_error_handler', 'openreplay_middleware']]
|
|
logger.debug("%s > %s took %d s to finish" % (" > ".join(call_stack), f.__name__, elapsed))
|
|
return result
|
|
|
|
return wrapper
|