Simple, beautiful logging from Flask web apps to FireBug console
After a long time away, I circled back to it, and with help from the Flask folks, got it working smoothly.
Indeed, it was so simple to do, knowing the right invocation and configuration, that I can only blame myself for not getting it earlier. My only consolation is that there is no real documentation (the usage link on FireLogger’s home page is a dead link).
So, having figured it out, I’m sharing in the hopes that others can now simply use this beautiful tool.
The code is sufficiently simple I can put the core of it here:
from flask import Flask from logging import DEBUG from firepython.middleware import FirePythonWSGI, logging app = Flask('appname') app.wsgi_app = FirePythonWSGI(app.wsgi_app) logging.getLogger().setLevel(DEBUG)
That’s it. Now you’re off to the races. When the app server is run, any logging messages you direct to the logging object end up in your FireBug / FireLogger console. More complete versions of this demo code can be found in trivial.py and demo_primitive.py in the repository.
To make things even simpler, the fireflask module requires just two lines of code (one to import fireflask, and one to put it into operation).
from flask import Flask from fireflask import * app = Flask('appname') FireFlask(app) @app.route('/') def hello_world(): logging.info('serving hello_world content') return 'Hello World!' app.run()
Here we’ve completed the program with a function that provides content, and the startup code for the Flask web server. fireflask isn’t a huge lines-of-code savings, but it will save you a few steps and make the program cleaner.
To install or upgrade to the latest version of fireflask:
pip install -U fireflask
This will install the firepython module automatically. Or, if you want to use just the primitive approach:
pip install -U firepython
(You may need to prefix these with sudo to authorize installation.)
Use the standard Firefox tools to install FireBug and the FireLogger extension.
To run the demonstration programs, run trivial.py, demo_primitive.py or demo.py.
Browse to 127.0.0.1:5000 in Firefox, with the FireBug extension turned on, and the Logger pane visible. This is the FireBug icon:
When FireBug is operational, it’s displayed in color, not grayed out. If you browse to the page before FireBug is turned on, you’ll need to reload the page to see the logged messages.
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size fireflask-0.2.0-py2.py3-none-any.whl (6.0 kB)||File type Wheel||Python version 2.7||Upload date||Hashes View hashes|
|Filename, size fireflask-0.2.0.tar.gz (3.6 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
|Filename, size fireflask-0.2.0.zip (8.7 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
Hashes for fireflask-0.2.0-py2.py3-none-any.whl