forked from knative/pkg
/
error_checks.go
70 lines (58 loc) · 2.15 KB
/
error_checks.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
Copyright 2019 The Knative Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// spoof contains logic to make polling HTTP requests against an endpoint with optional host spoofing.
package spoof
import (
"errors"
"net"
"net/http"
"strings"
)
func isTCPTimeout(err error) bool {
if err == nil {
return false
}
var errNet net.Error
if !errors.As(err, &errNet) {
return false
}
return errNet.Timeout()
}
func isDNSError(err error) bool {
if err == nil {
return false
}
// Checking by casting to url.Error and casting the nested error
// seems to be not as robust as string check.
msg := strings.ToLower(err.Error())
// Example error message:
// > Get http://this.url.does.not.exist: dial tcp: lookup this.url.does.not.exist on 127.0.0.1:53: no such host
return strings.Contains(msg, "no such host") || strings.Contains(msg, ":53")
}
func isConnectionRefused(err error) bool {
// The alternative for the string check is:
// errNo := (((err.(*url.Error)).Err.(*net.OpError)).Err.(*os.SyscallError).Err).(syscall.Errno)
// if errNo == syscall.Errno(0x6f) {...}
// But with assertions, of course.
return err != nil && strings.Contains(err.Error(), "connect: connection refused")
}
func isConnectionReset(err error) bool {
return err != nil && strings.Contains(err.Error(), "connection reset by peer")
}
func isNoRouteToHostError(err error) bool {
return err != nil && strings.Contains(err.Error(), "connect: no route to host")
}
func isResponseDNSError(resp *Response) bool {
// no such host with 502 is sent back from istio-ingressgateway when it fails to resolve domain.
return resp.StatusCode == http.StatusBadGateway && strings.Contains(string(resp.Body), "no such host")
}