Flask-Limiter (1.5)
Installation
pip install --index-url Flask-LimiterAbout this package
Rate limiting for flask applications
.. |ci| image:: https://github.com/alisaifee/flask-limiter/workflows/CI/badge.svg?branch=master :target: https://github.com/alisaifee/flask-limiter/actions?query=branch%3Amaster+workflow%3ACI .. |codecov| image:: https://codecov.io/gh/alisaifee/flask-limiter/branch/master/graph/badge.svg :target: https://codecov.io/gh/alisaifee/flask-limiter .. |pypi| image:: https://img.shields.io/pypi/v/Flask-Limiter.svg?style=flat-square :target: https://pypi.python.org/pypi/Flask-Limiter .. |license| image:: https://img.shields.io/pypi/l/Flask-Limiter.svg?style=flat-square :target: https://pypi.python.org/pypi/Flask-Limiter .. |docs| image:: https://readthedocs.org/projects/flask-limiter/badge :target: https://flask-limiter.readthedocs.org
Flask-Limiter
|docs| |ci| |codecov| |pypi| |license|
Flask-Limiter provides rate limiting features to flask routes. It has support for a configurable backend for storage with current implementations for in-memory, redis and memcache.
Quickstart
Add the rate limiter to your flask app. The following example uses the default in memory implementation for storage.
.. code-block:: python
from flask import Flask from flask_limiter import Limiter from flask_limiter.util import get_remote_address
app = Flask(name) limiter = Limiter( app, key_func=get_remote_address, default_limits=["2 per minute", "1 per second"], )
@app.route("/slow") @limiter.limit("1 per day") def slow(): return "24"
@app.route("/fast") def fast(): return "42"
@app.route("/ping") @limiter.exempt def ping(): return 'PONG'
app.run()
Test it out. The fast endpoint respects the default rate limit while the
slow endpoint uses the decorated one. ping has no rate limit associated
with it.
.. code-block:: bash
$ curl localhost:5000/fast
42
$ curl localhost:5000/fast
42
$ curl localhost:5000/fast
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<title>429 Too Many Requests</title>
<h1>Too Many Requests</h1>
<p>2 per 1 minute</p>
$ curl localhost:5000/slow
24
$ curl localhost:5000/slow
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<title>429 Too Many Requests</title>
<h1>Too Many Requests</h1>
<p>1 per 1 day</p>
$ curl localhost:5000/ping
PONG
$ curl localhost:5000/ping
PONG
$ curl localhost:5000/ping
PONG
$ curl localhost:5000/ping
PONG
Read the docs <http://flask-limiter.readthedocs.org>_
.. :changelog:
Changelog
v1.5
Release Date: 2021-11-27
Final Release for python < 3.7
-
Features
- Prepend
key_prefixto extension variables attached tog - Expose
g.view_limits
- Prepend
v1.4
Release Date: 2020-08-25
-
Bug Fix
- Always set headers for conditional limits
- Skip init_app sequence when the rate limiter is disabled
v1.3.1
Release Date: 2020-05-21
-
Bug Fix
- Ensure headers provided explictely by setting
_header_mappingtake precedence over configuration values.
- Ensure headers provided explictely by setting
v1.3
Release Date: 2020-05-20
-
Features
- Add new
deduct_whenargument that accepts a function to decorated limits to conditionally perform depletion of a rate limit (Pull Request 248 <https://github.com/alisaifee/flask-limiter/pull/248>_) - Add new
default_limits_deduct_whenargument to Limiter constructor to conditionally perform depletion of default rate limits - Add
default_limits_exempt_whenargument that accepts a function to allow skipping the default limits in thebefore_requestphase
- Add new
-
Bug Fix
- Fix handling of storage failures during
after_requestphase.
- Fix handling of storage failures during
-
Code Quality
- Use github-actions instead of travis for CI
- Use pytest instaad of nosetests
- Add docker configuration for test dependencies
- Increase code coverage to 100%
- Ensure pyflake8 compliance
v1.2.1
Release Date: 2020-02-26
-
Bug fix
- Syntax error in version 1.2.0 when application limits are provided through
configuration file (
Issue 241 <https://github.com/alisaifee/flask-limiter/issues/241>_)
- Syntax error in version 1.2.0 when application limits are provided through
configuration file (
v1.2.0
Release Date: 2020-02-25
-
Add
override_defaultsargument to decorated limits to allow combinined defaults with decorated limits. -
Add configuration parameter RATELIMIT_DEFAULTS_PER_METHOD to control whether defaults are applied per method.
-
Add support for in memory fallback without override (
Pull Request 236 <https://github.com/alisaifee/flask-limiter/pull/236>_) -
Bug fix
- Ensure defaults are enforced when decorated limits are skipped (
Issue 238 <https://github.com/alisaifee/flask-limiter/issues/238>_)
- Ensure defaults are enforced when decorated limits are skipped (
v1.1.0
Release Date: 2019-10-02
- Provide Rate limit information with Exception (
Pull Request 202 <https://github.com/alisaifee/flask-limiter/pull/202>_) - Respect existing Retry-After header values (
Pull Request 143 <https://github.com/alisaifee/flask-limiter/pull/143>_) - Documentation improvements
v1.0.1
Release Date: 2017-12-08
-
Bug fix
- Duplicate rate limits applied via application limits (
Issue 108 <https://github.com/alisaifee/flask-limiter/issues/108>_)
- Duplicate rate limits applied via application limits (
v1.0.0
Release Date: 2017-11-06
-
Improved documentation for handling ip addresses for applications behind proxiues (
Issue 41 <https://github.com/alisaifee/flask-limiter/issues/41>_) -
Execute rate limits for decorated routes in decorator instead of
before_request(Issue 67 <https://github.com/alisaifee/flask-limiter/issues/67>_) -
Bug Fix
- Python 3.5 Errors (
Issue 82 <https://github.com/alisaifee/flask-limiter/issues/82>_) - RATELIMIT_KEY_PREFIX configuration constant not used (
Issue 88 <https://github.com/alisaifee/flask-limiter/issues/88>_) - Can't use dynamic limit in
default_limits(Issue 94 <https://github.com/alisaifee/flask-limiter/issues/94>_) - Retry-After header always zero when using key prefix (
Issue 99 <https://github.com/alisaifee/flask-limiter/issues/99>_)
- Python 3.5 Errors (
v0.9.5.1
Release Date: 2017-08-18
- Upgrade versioneer
v0.9.5
Release Date: 2017-07-26
- Add support for key prefixes
v0.9.4
Release Date: 2017-05-01
- Implemented application wide shared limits
v0.9.3
Release Date: 2016-03-14
- Allow
resetof limiter storage if available
v0.9.2
Release Date: 2016-03-04
- Deprecation warning for default
key_funcget_ipaddr - Support for
Retry-Afterheader
v0.9.1
Release Date: 2015-11-21
- Re-expose
enabledproperty onLimiterinstance.
v0.9
Release Date: 2015-11-13
- In-memory fallback option for unresponsive storage
- Rate limit exemption option per limit
v0.8.5
Release Date: 2015-10-05
- Bug fix for reported issues of missing (limits) dependency upon installation.
v0.8.4
Release Date: 2015-10-03
- Documentation tweaks.
v0.8.2
Release Date: 2015-09-17
- Remove outdated files from egg
v0.8.1
Release Date: 2015-08-06
- Fixed compatibility with latest version of Flask-Restful
v0.8
Release Date: 2015-06-07
- No functional change
v0.7.9
Release Date: 2015-04-02
- Bug fix for case sensitive
methodswhitelist forlimitsdecorator
v0.7.8
Release Date: 2015-03-20
- Hotfix for dynamic limits with blueprints
- Undocumented feature to pass storage options to underlying storage backend.
v0.7.6
Release Date: 2015-03-02
methodskeyword argument forlimitsdecorator to specify specific http methods to apply the rate limit to.
v0.7.5
Release Date: 2015-02-16
Custom error messages <http://flask-limiter.readthedocs.org/en/stable/#custom-error-messages>_.
v0.7.4
Release Date: 2015-02-03
- Use Werkzeug TooManyRequests as the exception raised when available.
v0.7.3
Release Date: 2015-01-30
-
Bug Fix
- Fix for version comparison when monkey patching Werkzeug
(
Issue 24 <https://github.com/alisaifee/flask-limiter/issues/24>_)
- Fix for version comparison when monkey patching Werkzeug
(
v0.7.1
Release Date: 2015-01-09
- Refactor core storage & ratelimiting strategy out into the
limits <http://github.com/alisaifee/limits>_ package. - Remove duplicate hits when stacked rate limits are in use and a rate limit is hit.
v0.7
Release Date: 2015-01-09
- Refactoring of RedisStorage for extensibility (
Issue 18 <https://github.com/alisaifee/flask-limiter/issues/18>_) - Bug fix: Correct default setting for enabling rate limit headers. (
Issue 22 <https://github.com/alisaifee/flask-limiter/issues/22>_)
v0.6.6
Release Date: 2014-10-21
-
Bug fix
- Fix for responses slower than rate limiting window.
(
Issue 17 <https://github.com/alisaifee/flask-limiter/issues/17>_.)
- Fix for responses slower than rate limiting window.
(
v0.6.5
Release Date: 2014-10-01
- Bug fix: in memory storage thread safety
v0.6.4
Release Date: 2014-08-31
- Support for manually triggering rate limit check
v0.6.3
Release Date: 2014-08-26
- Header name overrides
v0.6.2
Release Date: 2014-07-13
Rate limiting for blueprints <http://flask-limiter.readthedocs.org/en/latest/#rate-limiting-all-routes-in-a-flask-blueprint>_
v0.6.1
Release Date: 2014-07-11
- per http method rate limit separation (
Recipe <http://flask-limiter.readthedocs.org/en/latest/index.html#using-flask-pluggable-views>_) - documentation improvements
v0.6
Release Date: 2014-06-24
Shared limits between routes <http://flask-limiter.readthedocs.org/en/latest/index.html#ratelimit-decorator-shared-limit>_
v0.5
Release Date: 2014-06-13
Request Filters <http://flask-limiter.readthedocs.org/en/latest/index.html#ratelimit-decorator-request-filter>_
v0.4.4
Release Date: 2014-06-13
-
Bug fix
- Werkzeug < 0.9 Compatibility
(
Issue 6 <https://github.com/alisaifee/flask-limiter/issues/6>_.)
- Werkzeug < 0.9 Compatibility
(
v0.4.3
Release Date: 2014-06-12
- Hotfix : use HTTPException instead of abort to play well with other extensions.
v0.4.2
Release Date: 2014-06-12
- Allow configuration overrides via extension constructor
v0.4.1
Release Date: 2014-06-04
- Improved implementation of moving-window X-RateLimit-Reset value.
v0.4
Release Date: 2014-05-28
Rate limiting headers <http://flask-limiter.readthedocs.org/en/latest/#rate-limiting-headers>_
v0.3.2
Release Date: 2014-05-26
-
Bug fix
- Memory leak when using
Limiter.storage.MemoryStorage(Issue 4 <https://github.com/alisaifee/flask-limiter/issues/4>_.)
- Memory leak when using
-
Improved test coverage
v0.3.1
Release Date: 2014-02-20
- Strict version requirement on six
- documentation tweaks
v0.3.0
Release Date: 2014-02-19
-
improved logging support for multiple handlers
-
allow callables to be passed to
Limiter.limitdecorator to dynamically load rate limit strings. -
add a global kill switch in flask config for all rate limits.
-
Bug fixes
- default key function for rate limit domain wasn't accounting for X-Forwarded-For header.
v0.2.2
Release Date: 2014-02-18
-
add new decorator to exempt routes from limiting.
-
Bug fixes
- versioneer.py wasn't included in manifest.
- configuration string for strategy was out of sync with docs.
v0.2.1
Release Date: 2014-02-15
- python 2.6 support via counter backport
- source docs.
v0.2
Release Date: 2014-02-15
-
Implemented configurable strategies for rate limiting.
-
Bug fixes
- better locking for in-memory storage
- multi threading support for memcached storage
v0.1.1
Release Date: 2014-02-14
-
Bug fixes
- fix initializing the extension without an app
- don't rate limit static files
v0.1.0
Release Date: 2014-02-13
- first release.