forked from grpc-ecosystem/go-grpc-middleware
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexamples_test.go
46 lines (40 loc) · 1.33 KB
/
examples_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// Copyright (c) The go-grpc-middleware Authors.
// Licensed under the Apache License 2.0.
package ratelimit_test
import (
"context"
"github.com/grpc-ecosystem/go-grpc-middleware/v2/interceptors/ratelimit"
"google.golang.org/grpc"
)
// alwaysPassLimiter is an example limiter which implements Limiter interface.
// It does not limit any request because Limit function always returns false.
type alwaysPassLimiter struct{}
func (*alwaysPassLimiter) Limit(_ context.Context) error {
// Example rate limiter could be implemented using e.g. github.com/juju/ratelimit
// // Take one token per request. This call doesn't block.
// tokenRes := l.tokenBucket.TakeAvailable(1)
//
// // When rate limit reached, return specific error for the clients.
// if tokenRes == 0 {
// return fmt.Errorf("APP-XXX: reached Rate-Limiting %d", l.tokenBucket.Available())
// }
//
// // Rate limit isn't reached.
// return nil
//}
return nil
}
// Simple example of server initialization code.
func Example() {
// Create unary/stream rateLimiters, based on token bucket here.
// You can implement your own ratelimiter for the interface.
limiter := &alwaysPassLimiter{}
_ = grpc.NewServer(
grpc.ChainUnaryInterceptor(
ratelimit.UnaryServerInterceptor(limiter),
),
grpc.ChainStreamInterceptor(
ratelimit.StreamServerInterceptor(limiter),
),
)
}