chain

package
v0.13.8 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 22, 2022 License: MIT Imports: 1 Imported by: 0

Documentation

Overview

Package chain provides a convenient way to chain HTTP middleware functions and the app handler.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Chain

type Chain []Middleware

Chain acts as a list of http.Handler middleware. Chain is effectively immutable: once created, it will always hold the same set of middleware in the same order.

func New

func New(mw ...Middleware) Chain

New creates a new chain, memorizing the given list of middleware. New serves no other function, middleware is only constructed upon a call to Then().

func (Chain) Append

func (c Chain) Append(mw ...Middleware) Chain

Append extends a chain, adding the specified middleware as the last ones in the request flow.

chain := chain.New(m1, m2)
chain = chain.Append(m3, m4)
// requests in chain go m1 -> m2 -> m3 -> m4

func (Chain) Then

func (c Chain) Then(handler http.Handler) http.Handler

Then chains the middleware and returns the final http.Handler.

chain.New(m1, m2, m3).Then(h)

is equivalent to:

m1(m2(m3(h)))

When the request comes in, it will be passed to m1, then m2, then m3 and finally, the given handler (assuming every middleware calls the following one).

A chain can be safely reused by calling Then() several times.

chain := chain.New(rateLimitHandler, csrfHandler)
indexPipe = chain.Then(indexHandler)
authPipe  = chain.Then(authHandler)

Note that middleware pieces are called on every call to Then() and thus several instances of the same middleware will be created when a chain is reused in this previous example. For proper middleware, this should cause no problems.

Then() treats nil as http.DefaultServeMux.

func (Chain) ThenFunc

func (c Chain) ThenFunc(fn http.HandlerFunc) http.Handler

ThenFunc works identically to Then, but takes a HandlerFunc instead of a Handler.

The following two statements are equivalent:

c.Then(http.HandlerFunc(fn))
c.ThenFunc(fn)

ThenFunc provides all the guarantees of Then.

type Middleware

type Middleware func(http.Handler) http.Handler

Middleware is a constructor function returning a http.Handler.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL