Documentation ¶
Overview ¶
Package ratelimiter implements the Leaky Bucket ratelimiting algorithm with memcached and in-memory backends.
Index ¶
Constants ¶
View Source
const GC_SIZE int = 100
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type LeakyBucket ¶
type LeakyBucket struct { Size uint16 Fill float64 LeakInterval time.Duration // time.Duration for 1 unit of size to leak Lastupdate time.Time Now func() time.Time }
func NewLeakyBucket ¶
func NewLeakyBucket(size uint16, leakInterval time.Duration) *LeakyBucket
func (*LeakyBucket) DrainedAt ¶
func (b *LeakyBucket) DrainedAt() time.Time
The time at which this bucket will be completely drained
func (*LeakyBucket) Pour ¶
func (b *LeakyBucket) Pour(amount uint16) bool
func (*LeakyBucket) Serialise ¶
func (b *LeakyBucket) Serialise() *LeakyBucketSer
func (*LeakyBucket) TimeSinceLastUpdate ¶
func (b *LeakyBucket) TimeSinceLastUpdate() time.Duration
func (*LeakyBucket) TimeToDrain ¶
func (b *LeakyBucket) TimeToDrain() time.Duration
The duration until this bucket is completely drained
type LeakyBucketSer ¶
type LeakyBucketSer struct { Size uint16 Fill float64 LeakInterval time.Duration // time.Duration for 1 unit of size to leak Lastupdate time.Time }
func (*LeakyBucketSer) DeSerialise ¶
func (b *LeakyBucketSer) DeSerialise() *LeakyBucket
type Memory ¶
type Memory struct {
// contains filtered or unexported fields
}
func (*Memory) GarbageCollect ¶
func (m *Memory) GarbageCollect()
func (*Memory) GetBucketFor ¶
func (m *Memory) GetBucketFor(key string) (*LeakyBucket, error)
func (*Memory) SetBucketFor ¶
func (m *Memory) SetBucketFor(key string, bucket LeakyBucket) error
type Storage ¶
type Storage interface { GetBucketFor(string) (*LeakyBucket, error) SetBucketFor(string, LeakyBucket) error }
Click to show internal directories.
Click to hide internal directories.