Files
umbrix-libcore/v2/coreinfo.go

58 lines
1.5 KiB
Go
Raw Normal View History

2024-03-10 19:45:03 +01:00
package v2
import (
"encoding/json"
2024-03-16 09:02:55 +01:00
"fmt"
2024-03-10 19:45:03 +01:00
2024-03-22 16:25:56 +00:00
"github.com/hiddify/hiddify-core/bridge"
pb "github.com/hiddify/hiddify-core/hiddifyrpc"
"google.golang.org/grpc"
2024-03-10 19:45:03 +01:00
)
var (
coreInfoObserver = *NewObserver[*pb.CoreInfoResponse](1)
CoreState = pb.CoreState_STOPPED
)
2024-03-10 19:45:03 +01:00
func SetCoreStatus(state pb.CoreState, msgType pb.MessageType, message string) *pb.CoreInfoResponse {
2024-03-18 20:38:09 +01:00
msg := fmt.Sprintf("%s: %s %s", state.String(), msgType.String(), message)
if msgType == pb.MessageType_EMPTY {
msg = fmt.Sprintf("%s: %s", state.String(), message)
}
Log(pb.LogLevel_INFO, pb.LogType_CORE, msg)
2024-03-10 19:45:03 +01:00
CoreState = state
info := pb.CoreInfoResponse{
CoreState: state,
MessageType: msgType,
Message: message,
}
coreInfoObserver.Emit(&info)
2024-03-18 20:38:09 +01:00
if useFlutterBridge {
msg, _ := json.Marshal(StatusMessage{Status: convert2OldState(CoreState)})
bridge.SendStringToPort(statusPropagationPort, string(msg))
}
return &info
2024-03-10 19:45:03 +01:00
}
func (s *CoreService) CoreInfoListener(req *pb.Empty, stream grpc.ServerStreamingServer[pb.CoreInfoResponse]) error {
coreSub, done, err := coreInfoObserver.Subscribe()
if err != nil {
return err
}
2024-03-10 19:45:03 +01:00
defer coreInfoObserver.UnSubscribe(coreSub)
2024-03-10 19:45:03 +01:00
for {
select {
case <-stream.Context().Done():
2024-03-18 20:38:09 +01:00
return nil
case <-done:
2024-03-18 20:38:09 +01:00
return nil
2024-03-10 19:45:03 +01:00
case info := <-coreSub:
stream.Send(info)
// case <-time.After(500 * time.Millisecond):
// info := SetCoreStatus(pb.CoreState_STOPPED, pb.MessageType_EMPTY, "")
// stream.Send(info)
2024-03-10 19:45:03 +01:00
}
}
}