client.lua 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. -- Copyright (C) 2017 yushi studio <[email protected]> github.com/ywb94
  2. -- Copyright (C) 2018 lean <[email protected]> github.com/coolsnowwolf
  3. -- Licensed to the public under the GNU General Public License v3.
  4. local m, s, sec, o
  5. local uci = luci.model.uci.cursor()
  6. local validation = require "luci.cbi.datatypes"
  7. local function is_finded(e)
  8. return luci.sys.exec('type -t -p "%s"' % e) ~= "" and true or false
  9. end
  10. m = Map("shadowsocksr", translate("ShadowSocksR Plus+ Settings"), translate("<h3>Support SS/SSR/V2RAY/XRAY/TROJAN/NAIVEPROXY/SOCKS5/TUN etc.</h3>"))
  11. m:section(SimpleSection).template = "shadowsocksr/status"
  12. local server_table = {}
  13. uci:foreach("shadowsocksr", "servers", function(s)
  14. if s.alias then
  15. server_table[s[".name"]] = "[%s]:%s" % {string.upper(s.v2ray_protocol or s.type), s.alias}
  16. elseif s.server and s.server_port then
  17. server_table[s[".name"]] = "[%s]:%s:%s" % {string.upper(s.v2ray_protocol or s.type), s.server, s.server_port}
  18. end
  19. end)
  20. local key_table = {}
  21. for key, _ in pairs(server_table) do
  22. table.insert(key_table, key)
  23. end
  24. table.sort(key_table)
  25. -- [[ Global Setting ]]--
  26. s = m:section(TypedSection, "global")
  27. s.anonymous = true
  28. o = s:option(ListValue, "global_server", translate("Main Server"))
  29. o:value("nil", translate("Disable"))
  30. for _, key in pairs(key_table) do
  31. o:value(key, server_table[key])
  32. end
  33. o.default = "nil"
  34. o.rmempty = false
  35. o = s:option(ListValue, "udp_relay_server", translate("Game Mode UDP Server"))
  36. o:value("", translate("Disable"))
  37. o:value("same", translate("Same as Global Server"))
  38. for _, key in pairs(key_table) do
  39. o:value(key, server_table[key])
  40. end
  41. if uci:get_first("shadowsocksr", 'global', 'netflix_enable', '0') == '1' then
  42. o = s:option(ListValue, "netflix_server", translate("Netflix Node"))
  43. o:value("nil", translate("Disable"))
  44. o:value("same", translate("Same as Global Server"))
  45. for _, key in pairs(key_table) do
  46. o:value(key, server_table[key])
  47. end
  48. o.default = "nil"
  49. o.rmempty = false
  50. o = s:option(Flag, "netflix_proxy", translate("External Proxy Mode"))
  51. o.rmempty = false
  52. o.description = translate("Forward Netflix Proxy through Main Proxy")
  53. o.default = "0"
  54. end
  55. o = s:option(ListValue, "threads", translate("Multi Threads Option"))
  56. o:value("0", translate("Auto Threads"))
  57. o:value("1", translate("1 Thread"))
  58. o:value("2", translate("2 Threads"))
  59. o:value("4", translate("4 Threads"))
  60. o:value("8", translate("8 Threads"))
  61. o:value("16", translate("16 Threads"))
  62. o:value("32", translate("32 Threads"))
  63. o:value("64", translate("64 Threads"))
  64. o:value("128", translate("128 Threads"))
  65. o.default = "0"
  66. o.rmempty = false
  67. o = s:option(ListValue, "run_mode", translate("Running Mode"))
  68. o:value("gfw", translate("GFW List Mode"))
  69. o:value("router", translate("IP Route Mode"))
  70. o:value("all", translate("Global Mode"))
  71. o:value("oversea", translate("Oversea Mode"))
  72. o.default = gfw
  73. o = s:option(ListValue, "dports", translate("Proxy Ports"))
  74. o:value("1", translate("All Ports"))
  75. o:value("2", translate("Only Common Ports"))
  76. o.default = 1
  77. o = s:option(ListValue, "pdnsd_enable", translate("Resolve Dns Mode"))
  78. o:value("1", translate("Use DNS2TCP query"))
  79. o:value("2", translate("Use DNS2SOCKS query and cache"))
  80. o:value("3", translate("Use MOSDNS query (Not Support Oversea Mode)"))
  81. o:value("0", translate("Use Local DNS Service listen port 5335"))
  82. o.default = 1
  83. o = s:option(Value, "tunnel_forward", translate("Anti-pollution DNS Server"))
  84. o:value("8.8.4.4:53", translate("Google Public DNS (8.8.4.4)"))
  85. o:value("8.8.8.8:53", translate("Google Public DNS (8.8.8.8)"))
  86. o:value("208.67.222.222:53", translate("OpenDNS (208.67.222.222)"))
  87. o:value("208.67.220.220:53", translate("OpenDNS (208.67.220.220)"))
  88. o:value("209.244.0.3:53", translate("Level 3 Public DNS (209.244.0.3)"))
  89. o:value("209.244.0.4:53", translate("Level 3 Public DNS (209.244.0.4)"))
  90. o:value("4.2.2.1:53", translate("Level 3 Public DNS (4.2.2.1)"))
  91. o:value("4.2.2.2:53", translate("Level 3 Public DNS (4.2.2.2)"))
  92. o:value("4.2.2.3:53", translate("Level 3 Public DNS (4.2.2.3)"))
  93. o:value("4.2.2.4:53", translate("Level 3 Public DNS (4.2.2.4)"))
  94. o:value("1.1.1.1:53", translate("Cloudflare DNS (1.1.1.1)"))
  95. o:value("114.114.114.114:53", translate("Oversea Mode DNS-1 (114.114.114.114)"))
  96. o:value("114.114.115.115:53", translate("Oversea Mode DNS-2 (114.114.115.115)"))
  97. o:depends("pdnsd_enable", "1")
  98. o:depends("pdnsd_enable", "2")
  99. o.description = translate("Custom DNS Server format as IP:PORT (default: 8.8.4.4:53)")
  100. o.datatype = "ip4addrport"
  101. o = s:option(ListValue, "tunnel_forward_mosdns", translate("Anti-pollution DNS Server"))
  102. o:value("tcp://8.8.4.4:53,tcp://8.8.8.8:53", translate("Google Public DNS"))
  103. o:value("tcp://208.67.222.222:53,tcp://208.67.220.220:53", translate("OpenDNS"))
  104. o:value("tcp://209.244.0.3:53,tcp://209.244.0.4:53", translate("Level 3 Public DNS-1 (209.244.0.3-4)"))
  105. o:value("tcp://4.2.2.1:53,tcp://4.2.2.2:53", translate("Level 3 Public DNS-2 (4.2.2.1-2)"))
  106. o:value("tcp://4.2.2.3:53,tcp://4.2.2.4:53", translate("Level 3 Public DNS-3 (4.2.2.3-4)"))
  107. o:value("tcp://1.1.1.1:53,tcp://1.0.0.1:53", translate("Cloudflare DNS"))
  108. o:depends("pdnsd_enable", "3")
  109. o.description = translate("Custom DNS Server for mosdns")
  110. o = s:option(Flag, "mosdns_ipv6", translate("Disable IPv6 in MOSDNS query mode"))
  111. o:depends("pdnsd_enable", "3")
  112. o.rmempty = false
  113. o.default = "0"
  114. if is_finded("chinadns-ng") then
  115. o = s:option(Value, "chinadns_forward", translate("Domestic DNS Server"))
  116. o:value("", translate("Disable ChinaDNS-NG"))
  117. o:value("wan", translate("Use DNS from WAN"))
  118. o:value("wan_114", translate("Use DNS from WAN and 114DNS"))
  119. o:value("114.114.114.114:53", translate("Nanjing Xinfeng 114DNS (114.114.114.114)"))
  120. o:value("119.29.29.29:53", translate("DNSPod Public DNS (119.29.29.29)"))
  121. o:value("223.5.5.5:53", translate("AliYun Public DNS (223.5.5.5)"))
  122. o:value("180.76.76.76:53", translate("Baidu Public DNS (180.76.76.76)"))
  123. o:value("101.226.4.6:53", translate("360 Security DNS (China Telecom) (101.226.4.6)"))
  124. o:value("123.125.81.6:53", translate("360 Security DNS (China Unicom) (123.125.81.6)"))
  125. o:value("1.2.4.8:53", translate("CNNIC SDNS (1.2.4.8)"))
  126. o:depends({pdnsd_enable = "1", run_mode = "router"})
  127. o:depends({pdnsd_enable = "2", run_mode = "router"})
  128. o.description = translate("Custom DNS Server format as IP:PORT (default: disabled)")
  129. o.validate = function(self, value, section)
  130. if (section and value) then
  131. if value == "wan" or value == "wan_114" then
  132. return value
  133. end
  134. if validation.ip4addrport(value) then
  135. return value
  136. end
  137. return nil, translate("Expecting: %s"):format(translate("valid address:port"))
  138. end
  139. return value
  140. end
  141. end
  142. return m