From 3daa4802612ccbb51f0b536430c607d2ea0cfb06 Mon Sep 17 00:00:00 2001 From: Surbhi <98279679+Surbhi-sharma1@users.noreply.github.com> Date: Fri, 14 Jul 2023 11:41:58 +0530 Subject: [PATCH] docs(chore): add skip handler example (#121) for obf subpaths GH-120 --- README.md | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index b518d04..6a8ca89 100644 --- a/README.md +++ b/README.md @@ -174,7 +174,7 @@ async resetPassword( } ``` -- You can also disable rate limiting for specific API methods using the decorator like below. +- You can also disable rate limiting for specific API methods using the decorator like below or use the [skip handler](#skip-handler) ```ts @ratelimit(false) @@ -213,14 +213,33 @@ this.bind(RateLimitSecurityBindings.RATELIMITCONFIG).to({ RatelimitActionMiddleware: true, }); - this.component(RateLimiterComponent); - ``` This binding needs to be done before adding the RateLimiter component to your application. Apart from this all other steps will remain the same. +## Skip Handler + +By default all the paths are rate limited based on the configuration provided, but can be skipped using the skip handler. + +Following is the example of an handler that returns true if the path starts with `/obf/` such as `/obf/css/style.css`, `/obf/fonts`, `/obf/stats` etc. + +```diff +const obfPath = process.env.OBF_PATH ?? '/obf'; + +this.bind(RateLimitSecurityBindings.CONFIG).to({ + name: RedisDataSource.dataSourceName, + type: 'RedisStore', ++ skip: (request, response) => { ++ const isOBFSubpath = Boolean( ++ request.path.match(new RegExp(`^/$+{obfPath.replace(/^\//, '')}/.+`)), ++ ); ++ return !!isOBFSubpath; + }, +}); +``` + ## Feedback If you've noticed a bug or have a question or have a feature request, [search the issue tracker](https://github.com/sourcefuse/loopback4-ratelimiter/issues) to see if someone else in the community has already created a ticket.