| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- // +build json
- package http
- import (
- "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
- return nil
- }
- 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
- })
- }
|