|
|
@@ -1,31 +1,16 @@
|
|
1
|
1
|
package antireplay
|
|
2
|
2
|
|
|
3
|
|
-import (
|
|
4
|
|
- "github.com/allegro/bigcache"
|
|
|
3
|
+import "github.com/allegro/bigcache"
|
|
5
|
4
|
|
|
6
|
|
- "github.com/9seconds/mtg/config"
|
|
7
|
|
-)
|
|
8
|
|
-
|
|
9
|
|
-var cache *bigcache.BigCache
|
|
10
|
|
-
|
|
11
|
|
-func Add(data []byte) {
|
|
12
|
|
- cache.Set(string(data), nil) // nolint: errcheck
|
|
|
5
|
+type cache struct {
|
|
|
6
|
+ cache *bigcache.BigCache
|
|
13
|
7
|
}
|
|
14
|
8
|
|
|
15
|
|
-func Has(data []byte) bool {
|
|
16
|
|
- _, err := cache.Get(string(data))
|
|
17
|
|
- return err == nil
|
|
|
9
|
+func (c *cache) Add(data []byte) {
|
|
|
10
|
+ c.cache.Set(string(data), nil) // nolint: errcheck
|
|
18
|
11
|
}
|
|
19
|
12
|
|
|
20
|
|
-func Init() {
|
|
21
|
|
- c, err := bigcache.NewBigCache(bigcache.Config{
|
|
22
|
|
- Shards: 1024,
|
|
23
|
|
- LifeWindow: config.C.AntiReplay.EvictionTime,
|
|
24
|
|
- Hasher: hasher{},
|
|
25
|
|
- HardMaxCacheSize: config.C.AntiReplay.MaxSize,
|
|
26
|
|
- })
|
|
27
|
|
- if err != nil {
|
|
28
|
|
- panic(err)
|
|
29
|
|
- }
|
|
30
|
|
- cache = c
|
|
|
13
|
+func (c *cache) Has(data []byte) bool {
|
|
|
14
|
+ _, err := c.cache.Get(string(data))
|
|
|
15
|
+ return err == nil
|
|
31
|
16
|
}
|