package conf import ( "github.com/inazumav/sing-box/option" ) type SingConfig struct { LogConfig SingLogConfig `json:"Log"` NtpConfig SingNtpConfig `json:"NTP"` EnableConnClear bool `json:"EnableConnClear"` DnsConfigPath string `json:"DnsConfigPath"` OriginalPath string `json:"OriginalPath"` } type SingLogConfig struct { Disabled bool `json:"Disable"` Level string `json:"Level"` Output string `json:"Output"` Timestamp bool `json:"Timestamp"` } func NewSingConfig() *SingConfig { return &SingConfig{ LogConfig: SingLogConfig{ Level: "error", Timestamp: true, }, NtpConfig: SingNtpConfig{ Enable: false, Server: "time.apple.com", ServerPort: 0, }, } } type SingOptions struct { EnableProxyProtocol bool `json:"EnableProxyProtocol"` TCPFastOpen bool `json:"EnableTFO"` SniffEnabled bool `json:"EnableSniff"` EnableDNS bool `json:"EnableDNS"` DomainStrategy option.DomainStrategy `json:"DomainStrategy"` SniffOverrideDestination bool `json:"SniffOverrideDestination"` FallBackConfigs *FallBackConfigForSing `json:"FallBackConfigs"` } type SingNtpConfig struct { Enable bool `json:"Enable"` Server string `json:"Server"` ServerPort uint16 `json:"ServerPort"` } type FallBackConfigForSing struct { // sing-box FallBack FallBack `json:"FallBack"` FallBackForALPN map[string]FallBack `json:"FallBackForALPN"` } type FallBack struct { Server string `json:"Server"` ServerPort string `json:"ServerPort"` } func NewSingOptions() *SingOptions { return &SingOptions{ EnableDNS: false, EnableProxyProtocol: false, TCPFastOpen: false, SniffEnabled: true, SniffOverrideDestination: true, FallBackConfigs: &FallBackConfigForSing{}, } }