From 5e925add97cdc8081c76bb3680236efecfb1453f Mon Sep 17 00:00:00 2001 From: Saif Aljanahi <31359390+1saifj@users.noreply.github.com> Date: Tue, 13 Jun 2023 17:01:52 +0300 Subject: [PATCH] Added example how to use ulule-limiter with Iris web framework (#2152) * Added example how to use ulule-limiter with Iris web framework * format main.go Signed-off-by: Gerasimos (Makis) Maropoulos --------- Signed-off-by: Gerasimos (Makis) Maropoulos Co-authored-by: Gerasimos (Makis) Maropoulos --- .../{ => rate-middleware}/main.go | 0 .../request-ratelimit/ulule-limiter/main.go | 68 +++++++++++++++++++ 2 files changed, 68 insertions(+) rename _examples/request-ratelimit/{ => rate-middleware}/main.go (100%) create mode 100644 _examples/request-ratelimit/ulule-limiter/main.go diff --git a/_examples/request-ratelimit/main.go b/_examples/request-ratelimit/rate-middleware/main.go similarity index 100% rename from _examples/request-ratelimit/main.go rename to _examples/request-ratelimit/rate-middleware/main.go diff --git a/_examples/request-ratelimit/ulule-limiter/main.go b/_examples/request-ratelimit/ulule-limiter/main.go new file mode 100644 index 00000000..661c84b8 --- /dev/null +++ b/_examples/request-ratelimit/ulule-limiter/main.go @@ -0,0 +1,68 @@ +package main + +import ( + "log" + "net/http" + "strconv" + "time" + + "github.com/kataras/iris/v12" + + "github.com/ulule/limiter/v3" + "github.com/ulule/limiter/v3/drivers/store/memory" +) + +func main() { + app := iris.New() + app.Get("/hello", IPRateLimit(), helloWorldHandler) // 3. Use middleware + app.Run(iris.Addr(":8080")) +} + +func helloWorldHandler(ctx iris.Context) { + err := ctx.StopWithJSON(iris.StatusOK, iris.Map{ + "message": "Hello World!", + }) + if err != nil { + return + } +} + +func IPRateLimit() iris.Handler { + // 1. Configure + rate := limiter.Rate{ + Period: 2 * time.Second, + Limit: 1, + } + store := memory.NewStore() + ipRateLimiter := limiter.New(store, rate) + + // 2. Return middleware handler + return func(ctx iris.Context) { + ip := ctx.RemoteAddr() + limiterCtx, err := ipRateLimiter.Get(ctx.Request().Context(), ip) + if err != nil { + log.Printf("IPRateLimit - ipRateLimiter.Get - err: %v, %s on %s", err, ip, ctx.Request().URL) + ctx.StatusCode(http.StatusInternalServerError) + ctx.JSON(iris.Map{ + "success": false, + "message": err, + }) + return + } + + ctx.Header("X-RateLimit-Limit", strconv.FormatInt(limiterCtx.Limit, 10)) + ctx.Header("X-RateLimit-Remaining", strconv.FormatInt(limiterCtx.Remaining, 10)) + ctx.Header("X-RateLimit-Reset", strconv.FormatInt(limiterCtx.Reset, 10)) + + if limiterCtx.Reached { + log.Printf("Too Many Requests from %s on %s", ip, ctx.Request().URL) + ctx.StatusCode(http.StatusTooManyRequests) + ctx.JSON(iris.Map{ + "success": false, + "message": "Too Many Requests on " + ctx.Request().URL.String(), + }) + return + } + ctx.Next() + } +}