Files
umbrix-libcore/v2/logproto.go

45 lines
1.0 KiB
Go
Raw Normal View History

2024-03-10 19:45:03 +01:00
package v2
import (
"fmt"
2024-03-10 19:45:03 +01:00
"time"
2024-03-22 16:25:56 +00:00
pb "github.com/hiddify/hiddify-core/hiddifyrpc"
2024-03-10 19:45:03 +01:00
"github.com/sagernet/sing/common/observable"
"google.golang.org/grpc"
2024-03-10 19:45:03 +01:00
)
func NewObserver[T any](listenerBufferSize int) *observable.Observer[T] {
return observable.NewObserver(observable.NewSubscriber[T](listenerBufferSize), listenerBufferSize)
}
var logObserver = NewObserver[pb.LogMessage](10)
2024-03-10 19:45:03 +01:00
func Log(level pb.LogLevel, typ pb.LogType, message string) {
2024-03-18 20:38:09 +01:00
if level != pb.LogLevel_DEBUG {
fmt.Printf("%s %s %s\n", level, typ, message)
}
2024-03-10 19:45:03 +01:00
logObserver.Emit(pb.LogMessage{
Level: level,
Type: typ,
Message: message,
})
}
func (s *CoreService) LogListener(req *pb.Empty, stream grpc.ServerStreamingServer[pb.LogMessage]) error {
logSub, stopch, _ := logObserver.Subscribe()
2024-03-10 19:45:03 +01:00
defer logObserver.UnSubscribe(logSub)
for {
select {
case <-stream.Context().Done():
return nil
case <-stopch:
return nil
2024-03-10 19:45:03 +01:00
case info := <-logSub:
stream.Send(&info)
case <-time.After(500 * time.Millisecond):
}
}
}