2024-03-10 19:45:03 +01:00
|
|
|
package v2
|
|
|
|
|
|
|
|
|
|
import (
|
2024-03-16 01:39:33 +01:00
|
|
|
"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
|
|
|
)
|
|
|
|
|
|
2024-03-16 01:39:33 +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 {
|
2024-03-16 03:01:22 +01:00
|
|
|
msg, _ := json.Marshal(StatusMessage{Status: convert2OldState(CoreState)})
|
|
|
|
|
bridge.SendStringToPort(statusPropagationPort, string(msg))
|
|
|
|
|
}
|
2024-03-10 19:45:03 +01:00
|
|
|
return info
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-16 01:39:33 +01:00
|
|
|
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):
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|