common.go 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. package conf
  2. import (
  3. "encoding/json"
  4. "strings"
  5. "github.com/xtls/xray-core/common/errors"
  6. "github.com/xtls/xray-core/common/net"
  7. "github.com/xtls/xray-core/common/platform"
  8. "github.com/xtls/xray-core/common/protocol"
  9. )
  10. type StringList []string
  11. func NewStringList(raw []string) *StringList {
  12. list := StringList(raw)
  13. return &list
  14. }
  15. func (v StringList) Len() int {
  16. return len(v)
  17. }
  18. func (v *StringList) UnmarshalJSON(data []byte) error {
  19. var strarray []string
  20. if err := json.Unmarshal(data, &strarray); err == nil {
  21. *v = *NewStringList(strarray)
  22. return nil
  23. }
  24. var rawstr string
  25. if err := json.Unmarshal(data, &rawstr); err == nil {
  26. strlist := strings.Split(rawstr, ",")
  27. *v = *NewStringList(strlist)
  28. return nil
  29. }
  30. return errors.New("unknown format of a string list: " + string(data))
  31. }
  32. type Address struct {
  33. net.Address
  34. }
  35. func (v *Address) UnmarshalJSON(data []byte) error {
  36. var rawStr string
  37. if err := json.Unmarshal(data, &rawStr); err != nil {
  38. return errors.New("invalid address: ", string(data)).Base(err)
  39. }
  40. if strings.HasPrefix(rawStr, "env:") {
  41. rawStr = platform.NewEnvFlag(rawStr[4:]).GetValue(func() string { return "" })
  42. }
  43. v.Address = net.ParseAddress(rawStr)
  44. return nil
  45. }
  46. func (v *Address) Build() *net.IPOrDomain {
  47. return net.NewIPOrDomain(v.Address)
  48. }
  49. type Network string
  50. func (v Network) Build() net.Network {
  51. switch strings.ToLower(string(v)) {
  52. case "tcp":
  53. return net.Network_TCP
  54. case "udp":
  55. return net.Network_UDP
  56. case "unix":
  57. return net.Network_UNIX
  58. default:
  59. return net.Network_Unknown
  60. }
  61. }
  62. type NetworkList []Network
  63. func (v *NetworkList) UnmarshalJSON(data []byte) error {
  64. var strarray []Network
  65. if err := json.Unmarshal(data, &strarray); err == nil {
  66. nl := NetworkList(strarray)
  67. *v = nl
  68. return nil
  69. }
  70. var rawstr Network
  71. if err := json.Unmarshal(data, &rawstr); err == nil {
  72. strlist := strings.Split(string(rawstr), ",")
  73. nl := make([]Network, len(strlist))
  74. for idx, network := range strlist {
  75. nl[idx] = Network(network)
  76. }
  77. *v = nl
  78. return nil
  79. }
  80. return errors.New("unknown format of a string list: " + string(data))
  81. }
  82. func (v *NetworkList) Build() []net.Network {
  83. if v == nil {
  84. return []net.Network{net.Network_TCP}
  85. }
  86. list := make([]net.Network, 0, len(*v))
  87. for _, network := range *v {
  88. list = append(list, network.Build())
  89. }
  90. return list
  91. }
  92. func parseIntPort(data []byte) (net.Port, error) {
  93. var intPort uint32
  94. err := json.Unmarshal(data, &intPort)
  95. if err != nil {
  96. return net.Port(0), err
  97. }
  98. return net.PortFromInt(intPort)
  99. }
  100. func parseStringPort(s string) (net.Port, net.Port, error) {
  101. if strings.HasPrefix(s, "env:") {
  102. s = platform.NewEnvFlag(s[4:]).GetValue(func() string { return "" })
  103. }
  104. pair := strings.SplitN(s, "-", 2)
  105. if len(pair) == 0 {
  106. return net.Port(0), net.Port(0), errors.New("invalid port range: ", s)
  107. }
  108. if len(pair) == 1 {
  109. port, err := net.PortFromString(pair[0])
  110. return port, port, err
  111. }
  112. fromPort, err := net.PortFromString(pair[0])
  113. if err != nil {
  114. return net.Port(0), net.Port(0), err
  115. }
  116. toPort, err := net.PortFromString(pair[1])
  117. if err != nil {
  118. return net.Port(0), net.Port(0), err
  119. }
  120. return fromPort, toPort, nil
  121. }
  122. func parseJSONStringPort(data []byte) (net.Port, net.Port, error) {
  123. var s string
  124. err := json.Unmarshal(data, &s)
  125. if err != nil {
  126. return net.Port(0), net.Port(0), err
  127. }
  128. return parseStringPort(s)
  129. }
  130. type PortRange struct {
  131. From uint32
  132. To uint32
  133. }
  134. func (v *PortRange) Build() *net.PortRange {
  135. return &net.PortRange{
  136. From: v.From,
  137. To: v.To,
  138. }
  139. }
  140. // UnmarshalJSON implements encoding/json.Unmarshaler.UnmarshalJSON
  141. func (v *PortRange) UnmarshalJSON(data []byte) error {
  142. port, err := parseIntPort(data)
  143. if err == nil {
  144. v.From = uint32(port)
  145. v.To = uint32(port)
  146. return nil
  147. }
  148. from, to, err := parseJSONStringPort(data)
  149. if err == nil {
  150. v.From = uint32(from)
  151. v.To = uint32(to)
  152. if v.From > v.To {
  153. return errors.New("invalid port range ", v.From, " -> ", v.To)
  154. }
  155. return nil
  156. }
  157. return errors.New("invalid port range: ", string(data))
  158. }
  159. type PortList struct {
  160. Range []PortRange
  161. }
  162. func (list *PortList) Build() *net.PortList {
  163. portList := new(net.PortList)
  164. for _, r := range list.Range {
  165. portList.Range = append(portList.Range, r.Build())
  166. }
  167. return portList
  168. }
  169. // UnmarshalJSON implements encoding/json.Unmarshaler.UnmarshalJSON
  170. func (list *PortList) UnmarshalJSON(data []byte) error {
  171. var listStr string
  172. var number uint32
  173. if err := json.Unmarshal(data, &listStr); err != nil {
  174. if err2 := json.Unmarshal(data, &number); err2 != nil {
  175. return errors.New("invalid port: ", string(data)).Base(err2)
  176. }
  177. }
  178. rangelist := strings.Split(listStr, ",")
  179. for _, rangeStr := range rangelist {
  180. trimmed := strings.TrimSpace(rangeStr)
  181. if len(trimmed) > 0 {
  182. if strings.Contains(trimmed, "-") || strings.Contains(trimmed, "env:") {
  183. from, to, err := parseStringPort(trimmed)
  184. if err != nil {
  185. return errors.New("invalid port range: ", trimmed).Base(err)
  186. }
  187. list.Range = append(list.Range, PortRange{From: uint32(from), To: uint32(to)})
  188. } else {
  189. port, err := parseIntPort([]byte(trimmed))
  190. if err != nil {
  191. return errors.New("invalid port: ", trimmed).Base(err)
  192. }
  193. list.Range = append(list.Range, PortRange{From: uint32(port), To: uint32(port)})
  194. }
  195. }
  196. }
  197. if number != 0 {
  198. list.Range = append(list.Range, PortRange{From: number, To: number})
  199. }
  200. return nil
  201. }
  202. type User struct {
  203. EmailString string `json:"email"`
  204. LevelByte byte `json:"level"`
  205. }
  206. func (v *User) Build() *protocol.User {
  207. return &protocol.User{
  208. Email: v.EmailString,
  209. Level: uint32(v.LevelByte),
  210. }
  211. }