Files
umbrix-libcore/custom/command_server.go

44 lines
1.1 KiB
Go
Raw Normal View History

2023-08-28 13:07:21 +03:30
package main
2023-10-27 14:36:00 +03:30
import (
"github.com/sagernet/sing-box/experimental/libbox"
"github.com/sagernet/sing-box/log"
)
2023-08-28 13:07:21 +03:30
var commandServer *libbox.CommandServer
2023-10-27 16:39:48 +03:30
type CommandServerHandler struct {
logger log.Logger
}
2023-08-28 13:07:21 +03:30
func (csh *CommandServerHandler) ServiceReload() error {
2023-10-27 16:39:48 +03:30
csh.logger.Trace("Reloading service")
2023-09-10 20:18:33 +03:30
propagateStatus(Starting)
if commandServer != nil {
commandServer.SetService(nil)
commandServer = nil
}
if box != nil {
box.Close()
box = nil
}
2023-10-27 14:36:00 +03:30
return startService(true)
2023-08-28 13:07:21 +03:30
}
2023-09-05 19:00:24 +03:30
func (csh *CommandServerHandler) GetSystemProxyStatus() *libbox.SystemProxyStatus {
2023-10-27 16:39:48 +03:30
csh.logger.Trace("Getting system proxy status")
2023-09-05 19:00:24 +03:30
return &libbox.SystemProxyStatus{Available: true, Enabled: false}
}
func (csh *CommandServerHandler) SetSystemProxyEnabled(isEnabled bool) error {
2023-10-27 16:39:48 +03:30
csh.logger.Trace("Setting system proxy status, enabled? ", isEnabled)
2023-10-27 14:36:00 +03:30
return csh.ServiceReload()
2023-09-05 19:00:24 +03:30
}
2023-10-27 16:39:48 +03:30
func startCommandServer(logFactory log.Factory) error {
logger := logFactory.NewLogger("[Command Server Handler]")
logger.Trace("Starting command server")
commandServer = libbox.NewCommandServer(&CommandServerHandler{logger: logger}, 300)
2023-08-28 13:07:21 +03:30
return commandServer.Start()
}