mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-05 00:47:51 -05:00
own hosts in http config
This commit is contained in:
parent
befd24c83e
commit
6b894c719d
@ -1,4 +1,18 @@
|
|||||||
package http
|
package http
|
||||||
|
|
||||||
|
import (
|
||||||
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
|
)
|
||||||
|
|
||||||
type Config struct {
|
type Config struct {
|
||||||
|
OwnHosts []v2net.Address
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *Config) IsOwnHost(host v2net.Address) bool {
|
||||||
|
for _, ownHost := range this.OwnHosts {
|
||||||
|
if ownHost.Equals(host) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
@ -3,12 +3,38 @@
|
|||||||
package http
|
package http
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
|
||||||
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
"github.com/v2ray/v2ray-core/proxy/internal/config"
|
"github.com/v2ray/v2ray-core/proxy/internal/config"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func (this *Config) UnmarshalJSON(data []byte) error {
|
||||||
|
type JsonConfig struct {
|
||||||
|
Hosts []v2net.AddressJson `json:"ownHosts"`
|
||||||
|
}
|
||||||
|
jsonConfig := new(JsonConfig)
|
||||||
|
if err := json.Unmarshal(data, jsonConfig); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
this.OwnHosts = make([]v2net.Address, len(jsonConfig.Hosts), len(jsonConfig.Hosts)+1)
|
||||||
|
for idx, host := range jsonConfig.Hosts {
|
||||||
|
this.OwnHosts[idx] = host.Address
|
||||||
|
}
|
||||||
|
|
||||||
|
v2rayHost := v2net.DomainAddress("local.v2ray.com")
|
||||||
|
if !this.IsOwnHost(v2rayHost) {
|
||||||
|
this.OwnHosts = append(this.OwnHosts, v2rayHost)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
config.RegisterInboundConfig("http",
|
config.RegisterInboundConfig("http",
|
||||||
func(data []byte) (interface{}, error) {
|
func(data []byte) (interface{}, error) {
|
||||||
return new(Config), nil
|
rawConfig := new(Config)
|
||||||
|
err := json.Unmarshal(data, rawConfig)
|
||||||
|
return rawConfig, err
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
32
proxy/http/config_json_test.go
Normal file
32
proxy/http/config_json_test.go
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
// +build json
|
||||||
|
|
||||||
|
package http_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
||||||
|
. "github.com/v2ray/v2ray-core/proxy/http"
|
||||||
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
||||||
|
"github.com/v2ray/v2ray-core/testing/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestOwnHosts(t *testing.T) {
|
||||||
|
v2testing.Current(t)
|
||||||
|
|
||||||
|
rawJson := `{
|
||||||
|
"ownHosts": [
|
||||||
|
"127.0.0.1",
|
||||||
|
"google.com"
|
||||||
|
]
|
||||||
|
}`
|
||||||
|
|
||||||
|
config := new(Config)
|
||||||
|
err := json.Unmarshal([]byte(rawJson), config)
|
||||||
|
assert.Error(err).IsNil()
|
||||||
|
assert.Bool(config.IsOwnHost(v2net.IPAddress([]byte{127, 0, 0, 1}))).IsTrue()
|
||||||
|
assert.Bool(config.IsOwnHost(v2net.DomainAddress("google.com"))).IsTrue()
|
||||||
|
assert.Bool(config.IsOwnHost(v2net.DomainAddress("local.v2ray.com"))).IsTrue()
|
||||||
|
assert.Bool(config.IsOwnHost(v2net.DomainAddress("v2ray.com"))).IsFalse()
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user