github.com/mvg-fi/go-limiter@v0.1.1/store.go (about)

     1  package limiter
     2  
     3  import (
     4  	"context"
     5  	"fmt"
     6  	"time"
     7  )
     8  
     9  // ErrStopped is the error returned when the store is stopped. All implementers
    10  // should return this error for stoppable stores.
    11  var ErrStopped = fmt.Errorf("store is stopped")
    12  
    13  // Store is an interface for limiter storage backends.
    14  //
    15  // Keys should be hash, sanitized, or otherwise scrubbed of identifiable
    16  // information they will be given to the store in plaintext. If you're rate
    17  // limiting by IP address, for example, the IP address would be stored in the
    18  // storage system in plaintext. This may be undesirable in certain situations,
    19  // like when the store is a public database. In those cases, you should hash or
    20  // HMAC the key before passing giving it to the store. If you want to encrypt
    21  // the value, you must use homomorphic encryption to ensure the value always
    22  // encrypts to the same ciphertext.
    23  type Store interface {
    24  	// Take takes a token from the given key if available, returning:
    25  	//
    26  	// - the configured limit size
    27  	// - the number of remaining tokens in the interval
    28  	// - the server time when new tokens will be available
    29  	// - whether the take was successful
    30  	// - any errors that occurred while performing the take - these should be
    31  	//   backend errors (e.g. connection failures); Take() should never return an
    32  	//   error for an bucket.
    33  	//
    34  	// If "ok" is false, the take was unsuccessful and the caller should NOT
    35  	// service the request.
    36  	//
    37  	// See the note about keys on the interface documentation.
    38  	Take(ctx context.Context, key string) (tokens, remaining, reset uint64, ok bool, err error)
    39  
    40  	// Get gets the current limit and remaining tokens for the provided key. It
    41  	// does not change any of the values.
    42  	Get(ctx context.Context, key string) (tokens, remaining uint64, err error)
    43  
    44  	// Set configures the limit at the provided key. If a limit already exists, it
    45  	// is overwritten. This also sets the number of tokens in the bucket to the
    46  	// limit.
    47  	Set(ctx context.Context, key string, tokens uint64, interval time.Duration) error
    48  
    49  	// Burst adds more tokens to the key's current bucket until the next interval
    50  	// tick. This will allow the current bucket tick to exceed the maximum number
    51  	// maximum ticks until the next interval.
    52  	Burst(ctx context.Context, key string, tokens uint64) error
    53  
    54  	// Close terminates the store and cleans up any data structures or connections
    55  	// that may remain open. After a store is stopped, Take() should always return
    56  	// zero values.
    57  	Close(ctx context.Context) error
    58  }