123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- package libbox
- import (
- "bytes"
- "context"
- "net/netip"
- "os"
- "github.com/sagernet/sing-box"
- "github.com/sagernet/sing-box/adapter"
- "github.com/sagernet/sing-box/common/process"
- "github.com/sagernet/sing-box/experimental/libbox/platform"
- "github.com/sagernet/sing-box/option"
- "github.com/sagernet/sing-tun"
- "github.com/sagernet/sing/common/control"
- E "github.com/sagernet/sing/common/exceptions"
- "github.com/sagernet/sing/common/json"
- "github.com/sagernet/sing/common/logger"
- "github.com/sagernet/sing/common/x/list"
- )
- func parseConfig(configContent string) (option.Options, error) {
- options, err := json.UnmarshalExtended[option.Options]([]byte(configContent))
- if err != nil {
- return option.Options{}, E.Cause(err, "decode config")
- }
- return options, nil
- }
- func CheckConfig(configContent string) error {
- options, err := parseConfig(configContent)
- if err != nil {
- return err
- }
- ctx, cancel := context.WithCancel(context.Background())
- defer cancel()
- instance, err := box.New(box.Options{
- Context: ctx,
- Options: options,
- PlatformInterface: (*platformInterfaceStub)(nil),
- })
- if err == nil {
- instance.Close()
- }
- return err
- }
- type platformInterfaceStub struct{}
- func (s *platformInterfaceStub) Initialize(ctx context.Context, router adapter.Router) error {
- return nil
- }
- func (s *platformInterfaceStub) UsePlatformAutoDetectInterfaceControl() bool {
- return true
- }
- func (s *platformInterfaceStub) AutoDetectInterfaceControl() control.Func {
- return nil
- }
- func (s *platformInterfaceStub) OpenTun(options *tun.Options, platformOptions option.TunPlatformOptions) (tun.Tun, error) {
- return nil, os.ErrInvalid
- }
- func (s *platformInterfaceStub) UsePlatformDefaultInterfaceMonitor() bool {
- return true
- }
- func (s *platformInterfaceStub) CreateDefaultInterfaceMonitor(logger logger.Logger) tun.DefaultInterfaceMonitor {
- return (*interfaceMonitorStub)(nil)
- }
- func (s *platformInterfaceStub) UsePlatformInterfaceGetter() bool {
- return true
- }
- func (s *platformInterfaceStub) Interfaces() ([]platform.NetworkInterface, error) {
- return nil, os.ErrInvalid
- }
- func (s *platformInterfaceStub) UnderNetworkExtension() bool {
- return false
- }
- func (s *platformInterfaceStub) ClearDNSCache() {
- }
- func (s *platformInterfaceStub) ReadWIFIState() adapter.WIFIState {
- return adapter.WIFIState{}
- }
- func (s *platformInterfaceStub) FindProcessInfo(ctx context.Context, network string, source netip.AddrPort, destination netip.AddrPort) (*process.Info, error) {
- return nil, os.ErrInvalid
- }
- type interfaceMonitorStub struct{}
- func (s *interfaceMonitorStub) Start() error {
- return os.ErrInvalid
- }
- func (s *interfaceMonitorStub) Close() error {
- return os.ErrInvalid
- }
- func (s *interfaceMonitorStub) DefaultInterfaceName(destination netip.Addr) string {
- return ""
- }
- func (s *interfaceMonitorStub) DefaultInterfaceIndex(destination netip.Addr) int {
- return -1
- }
- func (s *interfaceMonitorStub) DefaultInterface(destination netip.Addr) (string, int) {
- return "", -1
- }
- func (s *interfaceMonitorStub) OverrideAndroidVPN() bool {
- return false
- }
- func (s *interfaceMonitorStub) AndroidVPNEnabled() bool {
- return false
- }
- func (s *interfaceMonitorStub) RegisterCallback(callback tun.DefaultInterfaceUpdateCallback) *list.Element[tun.DefaultInterfaceUpdateCallback] {
- return nil
- }
- func (s *interfaceMonitorStub) UnregisterCallback(element *list.Element[tun.DefaultInterfaceUpdateCallback]) {
- }
- func FormatConfig(configContent string) (string, error) {
- options, err := parseConfig(configContent)
- if err != nil {
- return "", err
- }
- var buffer bytes.Buffer
- json.NewEncoder(&buffer)
- encoder := json.NewEncoder(&buffer)
- encoder.SetIndent("", " ")
- err = encoder.Encode(options)
- if err != nil {
- return "", err
- }
- return buffer.String(), nil
- }
|