mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-03 07:56:42 -05:00
Outbound detour config
This commit is contained in:
parent
8597642002
commit
1d4b98ab9a
@ -5,7 +5,7 @@ type RouterConfig interface {
|
|||||||
Settings() interface{}
|
Settings() interface{}
|
||||||
}
|
}
|
||||||
|
|
||||||
type ConnectionTag string
|
type DetourTag string
|
||||||
|
|
||||||
type ConnectionConfig interface {
|
type ConnectionConfig interface {
|
||||||
Protocol() string
|
Protocol() string
|
||||||
@ -27,6 +27,12 @@ type InboundDetourConfig interface {
|
|||||||
Settings() interface{}
|
Settings() interface{}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type OutboundDetourConfig interface {
|
||||||
|
Protocol() string
|
||||||
|
Tag() DetourTag
|
||||||
|
Settings() interface{}
|
||||||
|
}
|
||||||
|
|
||||||
type PointConfig interface {
|
type PointConfig interface {
|
||||||
Port() uint16
|
Port() uint16
|
||||||
LogConfig() LogConfig
|
LogConfig() LogConfig
|
||||||
|
@ -12,11 +12,12 @@ import (
|
|||||||
|
|
||||||
// Config is the config for Point server.
|
// Config is the config for Point server.
|
||||||
type Config struct {
|
type Config struct {
|
||||||
PortValue uint16 `json:"port"` // Port of this Point server.
|
PortValue uint16 `json:"port"` // Port of this Point server.
|
||||||
LogConfigValue *LogConfig `json:"log"`
|
LogConfigValue *LogConfig `json:"log"`
|
||||||
InboundConfigValue *ConnectionConfig `json:"inbound"`
|
InboundConfigValue *ConnectionConfig `json:"inbound"`
|
||||||
OutboundConfigValue *ConnectionConfig `json:"outbound"`
|
OutboundConfigValue *ConnectionConfig `json:"outbound"`
|
||||||
InboundDetoursValue []*InboundDetourConfig `json:"inboundDetour"`
|
InboundDetoursValue []*InboundDetourConfig `json:"inboundDetour"`
|
||||||
|
OutboundDetoursValue []*OutboundDetourConfig `json:"outboundDetour"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (config *Config) Port() uint16 {
|
func (config *Config) Port() uint16 {
|
||||||
@ -52,6 +53,14 @@ func (this *Config) InboundDetours() []config.InboundDetourConfig {
|
|||||||
return detours
|
return detours
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (this *Config) OutboundDetours() []config.OutboundDetourConfig {
|
||||||
|
detours := make([]config.OutboundDetourConfig, len(this.OutboundDetoursValue))
|
||||||
|
for idx, detour := range this.OutboundDetoursValue {
|
||||||
|
detours[idx] = detour
|
||||||
|
}
|
||||||
|
return detours
|
||||||
|
}
|
||||||
|
|
||||||
func LoadConfig(file string) (*Config, error) {
|
func LoadConfig(file string) (*Config, error) {
|
||||||
fixedFile := os.ExpandEnv(file)
|
fixedFile := os.ExpandEnv(file)
|
||||||
rawConfig, err := ioutil.ReadFile(fixedFile)
|
rawConfig, err := ioutil.ReadFile(fixedFile)
|
||||||
|
26
app/point/config/json/outbound_detour.go
Normal file
26
app/point/config/json/outbound_detour.go
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
package json
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
|
||||||
|
"github.com/v2ray/v2ray-core/app/point/config"
|
||||||
|
proxyconfig "github.com/v2ray/v2ray-core/proxy/common/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
type OutboundDetourConfig struct {
|
||||||
|
ProtocolValue string `json:"protocol"`
|
||||||
|
TagValue string `json:"tag"`
|
||||||
|
SettingsValue json.RawMessage `json:"settings"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *OutboundDetourConfig) Protocol() string {
|
||||||
|
return this.ProtocolValue
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *OutboundDetourConfig) Tag() config.DetourTag {
|
||||||
|
return config.DetourTag(this.TagValue)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *OutboundDetourConfig) Settings() interface{} {
|
||||||
|
return loadConnectionConfig(this.SettingsValue, this.ProtocolValue, proxyconfig.TypeOutbound)
|
||||||
|
}
|
@ -12,7 +12,7 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Router interface {
|
type Router interface {
|
||||||
TakeDetour(v2net.Packet) (config.ConnectionTag, error)
|
TakeDetour(v2net.Packet) (config.DetourTag, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type RouterFactory interface {
|
type RouterFactory interface {
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
type WildcardRouter struct {
|
type WildcardRouter struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (router *WildcardRouter) TakeDetour(packet v2net.Packet) (config.ConnectionTag, error) {
|
func (router *WildcardRouter) TakeDetour(packet v2net.Packet) (config.DetourTag, error) {
|
||||||
return "", nil
|
return "", nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user