package api import ( "net/http" "github.com/gin-gonic/gin" "github.com/go-gost/x/config" parser "github.com/go-gost/x/config/parsing/limiter" "github.com/go-gost/x/registry" ) // swagger:parameters createRateLimiterRequest type createRateLimiterRequest struct { // in: body Data config.LimiterConfig `json:"data"` } // successful operation. // swagger:response createRateLimiterResponse type createRateLimiterResponse struct { Data Response } func createRateLimiter(ctx *gin.Context) { // swagger:route POST /config/rlimiters Limiter createRateLimiterRequest // // Create a new rate limiter, the name of limiter must be unique in limiter list. // // Security: // basicAuth: [] // // Responses: // 200: createRateLimiterResponse var req createRateLimiterRequest ctx.ShouldBindJSON(&req.Data) if req.Data.Name == "" { writeError(ctx, ErrInvalid) return } v := parser.ParseRateLimiter(&req.Data) if err := registry.RateLimiterRegistry().Register(req.Data.Name, v); err != nil { writeError(ctx, ErrDup) return } config.OnUpdate(func(c *config.Config) error { c.RLimiters = append(c.RLimiters, &req.Data) return nil }) ctx.JSON(http.StatusOK, Response{ Msg: "OK", }) } // swagger:parameters updateRateLimiterRequest type updateRateLimiterRequest struct { // in: path // required: true Limiter string `uri:"limiter" json:"limiter"` // in: body Data config.LimiterConfig `json:"data"` } // successful operation. // swagger:response updateRateLimiterResponse type updateRateLimiterResponse struct { Data Response } func updateRateLimiter(ctx *gin.Context) { // swagger:route PUT /config/rlimiters/{limiter} Limiter updateRateLimiterRequest // // Update rate limiter by name, the limiter must already exist. // // Security: // basicAuth: [] // // Responses: // 200: updateRateLimiterResponse var req updateRateLimiterRequest ctx.ShouldBindUri(&req) ctx.ShouldBindJSON(&req.Data) if !registry.RateLimiterRegistry().IsRegistered(req.Limiter) { writeError(ctx, ErrNotFound) return } req.Data.Name = req.Limiter v := parser.ParseRateLimiter(&req.Data) registry.RateLimiterRegistry().Unregister(req.Limiter) if err := registry.RateLimiterRegistry().Register(req.Limiter, v); err != nil { writeError(ctx, ErrDup) return } config.OnUpdate(func(c *config.Config) error { for i := range c.RLimiters { if c.RLimiters[i].Name == req.Limiter { c.RLimiters[i] = &req.Data break } } return nil }) ctx.JSON(http.StatusOK, Response{ Msg: "OK", }) } // swagger:parameters deleteRateLimiterRequest type deleteRateLimiterRequest struct { // in: path // required: true Limiter string `uri:"limiter" json:"limiter"` } // successful operation. // swagger:response deleteRateLimiterResponse type deleteRateLimiterResponse struct { Data Response } func deleteRateLimiter(ctx *gin.Context) { // swagger:route DELETE /config/rlimiters/{limiter} Limiter deleteRateLimiterRequest // // Delete rate limiter by name. // // Security: // basicAuth: [] // // Responses: // 200: deleteRateLimiterResponse var req deleteRateLimiterRequest ctx.ShouldBindUri(&req) if !registry.RateLimiterRegistry().IsRegistered(req.Limiter) { writeError(ctx, ErrNotFound) return } registry.RateLimiterRegistry().Unregister(req.Limiter) config.OnUpdate(func(c *config.Config) error { limiteres := c.RLimiters c.RLimiters = nil for _, s := range limiteres { if s.Name == req.Limiter { continue } c.RLimiters = append(c.RLimiters, s) } return nil }) ctx.JSON(http.StatusOK, Response{ Msg: "OK", }) }