Handling basic configurations
One of the beauties of Flask is that it is very easy to configure a Flask application according to the needs of the project. In this recipe, we will try to understand the different ways in which a Flask application can be configured, including how to load a configuration from environment variables, Python files, or even a config
object.
Getting ready
In Flask, configuration variables are stored on a dictionary-like attribute named config
of the Flask
object. The config
attribute is a subclass of the Python dictionary, and we can modify it just like any dictionary.
How to do it...
To run our application in debug mode, for instance, we can write the following:
app = Flask(__name__) app.config['DEBUG'] = True
Tip
The debug
Boolean can also be set at the Flask object
level rather than at the config
level, as follows:
app.debug =
True
Alternatively, we can pass debug
as a named argument to app.run
, as follows:
app.run(debug=True)
In new versions of Flask, the debug mode can also be set on an environment variable, FLASK_DEBUG=1
. Then, we can run the app using flask run
or Python’s -
m
switch:
$
export FLASK_DEBUG=1
Enabling debug mode will make the server reload itself in the event of any code changes, and it also provides the very helpful Werkzeug debugger when something goes wrong.
There are a bunch of configuration values provided by Flask. We will come across them in relevant recipes throughout this chapter.
As an application becomes larger, there is a need to manage the application’s configuration in a separate file, as shown in the following example. In most operating systems and development environments that you use, it is unlikely that this file will be a part of the version control system. Thus, Flask provides us with multiple ways to fetch configurations. The most frequently used methods are as follows:
- From a Python configuration file (
*.cfg
), where the configuration can be fetched using the following statement:app.config.from_pyfile('myconfig.cfg')
- From an object, where the configuration can be fetched using the following statement:
app.config.from_object('myapplication.default_settings')
- Alternatively, to load from the same file from which this command is run, we can use the following statement:
app.config.from_object(__name__)
- From an environment variable, the configuration can be fetched using the following statement:
app.config.from_envvar('PATH_TO_CONFIG_FILE')
- New in Flask version 2.0 is a capability to load from generic configuration file formats such as JSON or TOML:
app.config.from_file('config.json', load=json.load)
Alternatively, we can do the following: app.config.from_file('config.toml', load=toml.load)
How it works...
Flask is designed to only pick up configuration variables that are written in uppercase. This allows us to define any local variables in our configuration files and objects and leave the rest to Flask.
The best practice when using configurations is to have a bunch of default settings in app.py
, or via any object in the application itself, and then override the same by loading it from the configuration file. So, the code will look as follows:
app = Flask(__name__) DEBUG = True TESTING = True app.config.from_object(__name__) app.config.from_pyfile('/path/to/config/file')