server.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package dns
  2. import (
  3. stdContext "context"
  4. "errors"
  5. "net"
  6. "github.com/metacubex/mihomo/common/sockopt"
  7. "github.com/metacubex/mihomo/context"
  8. "github.com/metacubex/mihomo/log"
  9. D "github.com/miekg/dns"
  10. )
  11. var (
  12. address string
  13. server = &Server{}
  14. dnsDefaultTTL uint32 = 600
  15. )
  16. type Server struct {
  17. *D.Server
  18. handler handler
  19. }
  20. // ServeDNS implement D.Handler ServeDNS
  21. func (s *Server) ServeDNS(w D.ResponseWriter, r *D.Msg) {
  22. msg, err := handlerWithContext(stdContext.Background(), s.handler, r)
  23. if err != nil {
  24. D.HandleFailed(w, r)
  25. return
  26. }
  27. msg.Compress = true
  28. w.WriteMsg(msg)
  29. }
  30. func handlerWithContext(stdCtx stdContext.Context, handler handler, msg *D.Msg) (*D.Msg, error) {
  31. if len(msg.Question) == 0 {
  32. return nil, errors.New("at least one question is required")
  33. }
  34. ctx := context.NewDNSContext(stdCtx, msg)
  35. return handler(ctx, msg)
  36. }
  37. func (s *Server) SetHandler(handler handler) {
  38. s.handler = handler
  39. }
  40. func ReCreateServer(addr string, resolver *Resolver, mapper *ResolverEnhancer) {
  41. UpdateIsolateHandler(resolver, mapper)
  42. if addr == address && resolver != nil {
  43. handler := NewHandler(resolver, mapper)
  44. server.SetHandler(handler)
  45. return
  46. }
  47. if server.Server != nil {
  48. server.Shutdown()
  49. server = &Server{}
  50. address = ""
  51. }
  52. if addr == "" {
  53. return
  54. }
  55. var err error
  56. defer func() {
  57. if err != nil {
  58. log.Errorln("Start DNS server error: %s", err.Error())
  59. }
  60. }()
  61. _, port, err := net.SplitHostPort(addr)
  62. if port == "0" || port == "" || err != nil {
  63. return
  64. }
  65. udpAddr, err := net.ResolveUDPAddr("udp", addr)
  66. if err != nil {
  67. return
  68. }
  69. p, err := net.ListenUDP("udp", udpAddr)
  70. if err != nil {
  71. return
  72. }
  73. err = sockopt.UDPReuseaddr(p)
  74. if err != nil {
  75. log.Warnln("Failed to Reuse UDP Address: %s", err)
  76. err = nil
  77. }
  78. address = addr
  79. handler := NewHandler(resolver, mapper)
  80. server = &Server{handler: handler}
  81. server.Server = &D.Server{Addr: addr, PacketConn: p, Handler: server}
  82. go func() {
  83. server.ActivateAndServe()
  84. }()
  85. log.Infoln("DNS server listening at: %s", p.LocalAddr().String())
  86. }