| RT | Created | Time in Triage | Client | Subject |
|---|---|---|---|---|
| 55107 | 17 Jun, 08:32 | 0h 01m | NFW | nfwgs2.nfw.internal spamassassin maint service failure |
| 55140 | 17 Jun, 09:55 | 0h 34m | Kahootz | Borg backup objects in Glacier storage class |
| 55142 | 17 Jun, 10:30 | 0h 01m | BD Group | Several sites down on ef-v5-nodes.c.ef-platform.internal |
| 55144 | 17 Jun, 12:11 | 0h 23m | Gravytrain | Backup request from S3 |
| 55146 | 17 Jun, 14:46 | 0h 01m | Global Brands | DOWN: claycross.global-brands.internal |
| 55148 | 17 Jun, 23:04 | 0 | None | The Opportunity You Have Been Waiting For |
git hash: master (ddde22a4)
Current Site Packages Directory:
/app/.venv/lib/python3.14/site-packages
| Package | Version | Homepage | Summary |
|---|---|---|---|
| alchemical | 1.0.2 | None | Modern SQLAlchemy simplified |
| alembic | 1.18.1 | None | A database migration tool for SQLAlchemy. |
| annotated-types | 0.7.0 | None | Reusable constraint types to use with typing.Annotated |
| anyio | 4.12.1 | None | High-level concurrency and networking framework on top of asyncio or Trio |
| asttokens | 3.0.1 | https://github.com/gristlabs/asttokens | Annotate AST trees with source code positions |
| backoff | 2.2.1 | https://github.com/litl/backoff | Function decoration for backoff and retry |
| blinker | 1.9.0 | None | Fast, simple object-to-object and broadcast signaling |
| Bootstrap-Flask | 2.5.0 | None | Bootstrap 4 & 5 helper for your Flask projects. |
| certifi | 2026.1.4 | https://github.com/certifi/python-certifi | Python package for providing Mozilla's CA Bundle. |
| charset-normalizer | 3.4.4 | None | The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet. |
| click | 8.3.1 | None | Composable command line interface toolkit |
| colorlog | 6.10.1 | https://github.com/borntyping/python-colorlog | Add colours to the output of Python's logging module. |
| decorator | 5.2.1 | None | Decorators for Humans |
| executing | 2.2.1 | https://github.com/alexmojaki/executing | Get the currently executing AST node of a frame, and other information |
| Flask | 3.1.2 | None | A simple framework for building complex web applications. |
| Flask-DebugToolbar | 0.16.0 | None | A toolbar overlay for debugging Flask applications. |
| Flask-DebugToolbar-LineProfilerPanel | 1.0.2 | https://github.com/phleet/flask_debugtoolbar_lineprofilerpanel | Panel for the Flask Debug toolbar to capture and view line-by-line profiling stats |
| Flask-Migrate | 4.1.0 | None | SQLAlchemy database migrations for Flask applications using Alembic. |
| Flask-SQLAlchemy | 3.1.1 | None | Add SQLAlchemy support to your Flask application. |
| Flask-WTF | 1.2.2 | None | Form rendering, validation, and CSRF protection for Flask with WTForms. |
| freezegun | 1.5.5 | https://github.com/spulec/freezegun | Let your Python tests travel through time |
| gql | 4.0.0 | https://github.com/graphql-python/gql | GraphQL client for Python |
| graphql-core | 3.2.7 | https://github.com/graphql-python/graphql-core | GraphQL implementation for Python, a port of GraphQL.js, the JavaScript reference implementation for GraphQL. |
| greenlet | 3.3.0 | https://greenlet.readthedocs.io/ | Lightweight in-process concurrent programming |
| gunicorn | 23.0.0 | None | WSGI HTTP Server for UNIX |
| h11 | 0.16.0 | https://github.com/python-hyper/h11 | A pure-Python, bring-your-own-I/O implementation of HTTP/1.1 |
| httpcore | 1.0.9 | None | A minimal low-level HTTP client. |
| httpx | 0.28.1 | None | The next generation HTTP client. |
| idna | 3.11 | None | Internationalized Domain Names in Applications (IDNA) |
| ilock | 1.0.3 | https://github.com/symonsoft/ilock | Inter-process named lock library |
| ipython | 9.9.0 | None | IPython: Productive Interactive Computing |
| ipython_pygments_lexers | 1.1.1 | None | Defines a variety of Pygments lexers for highlighting IPython code. |
| itsdangerous | 2.2.0 | None | Safely pass data to untrusted environments and back. |
| jedi | 0.19.2 | https://github.com/davidhalter/jedi | An autocompletion tool for Python that can be used for text editors. |
| Jinja2 | 3.1.6 | None | A very fast and expressive template engine. |
| librt | 0.7.8 | None | Mypyc runtime library |
| line_profiler | 5.0.0 | https://github.com/pyutils/line_profiler | Line-by-line profiler |
| Mako | 1.3.10 | https://www.makotemplates.org/ | A super-fast templating language that borrows the best ideas from the existing templating languages. |
| MarkupSafe | 3.0.3 | None | Safely add untrusted strings to HTML/XML markup. |
| matplotlib-inline | 0.2.1 | None | Inline Matplotlib backend for Jupyter |
| multidict | 6.7.0 | https://github.com/aio-libs/multidict | multidict implementation |
| mypy | 1.19.1 | None | Optional static typing for Python |
| mypy_extensions | 1.1.0 | None | Type system extensions for programs checked with the mypy type checker. |
| packaging | 25.0 | None | Core utilities for Python packages |
| parso | 0.8.5 | https://github.com/davidhalter/parso | A Python Parser |
| pathspec | 1.0.3 | None | Utility library for gitignore style pattern matching of file paths. |
| pdbp | 1.8.2 | https://github.com/mdmintz/pdbp | pdbp (Pdb+): A drop-in replacement for pdb and pdbpp. |
| pexpect | 4.9.0 | https://pexpect.readthedocs.io/ | Pexpect allows easy control of interactive console applications. |
| portalocker | 3.2.0 | None | Wraps the portalocker recipe for easy usage |
| prompt_toolkit | 3.0.52 | None | Library for building powerful interactive command lines in Python |
| propcache | 0.4.1 | https://github.com/aio-libs/propcache | Accelerated property cache |
| psycopg | 3.3.2 | None | PostgreSQL database adapter for Python |
| psycopg-binary | 3.3.2 | None | PostgreSQL database adapter for Python -- C optimisation distribution |
| ptyprocess | 0.7.0 | https://github.com/pexpect/ptyprocess | Run a subprocess in a pseudo terminal |
| pure_eval | 0.2.3 | http://github.com/alexmojaki/pure_eval | Safely evaluate AST nodes without side effects |
| pydantic | 2.12.5 | None | Data validation using Python type hints |
| pydantic_core | 2.41.5 | https://github.com/pydantic/pydantic-core | Core functionality for Pydantic validation and serialization |
| Pygments | 2.19.2 | None | Pygments is a syntax highlighting package written in Python. |
| python-dateutil | 2.9.0.post0 | https://github.com/dateutil/dateutil | Extensions to the standard Python datetime module |
| python-dotenv | 1.2.1 | None | Read key-value pairs from a .env file and set them as environment variables |
| pytz | 2025.2 | http://pythonhosted.org/pytz | World timezone definitions, modern and historical |
| requests | 2.32.5 | https://requests.readthedocs.io | Python HTTP for Humans. |
| requests-toolbelt | 1.0.0 | https://toolbelt.readthedocs.io/ | A utility belt for advanced users of python-requests |
| rt | 3.4.0 | None | Python interface to Request Tracker API |
| six | 1.17.0 | https://github.com/benjaminp/six | Python 2 and 3 compatibility utilities |
| SQLAlchemy | 2.0.46 | https://www.sqlalchemy.org | Database Abstraction Library |
| stack-data | 0.6.3 | http://github.com/alexmojaki/stack_data | Extract data from python stack frames and tracebacks for informative displays |
| stackprinter | 0.2.12 | https://github.com/cknd/stackprinter | Debug-friendly stack traces, with variable values and semantic highlighting |
| tabcompleter | 1.4.0 | https://github.com/mdmintz/tabcompleter | tabcompleter --- Autocompletion in the Python console. |
| traitlets | 5.14.3 | None | Traitlets Python configuration system |
| types-pytz | 2025.2.0.20251108 | None | Typing stubs for pytz |
| typing-inspection | 0.4.2 | None | Runtime typing introspection tools |
| typing_extensions | 4.15.0 | None | Backported and Experimental Type Hints for Python 3.9+ |
| urllib3 | 2.6.3 | None | HTTP library with thread-safe connection pooling, file post, and more. |
| wcwidth | 0.2.14 | https://github.com/jquast/wcwidth | Measures the displayed width of unicode strings in a terminal |
| Werkzeug | 3.1.5 | None | The comprehensive WSGI web application library. |
| WTForms | 3.2.1 | None | Form validation and rendering for Python web development. |
| yarl | 1.22.0 | https://github.com/aio-libs/yarl | Yet another URL library |
| Resource | Value |
|---|---|
| User CPU time | 27.757 msec |
| System CPU time | 0.206 msec |
| Total CPU time | 27.963 msec |
| Elapsed time | 43.815 msec |
| Context switches | 9 voluntary, 0 involuntary |
| Key | Value |
|---|---|
| HTTP_ACCEPT | */* |
| HTTP_ACCEPT_ENCODING | gzip, br, zstd, deflate |
| HTTP_HOST | dashboard.uat.tigr.uk |
| HTTP_USER_AGENT | Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com) |
| QUERY_STRING | end=2025-06-17&start=2025-06-17 |
| REMOTE_ADDR | 10.42.13.14 |
| REQUEST_METHOD | GET |
| SCRIPT_NAME | |
| SERVER_NAME | 0.0.0.0 |
| SERVER_PORT | 8000 |
| SERVER_PROTOCOL | HTTP/1.1 |
| SERVER_SOFTWARE | gunicorn/23.0.0 |
| View Function | kwargs |
|---|---|
| app.views.ops_reports.triage_response_report_drilldown | None |
| Variable | Value |
|---|
No SESSION data
| Variable | Value |
|---|---|
| 'end' | '2025-06-17' |
| 'start' | '2025-06-17' |
| Variable | Value |
|---|
| Variable | Value |
|---|---|
| data | [<Ticket(id=5813, rt_number=55107, queue=Problems, subject=nfwgs2.nfw.internal spamassassin maint service failure, ticket_status=closed, client=NFW, priority=42, created=2025-06-17 08:32:43, last_txn_id=0>, <Ticket(id=5814, rt_number=55140, queue=Requests, subject=Borg backup objects in Glacier storage class, ticket_status=closed, client=Kahootz, priority=66, created=2025-06-17 09:55:18, last_txn_id=0>, <Ticket(id=5816, rt_number=55142, queue=Incidents, subject=Several sites down on ef-v5-nodes.c.ef-platform.internal, ticket_status=closed, client=BD Group, priority=83, created=2025-06-17 10:30:57, last_txn_id=0>, <Ticket(id=5818, rt_number=55144, queue=Requests, subject=Backup request from S3, ticket_status=closed, client=Gravytrain, priority=41, created=2025-06-17 12:11:20, last_txn_id=0>, <Ticket(id=5820, rt_number=55146, queue=Incidents, subject=DOWN: claycross.global-brands.internal, ticket_status=closed, client=Global Brands, priority=61, created=2025-06-17 14:46:37, last_txn_id=0>, <Ticket(id=5822, rt_number=55148, queue=Triage, subject=The Opportunity You Have Been Waiting For, ticket_status=rejected, client=None, priority=0, created=2025-06-17 23:04:40, last_txn_id=0>] |
| g | <flask.g of 'app'> |
| meta | {'end': datetime.date(2025, 6, 17), 'start': datetime.date(2025, 6, 17), 'target': 600, 'title': 'Triage response', 'warning_threshold': 0.5} |
| request | <Request 'http://dashboard.uat.tigr.uk/triage_response_report_drilldown?end=2025-06-17&start=2025-06-17' [GET]> |
| session | <SecureCookieSession {}> |
The toolbar was unable to fetch the SQLAlchemy queries for this request. To enable the SQLAlchemy query display, please:
The Flask-SQLAlchemy extension needs to be configured for this application. Please see the Flask-SQLAlchemy documentation for details.
| Level | Time | Message | Location |
|---|---|---|---|
| DEBUG | 2026-01-22 21:26:23.914527 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914588 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914603 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914613 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914621 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914630 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914638 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914645 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914653 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914660 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914668 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914676 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914684 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914691 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914699 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914706 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914714 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914722 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914730 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914737 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914745 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914754 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914762 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914770 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914778 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914786 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914794 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914801 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914809 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914817 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914824 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914832 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914839 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914847 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914854 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914861 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914869 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914876 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914884 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914891 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914897 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914903 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914910 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914916 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914922 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914928 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914935 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914941 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914948 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914956 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914963 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914970 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914976 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914983 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914989 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.914995 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915001 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915007 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915019 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915027 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915033 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915040 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915046 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915051 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915057 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915064 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915069 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915076 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915082 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915088 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915095 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915101 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915107 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915113 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915119 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915126 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915132 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915138 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915145 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915151 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915157 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915164 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915170 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915176 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915183 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915190 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915196 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915202 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915209 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915216 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915222 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915228 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915234 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915242 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915248 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915254 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915261 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915267 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915274 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915280 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915287 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915294 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915301 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915308 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915314 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915321 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915328 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915334 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915341 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915347 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915353 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915359 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915365 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915371 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915378 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915384 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915391 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915397 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915404 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915410 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915416 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915422 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915429 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915436 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915442 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915448 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915455 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915461 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915467 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915474 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915481 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915487 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915494 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915500 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915506 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915513 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915519 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915526 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915532 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915556 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915563 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915569 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915576 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915584 | xxx | ./services/model.py:838 |
| DEBUG | 2026-01-22 21:26:23.915590 | xxx | ./services/model.py:838 |
from flask_debugtoolbar_lineprofilerpanel.profile import line_profile
# Using it as a decorator
@app.route('/profile')
@line_profile
def profile_page():
...
return flask.render_template('profile_page')
# Explicit argument
line_profile(some_function)