mirror of
https://github.com/superseriousbusiness/gotosocial
synced 2024-12-27 13:13:10 +00:00
35 lines
1.4 KiB
Go
35 lines
1.4 KiB
Go
|
package limiter
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
// Store is the common interface for limiter stores.
|
||
|
type Store interface {
|
||
|
// Get returns the limit for given identifier.
|
||
|
Get(ctx context.Context, key string, rate Rate) (Context, error)
|
||
|
// Peek returns the limit for given identifier, without modification on current values.
|
||
|
Peek(ctx context.Context, key string, rate Rate) (Context, error)
|
||
|
// Reset resets the limit to zero for given identifier.
|
||
|
Reset(ctx context.Context, key string, rate Rate) (Context, error)
|
||
|
// Increment increments the limit by given count & gives back the new limit for given identifier
|
||
|
Increment(ctx context.Context, key string, count int64, rate Rate) (Context, error)
|
||
|
}
|
||
|
|
||
|
// StoreOptions are options for store.
|
||
|
type StoreOptions struct {
|
||
|
// Prefix is the prefix to use for the key.
|
||
|
Prefix string
|
||
|
|
||
|
// MaxRetry is the maximum number of retry under race conditions on redis store.
|
||
|
// Deprecated: this option is no longer required since all operations are atomic now.
|
||
|
MaxRetry int
|
||
|
|
||
|
// CleanUpInterval is the interval for cleanup (run garbage collection) on stale entries on memory store.
|
||
|
// Setting this to a low value will optimize memory consumption, but will likely
|
||
|
// reduce performance and increase lock contention.
|
||
|
// Setting this to a high value will maximum throughput, but will increase the memory footprint.
|
||
|
CleanUpInterval time.Duration
|
||
|
}
|