| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | // +build jsonpackage httpimport (	"crypto/tls"	"encoding/json"	v2net "github.com/v2ray/v2ray-core/common/net"	"github.com/v2ray/v2ray-core/proxy/internal/config")func (this *CertificateConfig) UnmarshalJSON(data []byte) error {	type JsonConfig struct {		Domain   string `json:"domain"`		CertFile string `json:"cert"`		KeyFile  string `json:"key"`	}	jsonConfig := new(JsonConfig)	if err := json.Unmarshal(data, jsonConfig); err != nil {		return err	}	cert, err := tls.LoadX509KeyPair(jsonConfig.CertFile, jsonConfig.KeyFile)	if err != nil {		return err	}	this.Domain = jsonConfig.Domain	this.Certificate = cert}func (this *TlsConfig) UnmarshalJSON(data []byte) error {	type JsonConfig struct {		Enabled bool                 `json:"enable"`		Certs   []*CertificateConfig `json:"certs"`	}	jsonConfig := new(JsonConfig)	if err := json.Unmarshal(data, jsonConfig); err != nil {		return err	}	this.Enabled = jsonConfig.Enabled	this.Certs = jsonConfig.Certs	return nil}func (this *Config) UnmarshalJSON(data []byte) error {	type JsonConfig struct {		Hosts []v2net.AddressJson `json:"ownHosts"`		Tls   *TlsConfig          `json:"tls"`	}	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)	}	this.TlsConfig = jsonConfig.Tls	return nil}func init() {	config.RegisterInboundConfig("http",		func(data []byte) (interface{}, error) {			rawConfig := new(Config)			err := json.Unmarshal(data, rawConfig)			return rawConfig, err		})}
 |