mirror of https://github.com/dnomd343/XProxy.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
62 lines
2.3 KiB
62 lines
2.3 KiB
package proxy
|
|
|
|
import (
|
|
"XProxy/cmd/common"
|
|
)
|
|
|
|
type Config struct {
|
|
Log string `yaml:"log" json:"json"`
|
|
Http map[string]int `yaml:"http" json:"http"`
|
|
Socks map[string]int `yaml:"socks" json:"socks"`
|
|
AddOn []interface{} `yaml:"addon" json:"addon"`
|
|
Sniff struct {
|
|
Enable bool `yaml:"enable" json:"enable"`
|
|
Redirect bool `yaml:"redirect" json:"redirect"`
|
|
Exclude []string `yaml:"exclude" json:"exclude"`
|
|
} `yaml:"sniff" json:"sniff"`
|
|
V4TProxyPort int
|
|
V6TProxyPort int
|
|
}
|
|
|
|
func saveConfig(configDir string, caption string, content string, overwrite bool) {
|
|
filePath := configDir + "/" + caption + ".json"
|
|
common.WriteFile(filePath, content+"\n", overwrite)
|
|
}
|
|
|
|
func loadInbounds(config *Config) string {
|
|
sniff := sniffObject{
|
|
Enabled: config.Sniff.Enable,
|
|
RouteOnly: !config.Sniff.Redirect,
|
|
DestOverride: []string{"http", "tls", "quic"},
|
|
DomainsExcluded: config.Sniff.Exclude,
|
|
}
|
|
var inbounds []interface{}
|
|
inbounds = append(inbounds, loadTProxyConfig("tproxy", config.V4TProxyPort, sniff))
|
|
inbounds = append(inbounds, loadTProxyConfig("tproxy6", config.V6TProxyPort, sniff))
|
|
for tag, port := range config.Http {
|
|
inbounds = append(inbounds, loadHttpConfig(tag, port, sniff))
|
|
}
|
|
for tag, port := range config.Socks {
|
|
inbounds = append(inbounds, loadSocksConfig(tag, port, sniff))
|
|
}
|
|
for _, addon := range config.AddOn {
|
|
inbounds = append(inbounds, addon)
|
|
}
|
|
return common.JsonEncode(inboundsObject{
|
|
Inbounds: inbounds,
|
|
})
|
|
}
|
|
|
|
func Load(configDir string, exposeDir string, config *Config) {
|
|
common.CreateFolder(exposeDir + "/log")
|
|
common.CreateFolder(exposeDir + "/config")
|
|
common.CreateFolder(configDir)
|
|
saveConfig(exposeDir+"/config", "dns", dnsConfig, false)
|
|
saveConfig(exposeDir+"/config", "route", routeConfig, false)
|
|
saveConfig(exposeDir+"/config", "outbounds", outboundsConfig, false)
|
|
saveConfig(configDir, "inbounds", loadInbounds(config), true)
|
|
saveConfig(configDir, "log", loadLogConfig(config.Log, exposeDir+"/log"), true)
|
|
for _, configFile := range common.ListFiles(exposeDir+"/config", ".json") {
|
|
common.CopyFile(exposeDir+"/config/"+configFile, configDir+"/"+configFile)
|
|
}
|
|
}
|
|
|