style: improve code of http client init
This commit is contained in:
@@ -4,13 +4,12 @@ import (
|
||||
"crypto/tls"
|
||||
"github.com/Mmx233/BitSrunLoginGo/internal/config"
|
||||
"github.com/Mmx233/BitSrunLoginGo/tools"
|
||||
"github.com/Mmx233/tool"
|
||||
"net"
|
||||
"net/http"
|
||||
"syscall"
|
||||
)
|
||||
|
||||
func genHttpPack(eth *tools.Eth) *Http {
|
||||
func CreateClientFromEth(eth *tools.Eth) *http.Client {
|
||||
dialer := net.Dialer{
|
||||
Timeout: config.Timeout,
|
||||
}
|
||||
@@ -18,31 +17,28 @@ func genHttpPack(eth *tools.Eth) *Http {
|
||||
dialer.LocalAddr = eth.Addr
|
||||
ethName := eth.Name
|
||||
dialer.Control = func(network string, address string, c syscall.RawConn) error {
|
||||
var operr error
|
||||
var opErr error
|
||||
fn := func(fd uintptr) {
|
||||
operr = syscall.SetsockoptString(int(fd), syscall.SOL_SOCKET, syscall.SO_BINDTODEVICE, ethName)
|
||||
opErr = syscall.SetsockoptString(int(fd), syscall.SOL_SOCKET, syscall.SO_BINDTODEVICE, ethName)
|
||||
}
|
||||
if err := c.Control(fn); err != nil {
|
||||
return err
|
||||
}
|
||||
if operr != nil {
|
||||
return operr
|
||||
if opErr != nil {
|
||||
return opErr
|
||||
}
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
tr := &http.Transport{
|
||||
DialContext: dialer.DialContext,
|
||||
TLSHandshakeTimeout: config.Timeout,
|
||||
IdleConnTimeout: config.Timeout,
|
||||
TLSClientConfig: &tls.Config{InsecureSkipVerify: config.Settings.Basic.SkipCertVerify},
|
||||
}
|
||||
tr.Proxy = http.ProxyFromEnvironment
|
||||
return &Http{
|
||||
Client: tool.GenHttpClient(&tool.HttpClientOptions{
|
||||
Transport: tr,
|
||||
Timeout: config.Timeout,
|
||||
}),
|
||||
return &http.Client{
|
||||
Transport: &http.Transport{
|
||||
DialContext: dialer.DialContext,
|
||||
TLSHandshakeTimeout: config.Timeout,
|
||||
IdleConnTimeout: config.Timeout,
|
||||
TLSClientConfig: &tls.Config{InsecureSkipVerify: config.Settings.Basic.SkipCertVerify},
|
||||
Proxy: http.ProxyFromEnvironment,
|
||||
},
|
||||
Timeout: config.Timeout,
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user