mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-03 15:27:26 -08:00
feat(ipfy): add offline response
This commit is contained in:
parent
5f063e80f3
commit
e307b2f706
|
@ -587,6 +587,19 @@ func (env *ShellEnvironment) Shell() string {
|
||||||
return env.CmdFlags.Shell
|
return env.CmdFlags.Shell
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (env *ShellEnvironment) unWrapError(err error) error {
|
||||||
|
cause := err
|
||||||
|
for {
|
||||||
|
type nested interface{ Unwrap() error }
|
||||||
|
unwrap, ok := cause.(nested)
|
||||||
|
if !ok {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
cause = unwrap.Unwrap()
|
||||||
|
}
|
||||||
|
return cause
|
||||||
|
}
|
||||||
|
|
||||||
func (env *ShellEnvironment) HTTPRequest(targetURL string, body io.Reader, timeout int, requestModifiers ...HTTPRequestModifier) ([]byte, error) {
|
func (env *ShellEnvironment) HTTPRequest(targetURL string, body io.Reader, timeout int, requestModifiers ...HTTPRequestModifier) ([]byte, error) {
|
||||||
defer env.Trace(time.Now(), "HTTPRequest", targetURL)
|
defer env.Trace(time.Now(), "HTTPRequest", targetURL)
|
||||||
ctx, cncl := context.WithTimeout(context.Background(), time.Millisecond*time.Duration(timeout))
|
ctx, cncl := context.WithTimeout(context.Background(), time.Millisecond*time.Duration(timeout))
|
||||||
|
@ -605,7 +618,7 @@ func (env *ShellEnvironment) HTTPRequest(targetURL string, body io.Reader, timeo
|
||||||
response, err := client.Do(request)
|
response, err := client.Do(request)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
env.Log(Error, "HTTPRequest", err.Error())
|
env.Log(Error, "HTTPRequest", err.Error())
|
||||||
return nil, err
|
return nil, env.unWrapError(err)
|
||||||
}
|
}
|
||||||
// anything inside the range [200, 299] is considered a success
|
// anything inside the range [200, 299] is considered a success
|
||||||
if response.StatusCode < 200 || response.StatusCode >= 300 {
|
if response.StatusCode < 200 || response.StatusCode >= 300 {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package segments
|
package segments
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"net"
|
||||||
"oh-my-posh/environment"
|
"oh-my-posh/environment"
|
||||||
"oh-my-posh/properties"
|
"oh-my-posh/properties"
|
||||||
)
|
)
|
||||||
|
@ -13,6 +14,8 @@ type IPify struct {
|
||||||
|
|
||||||
const (
|
const (
|
||||||
IpifyURL properties.Property = "url"
|
IpifyURL properties.Property = "url"
|
||||||
|
|
||||||
|
OFFLINE = "OFFLINE"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (i *IPify) Template() string {
|
func (i *IPify) Template() string {
|
||||||
|
@ -46,6 +49,9 @@ func (i *IPify) getResult() (string, error) {
|
||||||
httpTimeout := i.props.GetInt(properties.HTTPTimeout, properties.DefaultHTTPTimeout)
|
httpTimeout := i.props.GetInt(properties.HTTPTimeout, properties.DefaultHTTPTimeout)
|
||||||
|
|
||||||
body, err := i.env.HTTPRequest(url, nil, httpTimeout)
|
body, err := i.env.HTTPRequest(url, nil, httpTimeout)
|
||||||
|
if dnsErr, OK := err.(*net.DNSError); OK && dnsErr.IsNotFound {
|
||||||
|
return OFFLINE, nil
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package segments
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"net"
|
||||||
"oh-my-posh/mock"
|
"oh-my-posh/mock"
|
||||||
"oh-my-posh/properties"
|
"oh-my-posh/properties"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -36,11 +37,18 @@ func TestIpifySegment(t *testing.T) {
|
||||||
Template: "Ext. IP: {{.IP}}",
|
Template: "Ext. IP: {{.IP}}",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Case: "Error in retrieving data",
|
Case: "Network Error",
|
||||||
Response: "nonsense",
|
Response: "nonsense",
|
||||||
Error: errors.New("Something went wrong"),
|
ExpectedString: "",
|
||||||
|
Error: errors.New("network is unreachable"),
|
||||||
ExpectedEnabled: false,
|
ExpectedEnabled: false,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Case: "Offline",
|
||||||
|
ExpectedString: OFFLINE,
|
||||||
|
Error: &net.DNSError{IsNotFound: true},
|
||||||
|
ExpectedEnabled: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range cases {
|
for _, tc := range cases {
|
||||||
|
|
Loading…
Reference in a new issue