mirror of
https://github.com/taigrr/godns
synced 2025-01-18 04:03:25 -08:00
refactor handlers
This commit is contained in:
parent
7720a92ad6
commit
025a5c0bbb
@ -12,7 +12,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/TimothyYe/godns"
|
"github.com/TimothyYe/godns"
|
||||||
"golang.org/x/net/proxy"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Handler struct definition
|
// Handler struct definition
|
||||||
@ -139,18 +138,9 @@ func recordTracked(domain *godns.Domain, record *DNSRecord) bool {
|
|||||||
|
|
||||||
// Create a new request with auth in place and optional proxy
|
// Create a new request with auth in place and optional proxy
|
||||||
func (handler *Handler) newRequest(method, url string, body io.Reader) (*http.Request, *http.Client) {
|
func (handler *Handler) newRequest(method, url string, body io.Reader) (*http.Request, *http.Client) {
|
||||||
client := &http.Client{}
|
client := godns.GetHttpClient(handler.Configuration)
|
||||||
|
if client == nil {
|
||||||
if handler.Configuration.Socks5Proxy != "" {
|
log.Println("cannot create HTTP client")
|
||||||
log.Println("use socks5 proxy:" + handler.Configuration.Socks5Proxy)
|
|
||||||
dialer, err := proxy.SOCKS5("tcp", handler.Configuration.Socks5Proxy, nil, proxy.Direct)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("can't connect to the proxy:", err)
|
|
||||||
} else {
|
|
||||||
httpTransport := &http.Transport{}
|
|
||||||
client.Transport = httpTransport
|
|
||||||
httpTransport.Dial = dialer.Dial
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
req, _ := http.NewRequest(method, handler.API+url, body)
|
req, _ := http.NewRequest(method, handler.API+url, body)
|
||||||
|
@ -2,6 +2,7 @@ package dnspod
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
@ -14,7 +15,6 @@ import (
|
|||||||
|
|
||||||
"github.com/TimothyYe/godns"
|
"github.com/TimothyYe/godns"
|
||||||
simplejson "github.com/bitly/go-simplejson"
|
simplejson "github.com/bitly/go-simplejson"
|
||||||
"golang.org/x/net/proxy"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Handler struct definition
|
// Handler struct definition
|
||||||
@ -239,21 +239,10 @@ func (handler *Handler) UpdateIP(domainID int64, subDomainID string, subDomainNa
|
|||||||
|
|
||||||
// PostData post data and invoke DNSPod API
|
// PostData post data and invoke DNSPod API
|
||||||
func (handler *Handler) PostData(url string, content url.Values) (string, error) {
|
func (handler *Handler) PostData(url string, content url.Values) (string, error) {
|
||||||
client := &http.Client{}
|
client := godns.GetHttpClient(handler.Configuration)
|
||||||
|
|
||||||
if handler.Configuration.Socks5Proxy != "" {
|
if client == nil {
|
||||||
|
return "", errors.New("failed to create HTTP client")
|
||||||
log.Println("use socks5 proxy:" + handler.Configuration.Socks5Proxy)
|
|
||||||
|
|
||||||
dialer, err := proxy.SOCKS5("tcp", handler.Configuration.Socks5Proxy, nil, proxy.Direct)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("can't connect to the proxy:", err)
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
httpTransport := &http.Transport{}
|
|
||||||
client.Transport = httpTransport
|
|
||||||
httpTransport.Dial = dialer.Dial
|
|
||||||
}
|
}
|
||||||
|
|
||||||
values := handler.GenerateHeader(content)
|
values := handler.GenerateHeader(content)
|
||||||
|
@ -4,12 +4,10 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
|
||||||
"runtime/debug"
|
"runtime/debug"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/TimothyYe/godns"
|
"github.com/TimothyYe/godns"
|
||||||
"golang.org/x/net/proxy"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -52,20 +50,7 @@ func (handler *Handler) DomainLoop(domain *godns.Domain, panicChan chan<- godns.
|
|||||||
log.Printf("IP is the same as cached one. Skip update.\n")
|
log.Printf("IP is the same as cached one. Skip update.\n")
|
||||||
} else {
|
} else {
|
||||||
lastIP = currentIP
|
lastIP = currentIP
|
||||||
client := &http.Client{}
|
client := godns.GetHttpClient(handler.Configuration)
|
||||||
|
|
||||||
if handler.Configuration.Socks5Proxy != "" {
|
|
||||||
log.Println("use socks5 proxy:" + handler.Configuration.Socks5Proxy)
|
|
||||||
dialer, err := proxy.SOCKS5("tcp", handler.Configuration.Socks5Proxy, nil, proxy.Direct)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("can't connect to the proxy:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
httpTransport := &http.Transport{}
|
|
||||||
client.Transport = httpTransport
|
|
||||||
httpTransport.Dial = dialer.Dial
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, subDomain := range domain.SubDomains {
|
for _, subDomain := range domain.SubDomains {
|
||||||
// update IP with HTTP GET request
|
// update IP with HTTP GET request
|
||||||
|
@ -11,8 +11,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/TimothyYe/godns"
|
"github.com/TimothyYe/godns"
|
||||||
|
|
||||||
"golang.org/x/net/proxy"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -83,20 +81,7 @@ func (handler *Handler) UpdateIP(domain, subDomain, currentIP string) {
|
|||||||
values.Add("username:password", fmt.Sprintf("%s:%s", handler.Configuration.Email, handler.Configuration.Password))
|
values.Add("username:password", fmt.Sprintf("%s:%s", handler.Configuration.Email, handler.Configuration.Password))
|
||||||
values.Add("myip", currentIP)
|
values.Add("myip", currentIP)
|
||||||
|
|
||||||
client := &http.Client{}
|
client := godns.GetHttpClient(handler.Configuration)
|
||||||
|
|
||||||
if handler.Configuration.Socks5Proxy != "" {
|
|
||||||
log.Println("use socks5 proxy:" + handler.Configuration.Socks5Proxy)
|
|
||||||
dialer, err := proxy.SOCKS5("tcp", handler.Configuration.Socks5Proxy, nil, proxy.Direct)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("can't connect to the proxy:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
httpTransport := &http.Transport{}
|
|
||||||
client.Transport = httpTransport
|
|
||||||
httpTransport.Dial = dialer.Dial
|
|
||||||
}
|
|
||||||
|
|
||||||
req, _ := http.NewRequest("POST", GoogleUrl, strings.NewReader(values.Encode()))
|
req, _ := http.NewRequest("POST", GoogleUrl, strings.NewReader(values.Encode()))
|
||||||
resp, err := client.Do(req)
|
resp, err := client.Do(req)
|
||||||
|
@ -11,8 +11,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/TimothyYe/godns"
|
"github.com/TimothyYe/godns"
|
||||||
|
|
||||||
"golang.org/x/net/proxy"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -82,20 +80,7 @@ func (handler *Handler) UpdateIP(domain, subDomain, currentIP string) {
|
|||||||
values.Add("password", handler.Configuration.Password)
|
values.Add("password", handler.Configuration.Password)
|
||||||
values.Add("myip", currentIP)
|
values.Add("myip", currentIP)
|
||||||
|
|
||||||
client := &http.Client{}
|
client := godns.GetHttpClient(handler.Configuration)
|
||||||
|
|
||||||
if handler.Configuration.Socks5Proxy != "" {
|
|
||||||
log.Println("use socks5 proxy:" + handler.Configuration.Socks5Proxy)
|
|
||||||
dialer, err := proxy.SOCKS5("tcp", handler.Configuration.Socks5Proxy, nil, proxy.Direct)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("can't connect to the proxy:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
httpTransport := &http.Transport{}
|
|
||||||
client.Transport = httpTransport
|
|
||||||
httpTransport.Dial = dialer.Dial
|
|
||||||
}
|
|
||||||
|
|
||||||
req, _ := http.NewRequest("POST", HEUrl, strings.NewReader(values.Encode()))
|
req, _ := http.NewRequest("POST", HEUrl, strings.NewReader(values.Encode()))
|
||||||
resp, err := client.Do(req)
|
resp, err := client.Do(req)
|
||||||
|
20
utils.go
20
utils.go
@ -109,6 +109,26 @@ func isIPv4(ip string) bool {
|
|||||||
return strings.Count(ip, ":") < 2
|
return strings.Count(ip, ":") < 2
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetHttpClient creates the HTTP client and return it
|
||||||
|
func GetHttpClient(configuration *Settings) *http.Client {
|
||||||
|
client := &http.Client{}
|
||||||
|
|
||||||
|
if configuration.Socks5Proxy != "" {
|
||||||
|
log.Println("use socks5 proxy:" + configuration.Socks5Proxy)
|
||||||
|
dialer, err := proxy.SOCKS5("tcp", configuration.Socks5Proxy, nil, proxy.Direct)
|
||||||
|
if err != nil {
|
||||||
|
log.Println("can't connect to the proxy:", err)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
httpTransport := &http.Transport{}
|
||||||
|
client.Transport = httpTransport
|
||||||
|
httpTransport.Dial = dialer.Dial
|
||||||
|
}
|
||||||
|
|
||||||
|
return client
|
||||||
|
}
|
||||||
|
|
||||||
//GetCurrentIP gets an IP from either internet or specific interface, depending on configuration
|
//GetCurrentIP gets an IP from either internet or specific interface, depending on configuration
|
||||||
func GetCurrentIP(configuration *Settings) (string, error) {
|
func GetCurrentIP(configuration *Settings) (string, error) {
|
||||||
var err error
|
var err error
|
||||||
|
Loading…
x
Reference in New Issue
Block a user