forked from pufferpanel/pufferpanel
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcache.go
86 lines (72 loc) · 1.85 KB
/
cache.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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
Copyright 2019 Padduck, LLC
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package pufferpanel
import (
"github.com/pufferpanel/pufferpanel/v2/config"
"sync"
"time"
)
type Cache interface {
Read() (cache []string, epoch int64)
ReadFrom(startTime int64) (cache []string, epoch int64)
Write(b []byte) (n int, err error)
}
type Message struct {
msg string
time int64
}
type MemoryCache struct {
Cache
Buffer []Message
Capacity int
Lock sync.Locker
}
func CreateCache() *MemoryCache {
capacity := config.ConsoleBuffer.Value()
if capacity <= 0 {
capacity = 50
}
return &MemoryCache{
Buffer: make([]Message, 0),
Capacity: capacity,
Lock: &sync.Mutex{},
}
}
func (c *MemoryCache) Read() (msg []string, lastTime int64) {
msg, lastTime = c.ReadFrom(0)
return
}
func (c *MemoryCache) ReadFrom(startTime int64) (msg []string, lastTime int64) {
result := make([]string, 0)
var endTime int64 = 0
for _, v := range c.Buffer {
if v.time > startTime {
result = append(result, v.msg)
endTime = v.time
}
}
if endTime == 0 {
endTime = time.Now().Unix()
}
return result, endTime
}
func (c *MemoryCache) Write(b []byte) (n int, err error) {
c.Lock.Lock()
defer c.Lock.Unlock()
if len(c.Buffer) == c.Capacity {
c.Buffer = c.Buffer[1:]
}
c.Buffer = append(c.Buffer, Message{msg: string(b), time: time.Now().Unix()})
n = len(b)
return
}