Skip to main content

Static analysis checks for Flask, by r2c. Available in our free program analysis tool, Bento. (ht

Project description

flake8-flask

flake8-flask is a plugin for flake8 with checks specifically for the flask framework, written by r2c

Installation

pip install flake8-flask

Validate the install using --version.

> flake8 --version
3.7.9 (flake8-flask: 0.2.1, mccabe: 0.6.1, pycodestyle: 2.5.0, pyflakes: 2.1.1)

List of warnings

r2c-flask-send-file-open: This check detects the use of a file-like object in flask.send_file without either mimetype or attachment_filename keyword arguments. send_file will throw a ValueError in this situation.

r2c-flask-secure-set-cookie: This check detects calls to response.set_cookie that do not have secure, httponly, and samesite set. This follows the guidance in the Flask documentation.

r2c-flask-unescaped-file-extension: Flask will not autoescape Jinja templates that do not have .html, .htm, .xml, or .xhtml as extensions. This check will alert you if you do not have one of these extensions. This check will also do its best to detect if context variables are escaped if a non-escaped extension is used.

r2c-flask-use-blueprint-for-modularity: This check recommends using Blueprint when there are too many route handlers in a single file. Blueprint encourages modularity and can greatly simplify how large applications work and provide a central means for Flask extensions to register operations on applications.

r2c-flask-use-jsonify: flask.jsonify() is a Flask helper method which handles the correct settings for returning JSON from Flask routes. This check catches uses of json.dumps() returned from Flask routes and encourages flask.jsonify() instead.

r2c-flask-missing-jwt-token: This check alerts when @jwt_required, @jwt_optional, @fresh_jwt_required, and @jwt_refresh_token_required decorators are missing in files where flask_jwt, flask_jwt_extended, or flask_jwt_simple packages are imported.

Have an idea for a check? Reach out to us at https://r2c.dev!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flake8-flask-0.10.0b2.tar.gz (13.4 kB view details)

Uploaded Source

Built Distribution

flake8_flask-0.10.0b2-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file flake8-flask-0.10.0b2.tar.gz.

File metadata

  • Download URL: flake8-flask-0.10.0b2.tar.gz
  • Upload date:
  • Size: 13.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/0.12.17 CPython/3.7.5 Darwin/19.2.0

File hashes

Hashes for flake8-flask-0.10.0b2.tar.gz
Algorithm Hash digest
SHA256 0cd44fbbbc3d5b0844a5cb9cb917c90efdc0eee6b387ebc85c6bd4f21b754ef9
MD5 c97f751b5fbf6ab61ae65f007e9b5965
BLAKE2b-256 39249912e3e97a0f0725080f4a0ddaeb256221a55f3688d579ba6b5d5639f473

See more details on using hashes here.

File details

Details for the file flake8_flask-0.10.0b2-py3-none-any.whl.

File metadata

  • Download URL: flake8_flask-0.10.0b2-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/0.12.17 CPython/3.7.5 Darwin/19.2.0

File hashes

Hashes for flake8_flask-0.10.0b2-py3-none-any.whl
Algorithm Hash digest
SHA256 c096912ff795e2a429a7e7fef1cd6ef550c660deb8653a9a0464bfa1e77c4cdc
MD5 1abbc7d32a96f0d7ff33b00c3f7895c0
BLAKE2b-256 505f417937894de3f6dbdc914837ce657e011c2062067e22e93d47a4fe13c29a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page