Files
umbrix-libcore/v2/coreinfo.go

56 lines
1.4 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
"time"
2024-03-22 16:25:56 +00:00
"github.com/hiddify/hiddify-core/bridge"
pb "github.com/hiddify/hiddify-core/hiddifyrpc"
2024-03-10 19:45:03 +01:00
)
var coreInfoObserver = NewObserver[pb.CoreInfoResponse](10)
2024-03-10 19:45:03 +01:00
var CoreState = pb.CoreState_STOPPED
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))
}
2024-03-10 19:45:03 +01:00
return info
}
func (s *CoreService) CoreInfoListener(stream pb.Core_CoreInfoListenerServer) error {
2024-03-10 19:45:03 +01:00
coreSub, _, _ := coreInfoObserver.Subscribe()
defer coreInfoObserver.UnSubscribe(coreSub)
stopch := make(chan int)
go func() {
stream.Recv()
close(stopch)
}()
for {
select {
case <-stream.Context().Done():
2024-03-18 20:38:09 +01:00
return nil
2024-03-10 19:45:03 +01:00
case <-stopch:
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):
}
}
}