ip/resolver: move services that just parses the ip from a http response to use basic_http service instead.
This commit is contained in:
parent
2ddf2dadd7
commit
ab15df5258
7 changed files with 20 additions and 221 deletions
|
|
@ -1,39 +0,0 @@
|
||||||
package ifconfigme
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Service struct {
|
|
||||||
url string
|
|
||||||
}
|
|
||||||
|
|
||||||
func New() *Service {
|
|
||||||
return &Service{
|
|
||||||
url: "https://ifconfig.me/ip",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Name() string {
|
|
||||||
return "ifconfig.me"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Lookup() (net.IP, error) {
|
|
||||||
resp, err := http.DefaultClient.Get(s.url)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
body, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Trim spaces and stuff.
|
|
||||||
ip_str := strings.TrimSpace(string(body))
|
|
||||||
|
|
||||||
return net.ParseIP(ip_str), err
|
|
||||||
}
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
||||||
package ifconfigme
|
|
||||||
|
|
||||||
import (
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
"net/http/httptest"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestService_Name(t *testing.T) {
|
|
||||||
s := Service{}
|
|
||||||
|
|
||||||
assert.Equal(t, "ifconfig.me", s.Name())
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestService_Lookup(t *testing.T) {
|
|
||||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
_, err := w.Write([]byte("113.145.244.129"))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
}))
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
s := Service{url: server.URL}
|
|
||||||
|
|
||||||
ip, err := s.Lookup()
|
|
||||||
assert.NoError(t, err)
|
|
||||||
|
|
||||||
assert.Equal(t, net.IPv4(113, 145, 244, 129), ip)
|
|
||||||
}
|
|
||||||
|
|
@ -1,35 +0,0 @@
|
||||||
package ipecho
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Service struct {
|
|
||||||
url string
|
|
||||||
}
|
|
||||||
|
|
||||||
func New() *Service {
|
|
||||||
return &Service{
|
|
||||||
url: "http://ipecho.net/plain",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Name() string {
|
|
||||||
return "ipecho"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Lookup() (net.IP, error) {
|
|
||||||
resp, err := http.DefaultClient.Get(s.url)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
body, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return net.ParseIP(string(body)), nil
|
|
||||||
}
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
||||||
package ipecho
|
|
||||||
|
|
||||||
import (
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
"net/http/httptest"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestService_Name(t *testing.T) {
|
|
||||||
s := Service{}
|
|
||||||
|
|
||||||
assert.Equal(t, "ipecho", s.Name())
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestService_Lookup(t *testing.T) {
|
|
||||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
_, err := w.Write([]byte("188.242.103.22"))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
}))
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
s := Service{url: server.URL}
|
|
||||||
|
|
||||||
ip, err := s.Lookup()
|
|
||||||
assert.NoError(t, err)
|
|
||||||
|
|
||||||
assert.Equal(t, net.IPv4(188, 242, 103, 22), ip)
|
|
||||||
}
|
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
package ipme
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Service struct {
|
|
||||||
url string
|
|
||||||
}
|
|
||||||
|
|
||||||
func New() *Service {
|
|
||||||
return &Service{
|
|
||||||
url: "https://ip.me",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Name() string {
|
|
||||||
return "ip.me"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s Service) Lookup() (net.IP, error) {
|
|
||||||
req, err := http.NewRequest("GET", s.url, nil)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
req.Header.Add("User-Agent", "curl")
|
|
||||||
|
|
||||||
resp, err := http.DefaultClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
body, err := io.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Trim spaces and stuff.
|
|
||||||
ip_str := strings.TrimSpace(string(body))
|
|
||||||
|
|
||||||
return net.ParseIP(ip_str), err
|
|
||||||
}
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
package ipme
|
|
||||||
|
|
||||||
import (
|
|
||||||
"net"
|
|
||||||
"net/http"
|
|
||||||
"net/http/httptest"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestService_Name(t *testing.T) {
|
|
||||||
s := Service{}
|
|
||||||
|
|
||||||
assert.Equal(t, "ip.me", s.Name())
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestService_Lookup(t *testing.T) {
|
|
||||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
assert.Equal(t, "curl", r.Header.Get("User-Agent"))
|
|
||||||
|
|
||||||
_, err := w.Write([]byte("255.240.85.2"))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
}))
|
|
||||||
defer server.Close()
|
|
||||||
|
|
||||||
s := Service{url: server.URL}
|
|
||||||
|
|
||||||
ip, err := s.Lookup()
|
|
||||||
assert.NoError(t, err)
|
|
||||||
|
|
||||||
assert.Equal(t, net.IPv4(255, 240, 85, 2), ip)
|
|
||||||
}
|
|
||||||
|
|
@ -3,10 +3,9 @@ package lookup
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"net"
|
"net"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
"dnsupdater/ip/resolver/ifconfigme"
|
"dnsupdater/ip/resolver/basic_http"
|
||||||
"dnsupdater/ip/resolver/ipecho"
|
|
||||||
"dnsupdater/ip/resolver/ipme"
|
|
||||||
"dnsupdater/ip/resolver/jsonip"
|
"dnsupdater/ip/resolver/jsonip"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -39,7 +38,22 @@ func Lookup() (net.IP, error) {
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
Provide(jsonip.New())
|
Provide(jsonip.New())
|
||||||
Provide(ifconfigme.New())
|
|
||||||
Provide(ipme.New())
|
Provide(&basic_http.Service{
|
||||||
Provide(ipecho.New())
|
ServiceName: "ifconfig.me",
|
||||||
|
Url: "https://ifconfig.me/ip",
|
||||||
|
})
|
||||||
|
|
||||||
|
Provide(&basic_http.Service{
|
||||||
|
ServiceName: "ip.me",
|
||||||
|
Url: "https://ip.me",
|
||||||
|
Headers: http.Header{
|
||||||
|
"User-Agent": []string{"curl"},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
Provide(&basic_http.Service{
|
||||||
|
ServiceName: "ipecho",
|
||||||
|
Url: "http://ipecho.net/plain",
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue