stn/rate-limiting-bundle
Composer 安装命令:
composer require stn/rate-limiting-bundle
包简介
The bundle for managing request rate limiting
README 文档
README
This bundle(require Predis) adds support for request rate limiting management in Symfony.
Installation
Download StnRateLimitingBundle bundle using Composer
$ composer require stn/rate-limiting-bundle
Register StnRateLimitingBundle
<?php // app/AppKernel.php // ... public function registerBundles() { $bundles = array( // Other bundles ... new Stn\RateLimitingBundle\StnRateLimitingBundle(), ); } // ...
Configuration
# app/config/config.yml
stn_rate_limiting:
enable: true # Whether rate limiting is available or not
limit: 60 # Limit of request
ttl: 60 # Cache expiry time, second as unit (Time to live)
key_prefix: ~ # The cache key prefix, defaults to 'RL'
key_length: ~ # The cache key length, defaults to 8
client: # Configuration for Predis
dsn: ~ # DSN for connection, defaults to 'tcp://127.0.0.1:6379'
pass: ~ # Redis requirepass configuration, will invoke `auth` to setup connection if provided, defaults to null
Usage
Use annotation @RateLimiting to rate limit request, and you can setup rate limit by manual the following two parameters or use default configuration:
limitttl
// any controller use Symfony\Bundle\FrameworkBundle\Controller\Controller; use Stn\RateLimitingBundle\Annotation\RateLimiting; /** * Mark with annotation `RateLimiting` to enable rate limiting. * * @RateLimiting(limit=10, ttl=60) */ class DefaultController extends Controller { /** * Annotation in controller's action has a higher priority than controller itself. * * @RateLimiting(limit=2, ttl=10) */ public function indexAction() { // Do something... } }
TODO
- Add forbidden response template
- Make redis configuration more flexible
- More tests
License
MIT
统计信息
- 总下载量: 71
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-10-07