/* Package cache provides server-side caching capabilities with rich support of options and rules. Use it for server-side caching, see the `iris#Cache304` for an alternative approach that may fit your needs most. Example code: import ( "time" "github.com/kataras/iris/v12" "github.com/kataras/iris/v12/cache" ) func main(){ app := iris.Default() middleware := cache.Handler(2 *time.Minute) app.Get("/hello", middleware, h) app.Listen(":8080") } func h(ctx iris.Context) { ctx.HTML("

Hello, this should be cached. Every 2 minutes it will be refreshed, check your browser's inspector

") } */ package cache import ( "time" "github.com/kataras/iris/v12/cache/client" "github.com/kataras/iris/v12/context" ) // WithKey sets a custom entry key for cached pages. // Should be prepended to the cache handler. // // Usage: // app.Get("/", cache.WithKey("custom-key"), cache.Handler(time.Minute), mainHandler) func WithKey(key string) context.Handler { return func(ctx *context.Context) { client.SetKey(ctx, key) ctx.Next() } } // Cache accepts the cache expiration duration. // If the "expiration" input argument is invalid, <=2 seconds, // then expiration is taken by the "cache-control's maxage" header. // Returns a Handler structure which you can use to customize cache further. // // All types of response can be cached, templates, json, text, anything. // // Use it for server-side caching, see the `iris#Cache304` for an alternative approach that // may be more suited to your needs. // // You can add validators with this function. func Cache(expiration time.Duration) *client.Handler { return client.NewHandler(expiration) } // Handler like `Cache` but returns an Iris Handler to be used as a middleware. // For more options use the `Cache`. // // Examples can be found at: https://github.com/kataras/iris/tree/master/_examples/response-writer/cache func Handler(expiration time.Duration) context.Handler { h := Cache(expiration).ServeHTTP return h }