24
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								README.md
									
									
									
									
									
								
							| @ -40,7 +40,8 @@ core applications: https://status.twinnation.org/ | ||||
|   - [Recommended interval](#recommended-interval) | ||||
|   - [Default timeouts](#default-timeouts) | ||||
|   - [Monitoring a TCP service](#monitoring-a-tcp-service) | ||||
|   - [Monitoring using DNS queries](#monitoring-using-dns-queries) | ||||
|   - [Monitoring a service using ICMP](#monitoring-a-service-using-icmp) | ||||
|   - [Monitoring a service using DNS queries](#monitoring-a-service-using-dns-queries) | ||||
|   - [Basic authentication](#basic-authentication) | ||||
|   - [disable-monitoring-lock](#disable-monitoring-lock) | ||||
|   - [Service groups](#service-groups) | ||||
| @ -557,6 +558,7 @@ simple health checks used for alerting (PagerDuty/Twilio) to `30s`. | ||||
| By prefixing `services[].url` with `tcp:\\`, you can monitor TCP services at a very basic level: | ||||
|  | ||||
| ```yaml | ||||
| services: | ||||
|   - name: redis | ||||
|     url: "tcp://127.0.0.1:6379" | ||||
|     interval: 30s | ||||
| @ -572,10 +574,28 @@ something at the given address listening to the given port, and that a connectio | ||||
| established. | ||||
|  | ||||
|  | ||||
| ### Monitoring using DNS queries | ||||
| ### Monitoring a service using ICMP | ||||
|  | ||||
| By prefixing `services[].url` with `icmp:\\`, you can monitor services at a very basic level using ICMP, or more  | ||||
| commonly known as "ping" or "echo": | ||||
|  | ||||
| ```yaml | ||||
| services: | ||||
|   - name: ICMP | ||||
|     url: "icmp://example.com" | ||||
|     conditions: | ||||
|       - "[CONNECTED] == true" | ||||
| ``` | ||||
|  | ||||
| Only the placeholders `[CONNECTED]`, `[IP]` and `[RESPONSE_TIME]` are supported for services of type ICMP. | ||||
| You can specify a domain prefixed by `icmp://` or an IP address. | ||||
|  | ||||
|  | ||||
| ### Monitoring a service using DNS queries | ||||
|  | ||||
| Defining a `dns` configuration in a service will automatically mark that service as a service of type DNS: | ||||
| ```yaml | ||||
| services: | ||||
|   - name: example dns query | ||||
|     url: "8.8.8.8" # Address of the DNS server to use | ||||
|     interval: 30s | ||||
|  | ||||
| @ -5,6 +5,8 @@ import ( | ||||
| 	"net" | ||||
| 	"net/http" | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/go-ping/ping" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @ -31,7 +33,7 @@ func GetHTTPClient(insecure bool) *http.Client { | ||||
| 	} | ||||
| 	if secureHTTPClient == nil { | ||||
| 		secureHTTPClient = &http.Client{ | ||||
| 			Timeout: time.Second * 10, | ||||
| 			Timeout: 10 * time.Second, | ||||
| 			Transport: &http.Transport{ | ||||
| 				MaxIdleConns:        100, | ||||
| 				MaxIdleConnsPerHost: 20, | ||||
| @ -41,8 +43,8 @@ func GetHTTPClient(insecure bool) *http.Client { | ||||
| 	return secureHTTPClient | ||||
| } | ||||
|  | ||||
| // CanCreateConnectionToTCPService checks whether a connection can be established with a TCP service | ||||
| func CanCreateConnectionToTCPService(address string) bool { | ||||
| // CanCreateTCPConnection checks whether a connection can be established with a TCP service | ||||
| func CanCreateTCPConnection(address string) bool { | ||||
| 	conn, err := net.DialTimeout("tcp", address, 5*time.Second) | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| @ -50,3 +52,21 @@ func CanCreateConnectionToTCPService(address string) bool { | ||||
| 	_ = conn.Close() | ||||
| 	return true | ||||
| } | ||||
|  | ||||
| // CanPing checks if an address can be pinged | ||||
| // Note that this function takes at least 100ms, even if the address is 127.0.0.1 | ||||
| func CanPing(address string) bool { | ||||
| 	pinger, err := ping.NewPinger(address) | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	pinger.Count = 1 | ||||
| 	pinger.Timeout = 5 * time.Second | ||||
| 	pinger.SetNetwork("ip4") | ||||
| 	pinger.SetPrivileged(true) | ||||
| 	err = pinger.Run() | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	return true | ||||
| } | ||||
|  | ||||
| @ -26,3 +26,12 @@ func TestGetHttpClient(t *testing.T) { | ||||
| 		t.Error("insecureHTTPClient shouldn't have been nil, since it has been called once") | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCanPing(t *testing.T) { | ||||
| 	if !CanPing("127.0.0.1") { | ||||
| 		t.Error("expected true") | ||||
| 	} | ||||
| 	if CanPing("256.256.256.256") { | ||||
| 		t.Error("expected false") | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -182,9 +182,10 @@ func (service *Service) call(result *Result) { | ||||
| 	var request *http.Request | ||||
| 	var response *http.Response | ||||
| 	var err error | ||||
| 	isServiceTCP := strings.HasPrefix(service.URL, "tcp://") | ||||
| 	isServiceDNS := service.DNS != nil | ||||
| 	isServiceHTTP := !isServiceTCP && !isServiceDNS | ||||
| 	isServiceTCP := strings.HasPrefix(service.URL, "tcp://") | ||||
| 	isServiceICMP := strings.HasPrefix(service.URL, "icmp://") | ||||
| 	isServiceHTTP := !isServiceDNS && !isServiceTCP && !isServiceICMP | ||||
| 	if isServiceHTTP { | ||||
| 		request = service.buildHTTPRequest() | ||||
| 	} | ||||
| @ -193,7 +194,10 @@ func (service *Service) call(result *Result) { | ||||
| 		service.DNS.query(service.URL, result) | ||||
| 		result.Duration = time.Since(startTime) | ||||
| 	} else if isServiceTCP { | ||||
| 		result.Connected = client.CanCreateConnectionToTCPService(strings.TrimPrefix(service.URL, "tcp://")) | ||||
| 		result.Connected = client.CanCreateTCPConnection(strings.TrimPrefix(service.URL, "tcp://")) | ||||
| 		result.Duration = time.Since(startTime) | ||||
| 	} else if isServiceICMP { | ||||
| 		//result.Connected = client.CanPing(strings.TrimPrefix(service.URL, "icmp://")) | ||||
| 		result.Duration = time.Since(startTime) | ||||
| 	} else { | ||||
| 		response, err = client.GetHTTPClient(service.Insecure).Do(request) | ||||
|  | ||||
| @ -203,6 +203,25 @@ func TestIntegrationEvaluateHealth(t *testing.T) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestIntegrationEvaluateHealthWithFailure(t *testing.T) { | ||||
| 	condition := Condition("[STATUS] == 500") | ||||
| 	service := Service{ | ||||
| 		Name:       "TwiNNatioN", | ||||
| 		URL:        "https://twinnation.org/health", | ||||
| 		Conditions: []*Condition{&condition}, | ||||
| 	} | ||||
| 	result := service.EvaluateHealth() | ||||
| 	if result.ConditionResults[0].Success { | ||||
| 		t.Errorf("Condition '%s' should have been a failure", condition) | ||||
| 	} | ||||
| 	if !result.Connected { | ||||
| 		t.Error("Because the connection has been established, result.Connected should've been true") | ||||
| 	} | ||||
| 	if result.Success { | ||||
| 		t.Error("Because one of the conditions failed, success should have been false") | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestIntegrationEvaluateHealthForDNS(t *testing.T) { | ||||
| 	conditionSuccess := Condition("[DNS_RCODE] == NOERROR") | ||||
| 	conditionBody := Condition("[BODY] == 93.184.216.34") | ||||
| @ -227,21 +246,21 @@ func TestIntegrationEvaluateHealthForDNS(t *testing.T) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestIntegrationEvaluateHealthWithFailure(t *testing.T) { | ||||
| 	condition := Condition("[STATUS] == 500") | ||||
| func TestIntegrationEvaluateHealthForICMP(t *testing.T) { | ||||
| 	conditionSuccess := Condition("[CONNECTED] == true") | ||||
| 	service := Service{ | ||||
| 		Name:       "TwiNNatioN", | ||||
| 		URL:        "https://twinnation.org/health", | ||||
| 		Conditions: []*Condition{&condition}, | ||||
| 		Name:       "Google", | ||||
| 		URL:        "icmp://google.com", | ||||
| 		Conditions: []*Condition{&conditionSuccess}, | ||||
| 	} | ||||
| 	result := service.EvaluateHealth() | ||||
| 	if result.ConditionResults[0].Success { | ||||
| 		t.Errorf("Condition '%s' should have been a failure", condition) | ||||
| 	if !result.ConditionResults[0].Success { | ||||
| 		t.Errorf("Conditions '%s' should have been a success", conditionSuccess) | ||||
| 	} | ||||
| 	if !result.Connected { | ||||
| 		t.Error("Because the connection has been established, result.Connected should've been true") | ||||
| 	} | ||||
| 	if result.Success { | ||||
| 		t.Error("Because one of the conditions failed, success should have been false") | ||||
| 	if !result.Success { | ||||
| 		t.Error("Because all conditions passed, this should have been a success") | ||||
| 	} | ||||
| } | ||||
|  | ||||
							
								
								
									
										28
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								go.mod
									
									
									
									
									
								
							| @ -3,19 +3,23 @@ module github.com/TwinProduction/gatus | ||||
| go 1.15 | ||||
|  | ||||
| require ( | ||||
| 	cloud.google.com/go v0.74.0 // indirect | ||||
| 	github.com/go-logr/logr v0.3.0 // indirect | ||||
| 	github.com/go-ping/ping v0.0.0-20201115131931-3300c582a663 | ||||
| 	github.com/google/gofuzz v1.2.0 // indirect | ||||
| 	github.com/googleapis/gnostic v0.5.3 // indirect | ||||
| 	github.com/imdario/mergo v0.3.11 // indirect | ||||
| 	github.com/miekg/dns v1.1.35 | ||||
| 	github.com/prometheus/client_golang v1.7.1 | ||||
| 	github.com/prometheus/common v0.13.0 // indirect | ||||
| 	golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f // indirect | ||||
| 	golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 // indirect | ||||
| 	google.golang.org/protobuf v1.25.0 // indirect | ||||
| 	gopkg.in/inf.v0 v0.9.1 // indirect | ||||
| 	gopkg.in/yaml.v2 v2.3.0 | ||||
| 	k8s.io/api v0.0.0-20190816222004-e3a6b8045b0b | ||||
| 	k8s.io/apimachinery v0.0.0-20190816221834-a9f1d8a9c101 | ||||
| 	k8s.io/client-go v11.0.1-0.20190918222721-c0e3722d5cf0+incompatible | ||||
| 	k8s.io/klog v1.0.0 // indirect | ||||
| 	k8s.io/utils v0.0.0-20201027101359-01387209bb0d // indirect | ||||
| 	github.com/prometheus/client_golang v1.9.0 | ||||
| 	golang.org/x/crypto v0.0.0-20201221181555-eec23a3978ad // indirect | ||||
| 	golang.org/x/net v0.0.0-20201224014010-6772e930b67b | ||||
| 	golang.org/x/sys v0.0.0-20201223074533-0d417f636930 // indirect | ||||
| 	golang.org/x/term v0.0.0-20201210144234-2321bbc49cbf // indirect | ||||
| 	golang.org/x/time v0.0.0-20201208040808-7e3f01d25324 // indirect | ||||
| 	gopkg.in/yaml.v2 v2.4.0 | ||||
| 	k8s.io/api v0.19.6 | ||||
| 	k8s.io/apimachinery v0.19.6 | ||||
| 	k8s.io/client-go v0.19.6 | ||||
| ) | ||||
|  | ||||
| replace k8s.io/client-go => k8s.io/client-go v0.19.6 | ||||
|  | ||||
							
								
								
									
										395
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										395
									
								
								go.sum
									
									
									
									
									
								
							| @ -1,8 +1,58 @@ | ||||
| cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= | ||||
| cloud.google.com/go v0.34.0 h1:eOI3/cP2VTU6uZLDYAoic+eyzzB9YyGmJ7eIjl8rOPg= | ||||
| cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw= | ||||
| cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU= | ||||
| cloud.google.com/go v0.44.1/go.mod h1:iSa0KzasP4Uvy3f1mN/7PiObzGgflwredwwASm/v6AU= | ||||
| cloud.google.com/go v0.44.2/go.mod h1:60680Gw3Yr4ikxnPRS/oxxkBccT6SA1yMk63TGekxKY= | ||||
| cloud.google.com/go v0.45.1/go.mod h1:RpBamKRgapWJb87xiFSdk4g1CME7QZg3uwTez+TSTjc= | ||||
| cloud.google.com/go v0.46.3/go.mod h1:a6bKKbmY7er1mI7TEI4lsAkts/mkhTSZK8w33B4RAg0= | ||||
| cloud.google.com/go v0.50.0/go.mod h1:r9sluTvynVuxRIOHXQEHMFffphuXHOMZMycpNR5e6To= | ||||
| cloud.google.com/go v0.51.0/go.mod h1:hWtGJ6gnXH+KgDv+V0zFGDvpi07n3z8ZNj3T1RW0Gcw= | ||||
| cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4= | ||||
| cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M= | ||||
| cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc= | ||||
| cloud.google.com/go v0.56.0/go.mod h1:jr7tqZxxKOVYizybht9+26Z/gUq7tiRzu+ACVAMbKVk= | ||||
| cloud.google.com/go v0.57.0/go.mod h1:oXiQ6Rzq3RAkkY7N6t3TcE6jE+CIBBbA36lwQ1JyzZs= | ||||
| cloud.google.com/go v0.62.0/go.mod h1:jmCYTdRCQuc1PHIIJ/maLInMho30T/Y0M4hTdTShOYc= | ||||
| cloud.google.com/go v0.65.0/go.mod h1:O5N8zS7uWy9vkA9vayVHs65eM1ubvY4h553ofrNHObY= | ||||
| cloud.google.com/go v0.72.0/go.mod h1:M+5Vjvlc2wnp6tjzE102Dw08nGShTscUx2nZMufOKPI= | ||||
| cloud.google.com/go v0.74.0 h1:kpgPA77kSSbjSs+fWHkPTxQ6J5Z2Qkruo5jfXEkHxNQ= | ||||
| cloud.google.com/go v0.74.0/go.mod h1:VV1xSbzvo+9QJOxLDaJfTjx5e+MePCpCWwvftOeQmWk= | ||||
| cloud.google.com/go/bigquery v1.0.1/go.mod h1:i/xbL2UlR5RvWAURpBYZTtm/cXjCha9lbfbpx4poX+o= | ||||
| cloud.google.com/go/bigquery v1.3.0/go.mod h1:PjpwJnslEMmckchkHFfq+HTD2DmtT67aNFKH1/VBDHE= | ||||
| cloud.google.com/go/bigquery v1.4.0/go.mod h1:S8dzgnTigyfTmLBfrtrhyYhwRxG72rYxvftPBK2Dvzc= | ||||
| cloud.google.com/go/bigquery v1.5.0/go.mod h1:snEHRnqQbz117VIFhE8bmtwIDY80NLUZUMb4Nv6dBIg= | ||||
| cloud.google.com/go/bigquery v1.7.0/go.mod h1://okPTzCYNXSlb24MZs83e2Do+h+VXtc4gLoIoXIAPc= | ||||
| cloud.google.com/go/bigquery v1.8.0/go.mod h1:J5hqkt3O0uAFnINi6JXValWIb1v0goeZM77hZzJN/fQ= | ||||
| cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= | ||||
| cloud.google.com/go/datastore v1.1.0/go.mod h1:umbIZjpQpHh4hmRpGhH4tLFup+FVzqBi1b3c64qFpCk= | ||||
| cloud.google.com/go/pubsub v1.0.1/go.mod h1:R0Gpsv3s54REJCy4fxDixWD93lHJMoZTyQ2kNxGRt3I= | ||||
| cloud.google.com/go/pubsub v1.1.0/go.mod h1:EwwdRX2sKPjnvnqCa270oGRyludottCI76h+R3AArQw= | ||||
| cloud.google.com/go/pubsub v1.2.0/go.mod h1:jhfEVHT8odbXTkndysNHCcx0awwzvfOlguIAii9o8iA= | ||||
| cloud.google.com/go/pubsub v1.3.1/go.mod h1:i+ucay31+CNRpDW4Lu78I4xXG+O1r/MAHgjpRVR+TSU= | ||||
| cloud.google.com/go/storage v1.0.0/go.mod h1:IhtSnM/ZTZV8YYJWCY8RULGVqBDmpoyjwiyrjsg+URw= | ||||
| cloud.google.com/go/storage v1.5.0/go.mod h1:tpKbwo567HUNpVclU5sGELwQWBDZ8gh0ZeosJ0Rtdos= | ||||
| cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohlUTyfDhBk= | ||||
| cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs= | ||||
| cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0= | ||||
| dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= | ||||
| github.com/Azure/go-autorest/autorest v0.9.0/go.mod h1:xyHB1BMZT0cuDHU7I0+g046+BFDTQ8rEZB0s4Yfa6bI= | ||||
| github.com/Azure/go-autorest/autorest v0.9.6/go.mod h1:/FALq9T/kS7b5J5qsQ+RSTUdAmGFqi0vUdVNNx8q630= | ||||
| github.com/Azure/go-autorest/autorest/adal v0.5.0/go.mod h1:8Z9fGy2MpX0PvDjB1pEgQTmVqjGhiHBW7RJJEciWzS0= | ||||
| github.com/Azure/go-autorest/autorest/adal v0.8.2/go.mod h1:ZjhuQClTqx435SRJ2iMlOxPYt3d2C/T/7TiQCVZSn3Q= | ||||
| github.com/Azure/go-autorest/autorest/date v0.1.0/go.mod h1:plvfp3oPSKwf2DNjlBjWF/7vwR+cUD/ELuzDCXwHUVA= | ||||
| github.com/Azure/go-autorest/autorest/date v0.2.0/go.mod h1:vcORJHLJEh643/Ioh9+vPmf1Ij9AEBM5FuBIXLmIy0g= | ||||
| github.com/Azure/go-autorest/autorest/mocks v0.1.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= | ||||
| github.com/Azure/go-autorest/autorest/mocks v0.2.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= | ||||
| github.com/Azure/go-autorest/autorest/mocks v0.3.0/go.mod h1:a8FDP3DYzQ4RYfVAxAN3SVSiiO77gL2j2ronKKP0syM= | ||||
| github.com/Azure/go-autorest/logger v0.1.0/go.mod h1:oExouG+K6PryycPJfVSxi/koC6LSNgds39diKLz7Vrc= | ||||
| github.com/Azure/go-autorest/tracing v0.5.0/go.mod h1:r/s2XiOKccPW3HrqB+W0TQzfbtp2fGCgRFtBroKn4Dk= | ||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||
| github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | ||||
| github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0= | ||||
| github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ= | ||||
| github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= | ||||
| github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= | ||||
| github.com/Shopify/sarama v1.19.0/go.mod h1:FVkBWblsNy7DGZRfXLU0O9RCGt5g3g3yEuWXgklEdEo= | ||||
| github.com/Shopify/toxiproxy v2.1.4+incompatible/go.mod h1:OXgGpZ6Cli1/URJOF1DMxUHB2q5Ap20/P/eIdh4G0pI= | ||||
| github.com/VividCortex/gohistogram v1.0.0/go.mod h1:Pf5mBqqDxYaXu3hDrrU+w6nw50o/4+TcAqDqk/vUH7g= | ||||
| @ -31,8 +81,13 @@ github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QH | ||||
| github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= | ||||
| github.com/cespare/xxhash/v2 v2.1.1 h1:6MnRN8NT7+YBpUIWxHtefFZOKTAPgGjpQSxqLNn0+qY= | ||||
| github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= | ||||
| github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI= | ||||
| github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI= | ||||
| github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU= | ||||
| github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4dUb/I5gc9Hdhagfvm9+RyrPryS/auMzxE= | ||||
| github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= | ||||
| github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= | ||||
| github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= | ||||
| github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8= | ||||
| github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI= | ||||
| github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= | ||||
| @ -44,20 +99,32 @@ github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs | ||||
| github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= | ||||
| github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||
| github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ= | ||||
| github.com/docker/spdystream v0.0.0-20160310174837-449fdfce4d96/go.mod h1:Qh8CwZgvJUkLughtfhJv5dyTYa91l1fOUCrgjqmcifM= | ||||
| github.com/docopt/docopt-go v0.0.0-20180111231733-ee0de3bc6815/go.mod h1:WwZ+bS3ebgob9U8Nd0kOddGdZWjyMGR8Wziv+TBNwSE= | ||||
| github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= | ||||
| github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5mFgVsvEsIPBvNs= | ||||
| github.com/eapache/go-xerial-snappy v0.0.0-20180814174437-776d5712da21/go.mod h1:+020luEh2TKB4/GOp8oxxtq0Daoen/Cii55CzbTV6DU= | ||||
| github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I= | ||||
| github.com/edsrzf/mmap-go v1.0.0/go.mod h1:YO35OhQPt3KJa3ryjFM5Bs14WD66h8eGKpfaBNrHW5M= | ||||
| github.com/elazarl/goproxy v0.0.0-20180725130230-947c36da3153/go.mod h1:/Zj4wYkgs4iZTTu3o/KG3Itv/qCCa8VVMlb3i9OVuzc= | ||||
| github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= | ||||
| github.com/envoyproxy/go-control-plane v0.6.9/go.mod h1:SBwIajubJHhxtWwsL9s8ss4safvEdbitLhGGK48rN6g= | ||||
| github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||
| github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||
| github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= | ||||
| github.com/envoyproxy/go-control-plane v0.9.7/go.mod h1:cwu0lG7PUMfa9snN8LXBig5ynNVH9qI8YYLbd1fK2po= | ||||
| github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= | ||||
| github.com/evanphx/json-patch v4.9.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= | ||||
| github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= | ||||
| github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4= | ||||
| github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20= | ||||
| github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= | ||||
| github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= | ||||
| github.com/ghodss/yaml v0.0.0-20150909031657-73d445a93680/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= | ||||
| github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= | ||||
| github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= | ||||
| github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= | ||||
| github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= | ||||
| github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= | ||||
| github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= | ||||
| github.com/go-kit/kit v0.10.0/go.mod h1:xUsJbQ/Fp4kEt7AFgCuvyX4a71u8h9jB8tj/ORgOZ7o= | ||||
| @ -65,6 +132,16 @@ github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9 | ||||
| github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= | ||||
| github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= | ||||
| github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas= | ||||
| github.com/go-logr/logr v0.2.0 h1:QvGt2nLcHH0WK9orKa+ppBPAxREcH364nPUedEpK0TY= | ||||
| github.com/go-logr/logr v0.2.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= | ||||
| github.com/go-logr/logr v0.3.0 h1:q4c+kbcR0d5rSurhBR8dIgieOaYpXtsdTYfx22Cu6rs= | ||||
| github.com/go-logr/logr v0.3.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= | ||||
| github.com/go-openapi/jsonpointer v0.0.0-20160704185906-46af16f9f7b1/go.mod h1:+35s3my2LFTysnkMfxsJBAMHj/DoqoB9knIWoYG/Vk0= | ||||
| github.com/go-openapi/jsonreference v0.0.0-20160704190145-13c6e3589ad9/go.mod h1:W3Z9FmVs9qj+KR4zFKmDPGiLdk1D9Rlm7cyMvf57TTg= | ||||
| github.com/go-openapi/spec v0.0.0-20160808142527-6aced65f8501/go.mod h1:J8+jY1nAiCcj+friV/PDoE1/3eeccG9LYBs0tYvLOWc= | ||||
| github.com/go-openapi/swag v0.0.0-20160704191624-1d0bd113de87/go.mod h1:DXUve3Dpr1UfpPtxFw+EFuQ41HhCWZfha5jSVRG7C7I= | ||||
| github.com/go-ping/ping v0.0.0-20201115131931-3300c582a663 h1:jI2GiiRh+pPbey52EVmbU6kuLiXqwy4CXZ4gwUBj8Y0= | ||||
| github.com/go-ping/ping v0.0.0-20201115131931-3300c582a663/go.mod h1:35JbSyV/BYqHwwRA6Zr1uVDm1637YlNOU61wI797NPI= | ||||
| github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= | ||||
| github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= | ||||
| github.com/gogo/googleapis v1.1.0/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFGgqEef3s= | ||||
| @ -77,11 +154,22 @@ github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXP | ||||
| github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= | ||||
| github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= | ||||
| github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= | ||||
| github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= | ||||
| github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= | ||||
| github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= | ||||
| github.com/golang/mock v1.2.0/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= | ||||
| github.com/golang/mock v1.3.1/go.mod h1:sBzyDLLjw3U8JLTeZvSv8jJB+tU5PVekmnlKIyFUx0Y= | ||||
| github.com/golang/mock v1.4.0/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= | ||||
| github.com/golang/mock v1.4.1/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= | ||||
| github.com/golang/mock v1.4.3/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= | ||||
| github.com/golang/mock v1.4.4/go.mod h1:l3mdAwkq5BuhzHwde/uurv3sEJeZMXNpwsxVWU71h+4= | ||||
| github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.3.2 h1:6nsPYzhq5kReh6QImI3k5qWzO4PEbvbIW2cwSfR/6xs= | ||||
| github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | ||||
| github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= | ||||
| github.com/golang/protobuf v1.3.4/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= | ||||
| github.com/golang/protobuf v1.3.5/go.mod h1:6O5/vntMXwX2lRkT1hjjk0nAC1IDOTvTlVgjlRvqsdk= | ||||
| github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= | ||||
| github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= | ||||
| github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs= | ||||
| @ -99,19 +187,46 @@ github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5a | ||||
| github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= | ||||
| github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= | ||||
| github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.4.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.0 h1:/QaMHBdZ26BB3SSst0Iwl10Epc+xhTquomWX0oZEB6w= | ||||
| github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.4 h1:L8R9j+yAqZuZjsqh/z+F1NCffTKKLShY6zXTItVIZ8M= | ||||
| github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/gofuzz v1.0.0 h1:A8PeW59pxE9IoFRqBp37U+mSNaQoZ46F1f0f863XSXw= | ||||
| github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||
| github.com/google/gofuzz v1.1.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||
| github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= | ||||
| github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||
| github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= | ||||
| github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= | ||||
| github.com/google/martian/v3 v3.1.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= | ||||
| github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= | ||||
| github.com/google/pprof v0.0.0-20190515194954-54271f7e092f/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= | ||||
| github.com/google/pprof v0.0.0-20191218002539-d4f498aebedc/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= | ||||
| github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= | ||||
| github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= | ||||
| github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= | ||||
| github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= | ||||
| github.com/google/pprof v0.0.0-20201023163331-3e6fc7fc9c4c/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= | ||||
| github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= | ||||
| github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= | ||||
| github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||||
| github.com/googleapis/gnostic v0.5.3 h1:2qsuRm+bzgwSIKikigPASa2GhW8H2Dn4Qq7UxD8K/48= | ||||
| github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||||
| github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||||
| github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= | ||||
| github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= | ||||
| github.com/googleapis/gnostic v0.4.1 h1:DLJCy1n/vrD4HPjOvYcT8aYQXpPIzoRZONaYwyycI+I= | ||||
| github.com/googleapis/gnostic v0.4.1/go.mod h1:LRhVm6pbyptWbWbuZ38d1eyptfvIytN3ir6b65WBswg= | ||||
| github.com/googleapis/gnostic v0.5.3 h1:FP6YXyar5+eeXU8lBWDHJMZLHinornnILMJYBLgqKXk= | ||||
| github.com/googleapis/gnostic v0.5.3/go.mod h1:TRWw1s4gxBGjSe301Dai3c7wXJAZy57+/6tawkOvqHQ= | ||||
| github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= | ||||
| github.com/gorilla/context v1.1.1/go.mod h1:kBGZzfjB9CEq2AlWe17Uuf7NDRt0dE0s8S51q0aT7Yg= | ||||
| github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= | ||||
| github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= | ||||
| github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= | ||||
| github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= | ||||
| github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= | ||||
| github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= | ||||
| github.com/grpc-ecosystem/grpc-gateway v1.9.5/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= | ||||
| @ -137,6 +252,9 @@ github.com/hashicorp/memberlist v0.1.3/go.mod h1:ajVTdAv/9Im8oMAAj5G31PhhMCZJV2p | ||||
| github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/JwenrHc= | ||||
| github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= | ||||
| github.com/hudl/fargo v1.3.0/go.mod h1:y3CKSmjA+wD2gak7sUSXTAoopbhU08POFhmITJgmKTg= | ||||
| github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= | ||||
| github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= | ||||
| github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= | ||||
| github.com/imdario/mergo v0.3.11 h1:3tnifQM4i+fbajXKBHXWEH+KvNHqojZ778UH75j3bGA= | ||||
| github.com/imdario/mergo v0.3.11/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA= | ||||
| github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= | ||||
| @ -149,6 +267,8 @@ github.com/json-iterator/go v1.1.7/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/u | ||||
| github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= | ||||
| github.com/json-iterator/go v1.1.10 h1:Kz6Cvnvv2wGdaG/V8yMvfkmNiXq9Ya2KUv4rouJJr68= | ||||
| github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= | ||||
| github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU= | ||||
| github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk= | ||||
| github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU= | ||||
| github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= | ||||
| github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= | ||||
| @ -168,6 +288,7 @@ github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= | ||||
| github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM= | ||||
| github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4= | ||||
| github.com/lyft/protoc-gen-validate v0.0.13/go.mod h1:XbGvPuh87YZc5TdIa2/I4pLk0QoUACkjt2znoq26NVQ= | ||||
| github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= | ||||
| github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= | ||||
| github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= | ||||
| @ -190,8 +311,10 @@ github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJ | ||||
| github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= | ||||
| github.com/modern-go/reflect2 v1.0.1 h1:9f412s+6RmYXLWZSEzVVgPGK7C2PphHj5RJrvfx9AWI= | ||||
| github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= | ||||
| github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= | ||||
| github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= | ||||
| github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= | ||||
| github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw= | ||||
| github.com/nats-io/jwt v0.3.0/go.mod h1:fRYCDE99xlTsqUzISS1Bi75UBJ6ljOJQOAAu5VglpSg= | ||||
| github.com/nats-io/jwt v0.3.2/go.mod h1:/euKqTS1ZD+zzjYrY7pseZrTtWQSjujC7xjPc8wL6eU= | ||||
| github.com/nats-io/nats-server/v2 v2.1.2/go.mod h1:Afk+wRZqkMQs/p45uXdrVLuab3gwv3Z8C4HTBu8GD/k= | ||||
| @ -202,9 +325,13 @@ github.com/nats-io/nuid v1.0.1/go.mod h1:19wcPz3Ph3q0Jbyiqsd0kePYG7A95tJPxeL+1OS | ||||
| github.com/oklog/oklog v0.3.2/go.mod h1:FCV+B7mhrz4o+ueLpx+KqkyXRGMWOYEvfiXtdGtbWGs= | ||||
| github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA= | ||||
| github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5/go.mod h1:vsDQFd/mU46D+Z4whnwzcISnGGzXWMclvtLoiIKAKIo= | ||||
| github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
| github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
| github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk= | ||||
| github.com/opentracing-contrib/go-observer v0.0.0-20170622124052-a52f23424492/go.mod h1:Ngi6UdF0k5OKD5t5wlmGhe/EDKPoUM3BXZSSfIuJbis= | ||||
| github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74= | ||||
| @ -218,12 +345,14 @@ github.com/pact-foundation/pact-go v1.0.4/go.mod h1:uExwJY4kCzNPcHRj+hCR/HBbOOIw | ||||
| github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= | ||||
| github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= | ||||
| github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac= | ||||
| github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU= | ||||
| github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc= | ||||
| github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= | ||||
| github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/profile v1.2.1/go.mod h1:hJw3o1OdXxsrSjjVksARp5W95eeEaEfptyVZyv6JUPA= | ||||
| github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | ||||
| github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||
| github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI= | ||||
| github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw= | ||||
| @ -232,6 +361,8 @@ github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5Fsn | ||||
| github.com/prometheus/client_golang v1.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og= | ||||
| github.com/prometheus/client_golang v1.7.1 h1:NTGy1Ja9pByO+xAeH/qiWnLrKtr3hJPNjaVUwnjpdpA= | ||||
| github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M= | ||||
| github.com/prometheus/client_golang v1.9.0 h1:Rrch9mh17XcxvEu9D9DEpb4isxjGBtcevQjKvxPRQIU= | ||||
| github.com/prometheus/client_golang v1.9.0/go.mod h1:FqZLKOZnGdFAhOK4nqGHa7D66IdsO+O441Eve7ptJDU= | ||||
| github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= | ||||
| github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= | ||||
| github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= | ||||
| @ -245,14 +376,16 @@ github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y8 | ||||
| github.com/prometheus/common v0.7.0 h1:L+1lyG48J1zAQXA3RBX/nG/B3gjlHq0zTt2tlbJLyCY= | ||||
| github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA= | ||||
| github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo= | ||||
| github.com/prometheus/common v0.13.0 h1:vJlpe9wPgDRM1Z+7Wj3zUUjY1nr6/1jNKyl7llliccg= | ||||
| github.com/prometheus/common v0.13.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s= | ||||
| github.com/prometheus/common v0.15.0 h1:4fgOnadei3EZvgRwxJ7RMpG1k1pOZth5Pc13tyspaKM= | ||||
| github.com/prometheus/common v0.15.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s= | ||||
| github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk= | ||||
| github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk= | ||||
| github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= | ||||
| github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A= | ||||
| github.com/prometheus/procfs v0.1.3 h1:F0+tqvhOksq22sc6iCHF5WGlWjdwj92p0udFh1VFBS8= | ||||
| github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= | ||||
| github.com/prometheus/procfs v0.2.0 h1:wH4vA7pcjKuZzjF7lM8awk4fnuJO6idemZXoKnULUx4= | ||||
| github.com/prometheus/procfs v0.2.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= | ||||
| github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= | ||||
| github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= | ||||
| github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= | ||||
| @ -270,8 +403,11 @@ github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4k | ||||
| github.com/sony/gobreaker v0.4.1/go.mod h1:ZKptC7FHNvhBz7dN2LGjPVBz2sZJmc0/PkyDJOjmxWY= | ||||
| github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk= | ||||
| github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= | ||||
| github.com/spf13/pflag v0.0.0-20170130214245-9ff6c6923cff/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= | ||||
| github.com/spf13/pflag v1.0.1 h1:aCvUg6QPl3ibpQUxyLkrEkCHtPqYJL4x9AuhqVqFis4= | ||||
| github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= | ||||
| github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= | ||||
| github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= | ||||
| github.com/stoewer/go-strcase v1.2.0/go.mod h1:IBiWB2sKIp3wVVQ3Y035++gc+knqhUQag1KpM8ahLw8= | ||||
| github.com/streadway/amqp v0.0.0-20190404075320-75d898a42a94/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= | ||||
| github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw= | ||||
| @ -280,17 +416,28 @@ github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+ | ||||
| github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= | ||||
| github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= | ||||
| github.com/stretchr/testify v1.4.0 h1:2E4SXV/wtOkTonXsotYi4li6zVWxYlZuYNCXe9XRJyk= | ||||
| github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= | ||||
| github.com/stretchr/testify v1.5.1 h1:nOGnQDM7FYENwehXlg/kFVnos3rEvtKTjRvOWSzb6H4= | ||||
| github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= | ||||
| github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= | ||||
| github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA= | ||||
| github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= | ||||
| github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= | ||||
| github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= | ||||
| go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= | ||||
| go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg= | ||||
| go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk= | ||||
| go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk= | ||||
| go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= | ||||
| go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= | ||||
| go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= | ||||
| go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= | ||||
| go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= | ||||
| go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= | ||||
| go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= | ||||
| go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= | ||||
| go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= | ||||
| @ -302,19 +449,47 @@ golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnf | ||||
| golang.org/x/crypto v0.0.0-20181029021203-45a5f77698d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9 h1:psW17arqaxU48Z5kZ0CQnkZWQJsqcURM6tKiBApRjXI= | ||||
| golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| golang.org/x/crypto v0.0.0-20201221181555-eec23a3978ad h1:DN0cp81fZ3njFcrLCytUHRSUkqBjfTo4Tx9RJTWs0EY= | ||||
| golang.org/x/crypto v0.0.0-20201221181555-eec23a3978ad/go.mod h1:jdWPYTVW3xRLrWPugEBEK3UY2ZEsg3UU495nc5E+M+I= | ||||
| golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= | ||||
| golang.org/x/exp v0.0.0-20190829153037-c13cbed26979/go.mod h1:86+5VVa7VpoJ4kLfm080zCjGlMRFzhUhsZKEZO7MGek= | ||||
| golang.org/x/exp v0.0.0-20191030013958-a1ab85dbe136/go.mod h1:JXzH8nQsPlswgeRAPE3MuO9GYsAcnJvJ4vnMwN/5qkY= | ||||
| golang.org/x/exp v0.0.0-20191129062945-2f5052295587/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= | ||||
| golang.org/x/exp v0.0.0-20191227195350-da58074b4299/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= | ||||
| golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= | ||||
| golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM= | ||||
| golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU= | ||||
| golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= | ||||
| golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= | ||||
| golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= | ||||
| golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU= | ||||
| golang.org/x/lint v0.0.0-20190301231843-5614ed5bae6f/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= | ||||
| golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/lint v0.0.0-20190409202823-959b441ac422/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/lint v0.0.0-20190909230951-414d861bb4ac/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/lint v0.0.0-20190930215403-16217165b5de h1:5hukYrvBGR8/eNkX5mdUezrA6JiaEZDtJb9Ei+1LlBs= | ||||
| golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/lint v0.0.0-20191125180803-fdd1cda4f05f/go.mod h1:5qLYkcX4OjUUV8bRuDixDT3tpyyb+LUpUlRWLxfhWrs= | ||||
| golang.org/x/lint v0.0.0-20200130185559-910be7a94367/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= | ||||
| golang.org/x/lint v0.0.0-20200302205851-738671d3881b/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= | ||||
| golang.org/x/lint v0.0.0-20201208152925-83fdc39ff7b5/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= | ||||
| golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU15maQ/Ox0txvL9dWGYEHz965HBQE= | ||||
| golang.org/x/mobile v0.0.0-20190719004257-d2bd2a29d028/go.mod h1:E/iHnbuqvinMTCcRqshq8CkpyQDoeVncDDYHnLhea+o= | ||||
| golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKGUJ2LatrhH/nqhxcFungHvyanc= | ||||
| golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= | ||||
| golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= | ||||
| golang.org/x/mod v0.1.1-0.20191107180719-034126e5016b/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= | ||||
| golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= | ||||
| golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= | ||||
| golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= | ||||
| golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| @ -327,22 +502,58 @@ golang.org/x/net v0.0.0-20190125091013-d26f9f9a57f3/go.mod h1:mL1N/T3taQHkDXs73r | ||||
| golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190503192946-f4e77d36d62c/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= | ||||
| golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190724013045-ca1201d0de80/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190923162816-aa69164e4478/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200222125558-5a598a2470a0/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200301022130-244492dfa37a/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20200324143707-d3edc9973b7e/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= | ||||
| golang.org/x/net v0.0.0-20200501053045-e0ff5e5a1de5/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= | ||||
| golang.org/x/net v0.0.0-20200506145744-7e3656a0809f/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= | ||||
| golang.org/x/net v0.0.0-20200513185701-a91f0712d120/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= | ||||
| golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= | ||||
| golang.org/x/net v0.0.0-20200625001655-4c5254603344 h1:vGXIOMxbNfDTk/aXCmfdLgkrSV+Z2tcbze+pEc3v5W4= | ||||
| golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= | ||||
| golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= | ||||
| golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= | ||||
| golang.org/x/net v0.0.0-20200904194848-62affa334b73/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= | ||||
| golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= | ||||
| golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= | ||||
| golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= | ||||
| golang.org/x/net v0.0.0-20201209123823-ac852fbbde11/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | ||||
| golang.org/x/net v0.0.0-20201224014010-6772e930b67b h1:iFwSg7t5GZmB/Q5TjiEAsdoLDrdJRC1RiF2WhuV29Qw= | ||||
| golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | ||||
| golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | ||||
| golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421 h1:Wo7BWFiOk0QRFMLYMqJGFMd9CgUAcGx7V+qEg/h5IBI= | ||||
| golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||
| golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||
| golang.org/x/oauth2 v0.0.0-20191202225959-858c2ad4c8b6/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||
| golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||
| golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= | ||||
| golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= | ||||
| golang.org/x/oauth2 v0.0.0-20201208152858-08078c50e5b5 h1:Lm4OryKCca1vehdsWogr9N4t7NfZxLbJoc/H0w4K4S4= | ||||
| golang.org/x/oauth2 v0.0.0-20201208152858-08078c50e5b5/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= | ||||
| golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e h1:vcxGaoTs7kV8m5Np9uUNQin4BrLOthgV7252N8V+FwY= | ||||
| golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9 h1:SQFwaSi55rU7vdNs9Yr0Z324VNlrF+0wMqRXT4St8ck= | ||||
| golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| @ -352,41 +563,121 @@ golang.org/x/sys v0.0.0-20181107165924-66b7b1311ac8/go.mod h1:STP8DvDyc/dI5b8T5h | ||||
| golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20181122145206-62eef0e2fa9b/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190507160741-ecd444e8653b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190606165138-5da285871e9c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190624142023-c5567b49c5d0/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190726091711-fc99dfbffb4e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190924154521-2837fb4f24fe/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191220142924-d4481acd189f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200113162924-86b910548bc1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200212091648-12a6c2dcc1e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200302150141-5c8b2ff67527/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200331124033-c3d80250170d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f h1:+Nyd8tzPX9R7BWHguqsrbFdRx3WQ/1ib8I44HXV5yTA= | ||||
| golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20201112073958-5cba982894dd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20201214210602-f9fddec55a1e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20201223074533-0d417f636930 h1:vRgIt+nup/B/BwIS0g2oC0haq0iqbV3ZA+u6+0TlNCo= | ||||
| golang.org/x/sys v0.0.0-20201223074533-0d417f636930/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1 h1:v+OssWQX+hTHEmOBgwxdZxK4zHq3yOs8F9J7mk0PY8E= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/term v0.0.0-20201210144234-2321bbc49cbf h1:MZ2shdL+ZM/XzY3ZGOnh4Nlpnxz5GSOhOmtHo3iPU6M= | ||||
| golang.org/x/term v0.0.0-20201210144234-2321bbc49cbf/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs= | ||||
| golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= | ||||
| golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| golang.org/x/text v0.3.4 h1:0YWbFKbhXG/wIiuHDSKpS0Iy7FSA+u45VtBMfQcFTTc= | ||||
| golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20191024005414-555d28b269f0 h1:/5xXl8Y5W96D+TtHSlonuFqGHIWVuyCkGJLwGh9JJFs= | ||||
| golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20201208040808-7e3f01d25324 h1:Hir2P/De0WpUhtrKGGjvSb2YxUgyZ7EFOSLIcSSpiwE= | ||||
| golang.org/x/time v0.0.0-20201208040808-7e3f01d25324/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20181011042414-1f849cf54d09/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= | ||||
| golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190312170243-e65039ee4138/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190328211700-ab21143f2384/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190425150028-36563e24a262/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= | ||||
| golang.org/x/tools v0.0.0-20190506145303-2d16b83fe98c/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= | ||||
| golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= | ||||
| golang.org/x/tools v0.0.0-20190606124116-d0a3d012864b/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190621195816-6e04913cbbac/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190628153133-6cdbf07be9d0/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190816200558-6889da9d5479/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20190911174233-4f2ddba30aff/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191029041327-9cc4af7d6b2c/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191029190741-b9c20aec41a5/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191113191852-77e3bb0ad9e7/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191115202509-3a792d9c32b2/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191125144606-a911d9008d1f/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191130070609-6e064ea0cf2d/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/tools v0.0.0-20191216052735-49a3e744a425/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20191216173652-a0e659d51361/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20191227053925-7b8e75db28f4/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200103221440-774c71fcf114 h1:DnSr2mCsxyCE6ZgIkmcWUQY2R5cH/6wL7eIxEmQOMSE= | ||||
| golang.org/x/tools v0.0.0-20200103221440-774c71fcf114/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200117161641-43d50277825c/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200122220014-bf1340f18c4a/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200204074204-1cc6d1ef6c74/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200207183749-b753a1ba74fa/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200212150539-ea181f53ac56/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200224181240-023911ca70b2/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200227222343-706bc42d1f0d/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= | ||||
| golang.org/x/tools v0.0.0-20200304193943-95d2e580d8eb/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= | ||||
| golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= | ||||
| golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= | ||||
| golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= | ||||
| golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= | ||||
| golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= | ||||
| golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= | ||||
| golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= | ||||
| golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= | ||||
| golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= | ||||
| golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE= | ||||
| golang.org/x/tools v0.0.0-20201110124207-079ba7bd75cd/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= | ||||
| golang.org/x/tools v0.0.0-20201201161351-ac6f37ff4c2a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= | ||||
| golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4= | ||||
| @ -394,27 +685,89 @@ golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8T | ||||
| golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= | ||||
| golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| google.golang.org/api v0.3.1/go.mod h1:6wY9I6uQWHQ8EM57III9mq/AjF+i8G65rmVagqKMtkk= | ||||
| google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= | ||||
| google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= | ||||
| google.golang.org/api v0.8.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= | ||||
| google.golang.org/api v0.9.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= | ||||
| google.golang.org/api v0.13.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= | ||||
| google.golang.org/api v0.14.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= | ||||
| google.golang.org/api v0.15.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= | ||||
| google.golang.org/api v0.17.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= | ||||
| google.golang.org/api v0.18.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= | ||||
| google.golang.org/api v0.19.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= | ||||
| google.golang.org/api v0.20.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= | ||||
| google.golang.org/api v0.22.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= | ||||
| google.golang.org/api v0.24.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= | ||||
| google.golang.org/api v0.28.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= | ||||
| google.golang.org/api v0.29.0/go.mod h1:Lcubydp8VUV7KeIHD9z2Bys/sm/vGKnG1UHuDBSrHWM= | ||||
| google.golang.org/api v0.30.0/go.mod h1:QGmEvQ87FHZNiUVJkT14jQNYJ4ZJjdRF23ZXz5138Fc= | ||||
| google.golang.org/api v0.35.0/go.mod h1:/XrVsuzM0rZmrsbjJutiuftIzeuTQcEeaYcSk/mQ1dg= | ||||
| google.golang.org/api v0.36.0/go.mod h1:+z5ficQTmoYpPn8LCUNVpK5I7hwkpjbcgqA7I34qYtE= | ||||
| google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= | ||||
| google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/appengine v1.4.0 h1:/wp5JvzpHIxhs/dumFmF7BXTf3Z+dd4uXta4kVyO508= | ||||
| google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/appengine v1.5.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/appengine v1.6.1/go.mod h1:i06prIuMbXzDqacNJfV5OdTW448YApPu5ww/cMBSeb0= | ||||
| google.golang.org/appengine v1.6.5/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= | ||||
| google.golang.org/appengine v1.6.6/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= | ||||
| google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6c= | ||||
| google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= | ||||
| google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= | ||||
| google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= | ||||
| google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= | ||||
| google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= | ||||
| google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= | ||||
| google.golang.org/genproto v0.0.0-20190530194941-fb225487d101/go.mod h1:z3L6/3dTEVtUr6QSP8miRzeRqwQOioJ9I66odjN4I7s= | ||||
| google.golang.org/genproto v0.0.0-20190801165951-fa694d86fc64/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= | ||||
| google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc= | ||||
| google.golang.org/genproto v0.0.0-20190911173649-1774047e7e51/go.mod h1:IbNlFCBrqXvoKpeg0TB2l7cyZUmoaFKYIwrEpbDKLA8= | ||||
| google.golang.org/genproto v0.0.0-20191108220845-16a3f7862a1a/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20191115194625-c23dd37a84c9/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20191216164720-4f79533eabd1/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20200115191322-ca5a22157cba/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20200122232147-0452cf42e150/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc= | ||||
| google.golang.org/genproto v0.0.0-20200204135345-fa8e72b47b90/go.mod h1:GmwEX6Z4W5gMy59cAlVYjN9JhxgbQH6Gn+gFDQe2lzA= | ||||
| google.golang.org/genproto v0.0.0-20200212174721-66ed5ce911ce/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200224152610-e50cd9704f63/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200228133532-8c2c7df3a383/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200305110556-506484158171/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= | ||||
| google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U= | ||||
| google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= | ||||
| google.golang.org/genproto v0.0.0-20200618031413-b414f8b61790/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= | ||||
| google.golang.org/genproto v0.0.0-20200729003335-053ba62fc06f/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20200804131852-c06518451d9c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20200825200019-8632dd797987/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20200904004341-0bd0a958aa1d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20201019141844-1ed22bb0c154/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20201109203340-2640f1f9cdfb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20201201144952-b05cb90ed32e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/genproto v0.0.0-20201210142538-e3217bee35cc/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= | ||||
| google.golang.org/grpc v1.17.0/go.mod h1:6QZJwpn2B+Zp71q/5VxRsJ6NXXVCE5NRUHRo+f3cWCs= | ||||
| google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= | ||||
| google.golang.org/grpc v1.20.0/go.mod h1:chYK+tFQF0nDUGJgXMSgLCQk3phJEuONr2DCgLDdAQM= | ||||
| google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= | ||||
| google.golang.org/grpc v1.21.0/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= | ||||
| google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= | ||||
| google.golang.org/grpc v1.22.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= | ||||
| google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= | ||||
| google.golang.org/grpc v1.23.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= | ||||
| google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= | ||||
| google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= | ||||
| google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= | ||||
| google.golang.org/grpc v1.27.1/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= | ||||
| google.golang.org/grpc v1.28.0/go.mod h1:rpkK4SK4GF4Ach/+MFLZUBavHOvF2JJB5uozKKal+60= | ||||
| google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk= | ||||
| google.golang.org/grpc v1.30.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= | ||||
| google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= | ||||
| google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= | ||||
| google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc= | ||||
| google.golang.org/grpc v1.34.0/go.mod h1:WotjhfgOW/POjDeRt8vscBtXq+2VjORFy659qA51WJ8= | ||||
| google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= | ||||
| google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= | ||||
| google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= | ||||
| @ -448,25 +801,41 @@ gopkg.in/yaml.v2 v2.2.2 h1:ZCJp+EgiOT7lHqUV2J862kp8Qj64Jo6az82+3Td9dZw= | ||||
| gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.3.0 h1:clyUAQHOM3G0M3f5vQj7LuJrETvjVot3Z5el9nffUtU= | ||||
| gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= | ||||
| gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= | ||||
| gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ= | ||||
| gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||
| honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg= | ||||
| k8s.io/api v0.0.0-20190816222004-e3a6b8045b0b h1:RXEExX+zpnAwh3WmvQMVy5albf6/wuIP1W2ehL2lTqc= | ||||
| k8s.io/api v0.0.0-20190816222004-e3a6b8045b0b/go.mod h1:iuAfoD4hCxJ8Onx9kaTIt30j7jUFS00AXQi6QMi99vA= | ||||
| k8s.io/apimachinery v0.0.0-20190816221834-a9f1d8a9c101 h1:QtHYUjIdgXTtJVdYQhWIQZZoXa32aF3O9BNX2up2plE= | ||||
| k8s.io/apimachinery v0.0.0-20190816221834-a9f1d8a9c101/go.mod h1:ccL7Eh7zubPUSh9A3USN90/OzHNSVN6zxzde07TDCL0= | ||||
| k8s.io/client-go v11.0.1-0.20190918222721-c0e3722d5cf0+incompatible h1:Qbgu1b9y8BUhpTZD5+6z2pt0YD57D7FGaCkBg2UFaEY= | ||||
| k8s.io/client-go v11.0.1-0.20190918222721-c0e3722d5cf0+incompatible/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= | ||||
| k8s.io/klog v1.0.0 h1:Pt+yjF5aB1xDSVbau4VsWe+dQNzA0qv1LlXdC2dF6Q8= | ||||
| k8s.io/klog v1.0.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= | ||||
| honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= | ||||
| honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= | ||||
| k8s.io/api v0.19.6 h1:F3lfwgpKcKms6F1mMqkQXFzXmme8QqHTJBtBkev3TOg= | ||||
| k8s.io/api v0.19.6/go.mod h1:Plxx44Nh4zVblkJrIgxVPgPre1mvng6tXf1Sj3bs0fU= | ||||
| k8s.io/apimachinery v0.19.6 h1:kBLzSGuDdY1NdSV2uFzI+FwZ9wtkmG+X3ZVcWXSqNgA= | ||||
| k8s.io/apimachinery v0.19.6/go.mod h1:6sRbGRAVY5DOCuZwB5XkqguBqpqLU6q/kOaOdk29z6Q= | ||||
| k8s.io/client-go v0.19.6 h1:vtPb33nP8DBMW+/CyuJ8fiie36c3CM1Ts6L4Tsr+PtU= | ||||
| k8s.io/client-go v0.19.6/go.mod h1:gEiS+efRlXYUEQ9Oz4lmNXlxAl5JZ8y2zbTDGhvXXnk= | ||||
| k8s.io/gengo v0.0.0-20200413195148-3a45101e95ac/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE= | ||||
| k8s.io/utils v0.0.0-20201027101359-01387209bb0d h1:1qqs/6lQQGCeZhCu0tO7La4lAazDXic6BiCmpjWcWUo= | ||||
| k8s.io/utils v0.0.0-20201027101359-01387209bb0d/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/klog/v2 v2.2.0 h1:XRvcwJozkgZ1UQJmfMGpvRthQHOvihEhYtDfAaxMz/A= | ||||
| k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y= | ||||
| k8s.io/kube-openapi v0.0.0-20200805222855-6aeccd4b50c6/go.mod h1:UuqjUnNftUyPE5H64/qeyjQoUZhGpeFDVdxjTeEVN2o= | ||||
| k8s.io/utils v0.0.0-20200729134348-d5654de09c73 h1:uJmqzgNWG7XyClnU/mLPBWwfKKF1K8Hf8whTseBgJcg= | ||||
| k8s.io/utils v0.0.0-20200729134348-d5654de09c73/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8= | ||||
| rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0= | ||||
| rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.0.1 h1:YXTMot5Qz/X1iBRJhAt+vI+HVttY0WkSqqhKxQ0xVbA= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.0.1/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= | ||||
| sigs.k8s.io/yaml v1.1.0 h1:4A07+ZFc2wgJwo8YNlQpr1rVlgUDlxXHhPJciaPY5gs= | ||||
| sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o= | ||||
| sigs.k8s.io/yaml v1.2.0 h1:kr/MCeFWJWTwyaHoR9c8EjH9OumOmoF9YGiZd7lFm/Q= | ||||
| sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc= | ||||
| sourcegraph.com/sourcegraph/appdash v0.0.0-20190731080439-ebfcffb1b5c0/go.mod h1:hI742Nqp5OhwiqlzhgfbWU4mW4yO10fP+LoT9WOswdU= | ||||
|  | ||||
| @ -1,6 +1,7 @@ | ||||
| package k8s | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"flag" | ||||
| 	"fmt" | ||||
| 	"os" | ||||
| @ -28,7 +29,7 @@ type KubernetesClient struct { | ||||
|  | ||||
| // GetServices returns a list of services for a given namespace | ||||
| func (k *KubernetesClient) GetServices(namespace string) ([]v1.Service, error) { | ||||
| 	services, err := k.client.CoreV1().Services(namespace).List(metav1.ListOptions{}) | ||||
| 	services, err := k.client.CoreV1().Services(namespace).List(context.TODO(), metav1.ListOptions{}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										15
									
								
								vendor/cloud.google.com/go/AUTHORS
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								vendor/cloud.google.com/go/AUTHORS
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,15 +0,0 @@ | ||||
| # This is the official list of cloud authors for copyright purposes. | ||||
| # This file is distinct from the CONTRIBUTORS files. | ||||
| # See the latter for an explanation. | ||||
|  | ||||
| # Names should be added to this file as: | ||||
| # Name or Organization <email address> | ||||
| # The email address is not required for organizations. | ||||
|  | ||||
| Filippo Valsorda <hi@filippo.io> | ||||
| Google Inc. | ||||
| Ingo Oeser <nightlyone@googlemail.com> | ||||
| Palm Stone Games, Inc. | ||||
| Paweł Knap <pawelknap88@gmail.com> | ||||
| Péter Szilágyi <peterke@gmail.com> | ||||
| Tyler Treat <ttreat31@gmail.com> | ||||
							
								
								
									
										40
									
								
								vendor/cloud.google.com/go/CONTRIBUTORS
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								vendor/cloud.google.com/go/CONTRIBUTORS
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,40 +0,0 @@ | ||||
| # People who have agreed to one of the CLAs and can contribute patches. | ||||
| # The AUTHORS file lists the copyright holders; this file | ||||
| # lists people.  For example, Google employees are listed here | ||||
| # but not in AUTHORS, because Google holds the copyright. | ||||
| # | ||||
| # https://developers.google.com/open-source/cla/individual | ||||
| # https://developers.google.com/open-source/cla/corporate | ||||
| # | ||||
| # Names should be added to this file as: | ||||
| #     Name <email address> | ||||
|  | ||||
| # Keep the list alphabetically sorted. | ||||
|  | ||||
| Alexis Hunt <lexer@google.com> | ||||
| Andreas Litt <andreas.litt@gmail.com> | ||||
| Andrew Gerrand <adg@golang.org> | ||||
| Brad Fitzpatrick <bradfitz@golang.org> | ||||
| Burcu Dogan <jbd@google.com> | ||||
| Dave Day <djd@golang.org> | ||||
| David Sansome <me@davidsansome.com> | ||||
| David Symonds <dsymonds@golang.org> | ||||
| Filippo Valsorda <hi@filippo.io> | ||||
| Glenn Lewis <gmlewis@google.com> | ||||
| Ingo Oeser <nightlyone@googlemail.com> | ||||
| James Hall <james.hall@shopify.com> | ||||
| Johan Euphrosine <proppy@google.com> | ||||
| Jonathan Amsterdam <jba@google.com> | ||||
| Kunpei Sakai <namusyaka@gmail.com> | ||||
| Luna Duclos <luna.duclos@palmstonegames.com> | ||||
| Magnus Hiie <magnus.hiie@gmail.com> | ||||
| Mario Castro <mariocaster@gmail.com> | ||||
| Michael McGreevy <mcgreevy@golang.org> | ||||
| Omar Jarjur <ojarjur@google.com> | ||||
| Paweł Knap <pawelknap88@gmail.com> | ||||
| Péter Szilágyi <peterke@gmail.com> | ||||
| Sarah Adams <shadams@google.com> | ||||
| Thanatat Tamtan <acoshift@gmail.com> | ||||
| Toby Burress <kurin@google.com> | ||||
| Tuo Shan <shantuo@google.com> | ||||
| Tyler Treat <ttreat31@gmail.com> | ||||
							
								
								
									
										76
									
								
								vendor/cloud.google.com/go/compute/metadata/metadata.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										76
									
								
								vendor/cloud.google.com/go/compute/metadata/metadata.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -61,17 +61,7 @@ var ( | ||||
| 	instID  = &cachedValue{k: "instance/id", trim: true} | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| 	defaultClient = &Client{hc: &http.Client{ | ||||
| 		Transport: &http.Transport{ | ||||
| 			Dial: (&net.Dialer{ | ||||
| 				Timeout:   2 * time.Second, | ||||
| 				KeepAlive: 30 * time.Second, | ||||
| 			}).Dial, | ||||
| 			ResponseHeaderTimeout: 2 * time.Second, | ||||
| 		}, | ||||
| 	}} | ||||
| 	subscribeClient = &Client{hc: &http.Client{ | ||||
| var defaultClient = &Client{hc: &http.Client{ | ||||
| 	Transport: &http.Transport{ | ||||
| 		Dial: (&net.Dialer{ | ||||
| 			Timeout:   2 * time.Second, | ||||
| @ -79,7 +69,6 @@ var ( | ||||
| 		}).Dial, | ||||
| 	}, | ||||
| }} | ||||
| ) | ||||
|  | ||||
| // NotDefinedError is returned when requested metadata is not defined. | ||||
| // | ||||
| @ -137,7 +126,7 @@ func testOnGCE() bool { | ||||
| 	resc := make(chan bool, 2) | ||||
|  | ||||
| 	// Try two strategies in parallel. | ||||
| 	// See https://github.com/GoogleCloudPlatform/google-cloud-go/issues/194 | ||||
| 	// See https://github.com/googleapis/google-cloud-go/issues/194 | ||||
| 	go func() { | ||||
| 		req, _ := http.NewRequest("GET", "http://"+metadataIP, nil) | ||||
| 		req.Header.Set("User-Agent", userAgent) | ||||
| @ -151,7 +140,7 @@ func testOnGCE() bool { | ||||
| 	}() | ||||
|  | ||||
| 	go func() { | ||||
| 		addrs, err := net.LookupHost("metadata.google.internal") | ||||
| 		addrs, err := net.DefaultResolver.LookupHost(ctx, "metadata.google.internal") | ||||
| 		if err != nil || len(addrs) == 0 { | ||||
| 			resc <- false | ||||
| 			return | ||||
| @ -206,10 +195,9 @@ func systemInfoSuggestsGCE() bool { | ||||
| 	return name == "Google" || name == "Google Compute Engine" | ||||
| } | ||||
|  | ||||
| // Subscribe calls Client.Subscribe on a client designed for subscribing (one with no | ||||
| // ResponseHeaderTimeout). | ||||
| // Subscribe calls Client.Subscribe on the default client. | ||||
| func Subscribe(suffix string, fn func(v string, ok bool) error) error { | ||||
| 	return subscribeClient.Subscribe(suffix, fn) | ||||
| 	return defaultClient.Subscribe(suffix, fn) | ||||
| } | ||||
|  | ||||
| // Get calls Client.Get on the default client. | ||||
| @ -227,6 +215,9 @@ func InternalIP() (string, error) { return defaultClient.InternalIP() } | ||||
| // ExternalIP returns the instance's primary external (public) IP address. | ||||
| func ExternalIP() (string, error) { return defaultClient.ExternalIP() } | ||||
|  | ||||
| // Email calls Client.Email on the default client. | ||||
| func Email(serviceAccount string) (string, error) { return defaultClient.Email(serviceAccount) } | ||||
|  | ||||
| // Hostname returns the instance's hostname. This will be of the form | ||||
| // "<instanceID>.c.<projID>.internal". | ||||
| func Hostname() (string, error) { return defaultClient.Hostname() } | ||||
| @ -277,9 +268,14 @@ type Client struct { | ||||
| 	hc *http.Client | ||||
| } | ||||
|  | ||||
| // NewClient returns a Client that can be used to fetch metadata. All HTTP requests | ||||
| // will use the given http.Client instead of the default client. | ||||
| // NewClient returns a Client that can be used to fetch metadata. | ||||
| // Returns the client that uses the specified http.Client for HTTP requests. | ||||
| // If nil is specified, returns the default client. | ||||
| func NewClient(c *http.Client) *Client { | ||||
| 	if c == nil { | ||||
| 		return defaultClient | ||||
| 	} | ||||
|  | ||||
| 	return &Client{hc: c} | ||||
| } | ||||
|  | ||||
| @ -300,8 +296,12 @@ func (c *Client) getETag(suffix string) (value, etag string, err error) { | ||||
| 		// being stable anyway. | ||||
| 		host = metadataIP | ||||
| 	} | ||||
| 	url := "http://" + host + "/computeMetadata/v1/" + suffix | ||||
| 	req, _ := http.NewRequest("GET", url, nil) | ||||
| 	suffix = strings.TrimLeft(suffix, "/") | ||||
| 	u := "http://" + host + "/computeMetadata/v1/" + suffix | ||||
| 	req, err := http.NewRequest("GET", u, nil) | ||||
| 	if err != nil { | ||||
| 		return "", "", err | ||||
| 	} | ||||
| 	req.Header.Set("Metadata-Flavor", "Google") | ||||
| 	req.Header.Set("User-Agent", userAgent) | ||||
| 	res, err := c.hc.Do(req) | ||||
| @ -312,13 +312,13 @@ func (c *Client) getETag(suffix string) (value, etag string, err error) { | ||||
| 	if res.StatusCode == http.StatusNotFound { | ||||
| 		return "", "", NotDefinedError(suffix) | ||||
| 	} | ||||
| 	if res.StatusCode != 200 { | ||||
| 		return "", "", fmt.Errorf("status code %d trying to fetch %s", res.StatusCode, url) | ||||
| 	} | ||||
| 	all, err := ioutil.ReadAll(res.Body) | ||||
| 	if err != nil { | ||||
| 		return "", "", err | ||||
| 	} | ||||
| 	if res.StatusCode != 200 { | ||||
| 		return "", "", &Error{Code: res.StatusCode, Message: string(all)} | ||||
| 	} | ||||
| 	return string(all), res.Header.Get("Etag"), nil | ||||
| } | ||||
|  | ||||
| @ -367,6 +367,16 @@ func (c *Client) InternalIP() (string, error) { | ||||
| 	return c.getTrimmed("instance/network-interfaces/0/ip") | ||||
| } | ||||
|  | ||||
| // Email returns the email address associated with the service account. | ||||
| // The account may be empty or the string "default" to use the instance's | ||||
| // main account. | ||||
| func (c *Client) Email(serviceAccount string) (string, error) { | ||||
| 	if serviceAccount == "" { | ||||
| 		serviceAccount = "default" | ||||
| 	} | ||||
| 	return c.getTrimmed("instance/service-accounts/" + serviceAccount + "/email") | ||||
| } | ||||
|  | ||||
| // ExternalIP returns the instance's primary external (public) IP address. | ||||
| func (c *Client) ExternalIP() (string, error) { | ||||
| 	return c.getTrimmed("instance/network-interfaces/0/access-configs/0/external-ip") | ||||
| @ -394,11 +404,7 @@ func (c *Client) InstanceTags() ([]string, error) { | ||||
|  | ||||
| // InstanceName returns the current VM's instance ID string. | ||||
| func (c *Client) InstanceName() (string, error) { | ||||
| 	host, err := c.Hostname() | ||||
| 	if err != nil { | ||||
| 		return "", err | ||||
| 	} | ||||
| 	return strings.Split(host, ".")[0], nil | ||||
| 	return c.getTrimmed("instance/name") | ||||
| } | ||||
|  | ||||
| // Zone returns the current VM's zone, such as "us-central1-b". | ||||
| @ -499,3 +505,15 @@ func (c *Client) Subscribe(suffix string, fn func(v string, ok bool) error) erro | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Error contains an error response from the server. | ||||
| type Error struct { | ||||
| 	// Code is the HTTP response status code. | ||||
| 	Code int | ||||
| 	// Message is the server response message. | ||||
| 	Message string | ||||
| } | ||||
|  | ||||
| func (e *Error) Error() string { | ||||
| 	return fmt.Sprintf("compute: Received %d `%s`", e.Code, e.Message) | ||||
| } | ||||
|  | ||||
							
								
								
									
										201
									
								
								vendor/github.com/go-logr/logr/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								vendor/github.com/go-logr/logr/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,201 @@ | ||||
|                                  Apache License | ||||
|                            Version 2.0, January 2004 | ||||
|                         http://www.apache.org/licenses/ | ||||
|  | ||||
|    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
|    1. Definitions. | ||||
|  | ||||
|       "License" shall mean the terms and conditions for use, reproduction, | ||||
|       and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
|       "Licensor" shall mean the copyright owner or entity authorized by | ||||
|       the copyright owner that is granting the License. | ||||
|  | ||||
|       "Legal Entity" shall mean the union of the acting entity and all | ||||
|       other entities that control, are controlled by, or are under common | ||||
|       control with that entity. For the purposes of this definition, | ||||
|       "control" means (i) the power, direct or indirect, to cause the | ||||
|       direction or management of such entity, whether by contract or | ||||
|       otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||
|       outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
|       "You" (or "Your") shall mean an individual or Legal Entity | ||||
|       exercising permissions granted by this License. | ||||
|  | ||||
|       "Source" form shall mean the preferred form for making modifications, | ||||
|       including but not limited to software source code, documentation | ||||
|       source, and configuration files. | ||||
|  | ||||
|       "Object" form shall mean any form resulting from mechanical | ||||
|       transformation or translation of a Source form, including but | ||||
|       not limited to compiled object code, generated documentation, | ||||
|       and conversions to other media types. | ||||
|  | ||||
|       "Work" shall mean the work of authorship, whether in Source or | ||||
|       Object form, made available under the License, as indicated by a | ||||
|       copyright notice that is included in or attached to the work | ||||
|       (an example is provided in the Appendix below). | ||||
|  | ||||
|       "Derivative Works" shall mean any work, whether in Source or Object | ||||
|       form, that is based on (or derived from) the Work and for which the | ||||
|       editorial revisions, annotations, elaborations, or other modifications | ||||
|       represent, as a whole, an original work of authorship. For the purposes | ||||
|       of this License, Derivative Works shall not include works that remain | ||||
|       separable from, or merely link (or bind by name) to the interfaces of, | ||||
|       the Work and Derivative Works thereof. | ||||
|  | ||||
|       "Contribution" shall mean any work of authorship, including | ||||
|       the original version of the Work and any modifications or additions | ||||
|       to that Work or Derivative Works thereof, that is intentionally | ||||
|       submitted to Licensor for inclusion in the Work by the copyright owner | ||||
|       or by an individual or Legal Entity authorized to submit on behalf of | ||||
|       the copyright owner. For the purposes of this definition, "submitted" | ||||
|       means any form of electronic, verbal, or written communication sent | ||||
|       to the Licensor or its representatives, including but not limited to | ||||
|       communication on electronic mailing lists, source code control systems, | ||||
|       and issue tracking systems that are managed by, or on behalf of, the | ||||
|       Licensor for the purpose of discussing and improving the Work, but | ||||
|       excluding communication that is conspicuously marked or otherwise | ||||
|       designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
|       "Contributor" shall mean Licensor and any individual or Legal Entity | ||||
|       on behalf of whom a Contribution has been received by Licensor and | ||||
|       subsequently incorporated within the Work. | ||||
|  | ||||
|    2. Grant of Copyright License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       copyright license to reproduce, prepare Derivative Works of, | ||||
|       publicly display, publicly perform, sublicense, and distribute the | ||||
|       Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
|    3. Grant of Patent License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       (except as stated in this section) patent license to make, have made, | ||||
|       use, offer to sell, sell, import, and otherwise transfer the Work, | ||||
|       where such license applies only to those patent claims licensable | ||||
|       by such Contributor that are necessarily infringed by their | ||||
|       Contribution(s) alone or by combination of their Contribution(s) | ||||
|       with the Work to which such Contribution(s) was submitted. If You | ||||
|       institute patent litigation against any entity (including a | ||||
|       cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||
|       or a Contribution incorporated within the Work constitutes direct | ||||
|       or contributory patent infringement, then any patent licenses | ||||
|       granted to You under this License for that Work shall terminate | ||||
|       as of the date such litigation is filed. | ||||
|  | ||||
|    4. Redistribution. You may reproduce and distribute copies of the | ||||
|       Work or Derivative Works thereof in any medium, with or without | ||||
|       modifications, and in Source or Object form, provided that You | ||||
|       meet the following conditions: | ||||
|  | ||||
|       (a) You must give any other recipients of the Work or | ||||
|           Derivative Works a copy of this License; and | ||||
|  | ||||
|       (b) You must cause any modified files to carry prominent notices | ||||
|           stating that You changed the files; and | ||||
|  | ||||
|       (c) You must retain, in the Source form of any Derivative Works | ||||
|           that You distribute, all copyright, patent, trademark, and | ||||
|           attribution notices from the Source form of the Work, | ||||
|           excluding those notices that do not pertain to any part of | ||||
|           the Derivative Works; and | ||||
|  | ||||
|       (d) If the Work includes a "NOTICE" text file as part of its | ||||
|           distribution, then any Derivative Works that You distribute must | ||||
|           include a readable copy of the attribution notices contained | ||||
|           within such NOTICE file, excluding those notices that do not | ||||
|           pertain to any part of the Derivative Works, in at least one | ||||
|           of the following places: within a NOTICE text file distributed | ||||
|           as part of the Derivative Works; within the Source form or | ||||
|           documentation, if provided along with the Derivative Works; or, | ||||
|           within a display generated by the Derivative Works, if and | ||||
|           wherever such third-party notices normally appear. The contents | ||||
|           of the NOTICE file are for informational purposes only and | ||||
|           do not modify the License. You may add Your own attribution | ||||
|           notices within Derivative Works that You distribute, alongside | ||||
|           or as an addendum to the NOTICE text from the Work, provided | ||||
|           that such additional attribution notices cannot be construed | ||||
|           as modifying the License. | ||||
|  | ||||
|       You may add Your own copyright statement to Your modifications and | ||||
|       may provide additional or different license terms and conditions | ||||
|       for use, reproduction, or distribution of Your modifications, or | ||||
|       for any such Derivative Works as a whole, provided Your use, | ||||
|       reproduction, and distribution of the Work otherwise complies with | ||||
|       the conditions stated in this License. | ||||
|  | ||||
|    5. Submission of Contributions. Unless You explicitly state otherwise, | ||||
|       any Contribution intentionally submitted for inclusion in the Work | ||||
|       by You to the Licensor shall be under the terms and conditions of | ||||
|       this License, without any additional terms or conditions. | ||||
|       Notwithstanding the above, nothing herein shall supersede or modify | ||||
|       the terms of any separate license agreement you may have executed | ||||
|       with Licensor regarding such Contributions. | ||||
|  | ||||
|    6. Trademarks. This License does not grant permission to use the trade | ||||
|       names, trademarks, service marks, or product names of the Licensor, | ||||
|       except as required for reasonable and customary use in describing the | ||||
|       origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
|    7. Disclaimer of Warranty. Unless required by applicable law or | ||||
|       agreed to in writing, Licensor provides the Work (and each | ||||
|       Contributor provides its Contributions) on an "AS IS" BASIS, | ||||
|       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
|       implied, including, without limitation, any warranties or conditions | ||||
|       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||
|       PARTICULAR PURPOSE. You are solely responsible for determining the | ||||
|       appropriateness of using or redistributing the Work and assume any | ||||
|       risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
|    8. Limitation of Liability. In no event and under no legal theory, | ||||
|       whether in tort (including negligence), contract, or otherwise, | ||||
|       unless required by applicable law (such as deliberate and grossly | ||||
|       negligent acts) or agreed to in writing, shall any Contributor be | ||||
|       liable to You for damages, including any direct, indirect, special, | ||||
|       incidental, or consequential damages of any character arising as a | ||||
|       result of this License or out of the use or inability to use the | ||||
|       Work (including but not limited to damages for loss of goodwill, | ||||
|       work stoppage, computer failure or malfunction, or any and all | ||||
|       other commercial damages or losses), even if such Contributor | ||||
|       has been advised of the possibility of such damages. | ||||
|  | ||||
|    9. Accepting Warranty or Additional Liability. While redistributing | ||||
|       the Work or Derivative Works thereof, You may choose to offer, | ||||
|       and charge a fee for, acceptance of support, warranty, indemnity, | ||||
|       or other liability obligations and/or rights consistent with this | ||||
|       License. However, in accepting such obligations, You may act only | ||||
|       on Your own behalf and on Your sole responsibility, not on behalf | ||||
|       of any other Contributor, and only if You agree to indemnify, | ||||
|       defend, and hold each Contributor harmless for any liability | ||||
|       incurred by, or claims asserted against, such Contributor by reason | ||||
|       of your accepting any such warranty or additional liability. | ||||
|  | ||||
|    END OF TERMS AND CONDITIONS | ||||
|  | ||||
|    APPENDIX: How to apply the Apache License to your work. | ||||
|  | ||||
|       To apply the Apache License to your work, attach the following | ||||
|       boilerplate notice, with the fields enclosed by brackets "{}" | ||||
|       replaced with your own identifying information. (Don't include | ||||
|       the brackets!)  The text should be enclosed in the appropriate | ||||
|       comment syntax for the file format. We also recommend that a | ||||
|       file or class name and description of purpose be included on the | ||||
|       same "printed page" as the copyright notice for easier | ||||
|       identification within third-party archives. | ||||
|  | ||||
|    Copyright {yyyy} {name of copyright owner} | ||||
|  | ||||
|    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. | ||||
							
								
								
									
										183
									
								
								vendor/github.com/go-logr/logr/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										183
									
								
								vendor/github.com/go-logr/logr/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,183 @@ | ||||
| # A more minimal logging API for Go | ||||
|  | ||||
| Before you consider this package, please read [this blog post by the | ||||
| inimitable Dave Cheney][warning-makes-no-sense].  I really appreciate what | ||||
| he has to say, and it largely aligns with my own experiences.  Too many | ||||
| choices of levels means inconsistent logs. | ||||
|  | ||||
| This package offers a purely abstract interface, based on these ideas but with | ||||
| a few twists.  Code can depend on just this interface and have the actual | ||||
| logging implementation be injected from callers.  Ideally only `main()` knows | ||||
| what logging implementation is being used. | ||||
|  | ||||
| # Differences from Dave's ideas | ||||
|  | ||||
| The main differences are: | ||||
|  | ||||
| 1) Dave basically proposes doing away with the notion of a logging API in favor | ||||
| of `fmt.Printf()`.  I disagree, especially when you consider things like output | ||||
| locations, timestamps, file and line decorations, and structured logging.  I | ||||
| restrict the API to just 2 types of logs: info and error. | ||||
|  | ||||
| Info logs are things you want to tell the user which are not errors.  Error | ||||
| logs are, well, errors.  If your code receives an `error` from a subordinate | ||||
| function call and is logging that `error` *and not returning it*, use error | ||||
| logs. | ||||
|  | ||||
| 2) Verbosity-levels on info logs.  This gives developers a chance to indicate | ||||
| arbitrary grades of importance for info logs, without assigning names with | ||||
| semantic meaning such as "warning", "trace", and "debug".  Superficially this | ||||
| may feel very similar, but the primary difference is the lack of semantics. | ||||
| Because verbosity is a numerical value, it's safe to assume that an app running | ||||
| with higher verbosity means more (and less important) logs will be generated. | ||||
|  | ||||
| This is a BETA grade API. | ||||
|  | ||||
| There are implementations for the following logging libraries: | ||||
|  | ||||
| - **github.com/google/glog**: [glogr](https://github.com/go-logr/glogr) | ||||
| - **k8s.io/klog**: [klogr](https://git.k8s.io/klog/klogr) | ||||
| - **go.uber.org/zap**: [zapr](https://github.com/go-logr/zapr) | ||||
| - **log** (the Go standard library logger): | ||||
|   [stdr](https://github.com/go-logr/stdr) | ||||
| - **github.com/sirupsen/logrus**: [logrusr](https://github.com/bombsimon/logrusr) | ||||
| - **github.com/wojas/genericr**: [genericr](https://github.com/wojas/genericr) (makes it easy to implement your own backend) | ||||
| - **logfmt** (Heroku style [logging](https://www.brandur.org/logfmt)): [logfmtr](https://github.com/iand/logfmtr) | ||||
|  | ||||
| # FAQ | ||||
|  | ||||
| ## Conceptual | ||||
|  | ||||
| ## Why structured logging? | ||||
|  | ||||
| - **Structured logs are more easily queriable**: Since you've got | ||||
|   key-value pairs, it's much easier to query your structured logs for | ||||
|   particular values by filtering on the contents of a particular key -- | ||||
|   think searching request logs for error codes, Kubernetes reconcilers for | ||||
|   the name and namespace of the reconciled object, etc | ||||
|  | ||||
| - **Structured logging makes it easier to have cross-referencable logs**: | ||||
|   Similarly to searchability, if you maintain conventions around your | ||||
|   keys, it becomes easy to gather all log lines related to a particular | ||||
|   concept. | ||||
|   | ||||
| - **Structured logs allow better dimensions of filtering**: if you have | ||||
|   structure to your logs, you've got more precise control over how much | ||||
|   information is logged -- you might choose in a particular configuration | ||||
|   to log certain keys but not others, only log lines where a certain key | ||||
|   matches a certain value, etc, instead of just having v-levels and names | ||||
|   to key off of. | ||||
|  | ||||
| - **Structured logs better represent structured data**: sometimes, the | ||||
|   data that you want to log is inherently structured (think tuple-link | ||||
|   objects).  Structured logs allow you to preserve that structure when | ||||
|   outputting. | ||||
|  | ||||
| ## Why V-levels? | ||||
|  | ||||
| **V-levels give operators an easy way to control the chattiness of log | ||||
| operations**.  V-levels provide a way for a given package to distinguish | ||||
| the relative importance or verbosity of a given log message.  Then, if | ||||
| a particular logger or package is logging too many messages, the user | ||||
| of the package can simply change the v-levels for that library.  | ||||
|  | ||||
| ## Why not more named levels, like Warning? | ||||
|  | ||||
| Read [Dave Cheney's post][warning-makes-no-sense].  Then read [Differences | ||||
| from Dave's ideas](#differences-from-daves-ideas). | ||||
|  | ||||
| ## Why not allow format strings, too? | ||||
|  | ||||
| **Format strings negate many of the benefits of structured logs**: | ||||
|  | ||||
| - They're not easily searchable without resorting to fuzzy searching, | ||||
|   regular expressions, etc | ||||
|  | ||||
| - They don't store structured data well, since contents are flattened into | ||||
|   a string | ||||
|  | ||||
| - They're not cross-referencable | ||||
|  | ||||
| - They don't compress easily, since the message is not constant | ||||
|  | ||||
| (unless you turn positional parameters into key-value pairs with numerical | ||||
| keys, at which point you've gotten key-value logging with meaningless | ||||
| keys) | ||||
|  | ||||
| ## Practical | ||||
|  | ||||
| ## Why key-value pairs, and not a map? | ||||
|  | ||||
| Key-value pairs are *much* easier to optimize, especially around | ||||
| allocations.  Zap (a structured logger that inspired logr's interface) has | ||||
| [performance measurements](https://github.com/uber-go/zap#performance) | ||||
| that show this quite nicely. | ||||
|  | ||||
| While the interface ends up being a little less obvious, you get | ||||
| potentially better performance, plus avoid making users type | ||||
| `map[string]string{}` every time they want to log. | ||||
|  | ||||
| ## What if my V-levels differ between libraries? | ||||
|  | ||||
| That's fine.  Control your V-levels on a per-logger basis, and use the | ||||
| `WithName` function to pass different loggers to different libraries. | ||||
|  | ||||
| Generally, you should take care to ensure that you have relatively | ||||
| consistent V-levels within a given logger, however, as this makes deciding | ||||
| on what verbosity of logs to request easier. | ||||
|  | ||||
| ## But I *really* want to use a format string! | ||||
|  | ||||
| That's not actually a question.  Assuming your question is "how do | ||||
| I convert my mental model of logging with format strings to logging with | ||||
| constant messages": | ||||
|  | ||||
| 1. figure out what the error actually is, as you'd write in a TL;DR style, | ||||
|    and use that as a message | ||||
|  | ||||
| 2. For every place you'd write a format specifier, look to the word before | ||||
|    it, and add that as a key value pair | ||||
|  | ||||
| For instance, consider the following examples (all taken from spots in the | ||||
| Kubernetes codebase): | ||||
|  | ||||
| - `klog.V(4).Infof("Client is returning errors: code %v, error %v", | ||||
|   responseCode, err)` becomes `logger.Error(err, "client returned an | ||||
|   error", "code", responseCode)` | ||||
|  | ||||
| - `klog.V(4).Infof("Got a Retry-After %ds response for attempt %d to %v", | ||||
|   seconds, retries, url)` becomes `logger.V(4).Info("got a retry-after | ||||
|   response when requesting url", "attempt", retries, "after | ||||
|   seconds", seconds, "url", url)` | ||||
|  | ||||
| If you *really* must use a format string, place it as a key value, and | ||||
| call `fmt.Sprintf` yourself -- for instance, `log.Printf("unable to | ||||
| reflect over type %T")` becomes `logger.Info("unable to reflect over | ||||
| type", "type", fmt.Sprintf("%T"))`.  In general though, the cases where | ||||
| this is necessary should be few and far between. | ||||
|  | ||||
| ## How do I choose my V-levels? | ||||
|  | ||||
| This is basically the only hard constraint: increase V-levels to denote | ||||
| more verbose or more debug-y logs. | ||||
|  | ||||
| Otherwise, you can start out with `0` as "you always want to see this", | ||||
| `1` as "common logging that you might *possibly* want to turn off", and | ||||
| `10` as "I would like to performance-test your log collection stack". | ||||
|  | ||||
| Then gradually choose levels in between as you need them, working your way | ||||
| down from 10 (for debug and trace style logs) and up from 1 (for chattier | ||||
| info-type logs). | ||||
|  | ||||
| ## How do I choose my keys | ||||
|  | ||||
| - make your keys human-readable | ||||
| - constant keys are generally a good idea | ||||
| - be consistent across your codebase | ||||
| - keys should naturally match parts of the message string | ||||
|  | ||||
| While key names are mostly unrestricted (and spaces are acceptable), | ||||
| it's generally a good idea to stick to printable ascii characters, or at | ||||
| least match the general character set of your log lines. | ||||
|  | ||||
| [warning-makes-no-sense]: http://dave.cheney.net/2015/11/05/lets-talk-about-logging | ||||
							
								
								
									
										35
									
								
								vendor/github.com/go-logr/logr/discard.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								vendor/github.com/go-logr/logr/discard.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | ||||
| package logr | ||||
|  | ||||
| // Discard returns a valid Logger that discards all messages logged to it. | ||||
| // It can be used whenever the caller is not interested in the logs. | ||||
| func Discard() Logger { | ||||
| 	return discardLogger{} | ||||
| } | ||||
|  | ||||
| // discardLogger is a Logger that discards all messages. | ||||
| type discardLogger struct{} | ||||
|  | ||||
| func (l discardLogger) Enabled() bool { | ||||
| 	return false | ||||
| } | ||||
|  | ||||
| func (l discardLogger) Info(msg string, keysAndValues ...interface{}) { | ||||
| } | ||||
|  | ||||
| func (l discardLogger) Error(err error, msg string, keysAndValues ...interface{}) { | ||||
| } | ||||
|  | ||||
| func (l discardLogger) V(level int) Logger { | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| func (l discardLogger) WithValues(keysAndValues ...interface{}) Logger { | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| func (l discardLogger) WithName(name string) Logger { | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| // Verify that it actually implements the interface | ||||
| var _ Logger = discardLogger{} | ||||
							
								
								
									
										3
									
								
								vendor/github.com/go-logr/logr/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								vendor/github.com/go-logr/logr/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| module github.com/go-logr/logr | ||||
|  | ||||
| go 1.14 | ||||
							
								
								
									
										222
									
								
								vendor/github.com/go-logr/logr/logr.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										222
									
								
								vendor/github.com/go-logr/logr/logr.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,222 @@ | ||||
| /* | ||||
| Copyright 2019 The logr 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. | ||||
| */ | ||||
|  | ||||
| // Package logr defines abstract interfaces for logging.  Packages can depend on | ||||
| // these interfaces and callers can implement logging in whatever way is | ||||
| // appropriate. | ||||
| // | ||||
| // This design derives from Dave Cheney's blog: | ||||
| //     http://dave.cheney.net/2015/11/05/lets-talk-about-logging | ||||
| // | ||||
| // This is a BETA grade API.  Until there is a significant 2nd implementation, | ||||
| // I don't really know how it will change. | ||||
| // | ||||
| // The logging specifically makes it non-trivial to use format strings, to encourage | ||||
| // attaching structured information instead of unstructured format strings. | ||||
| // | ||||
| // Usage | ||||
| // | ||||
| // Logging is done using a Logger.  Loggers can have name prefixes and named | ||||
| // values attached, so that all log messages logged with that Logger have some | ||||
| // base context associated. | ||||
| // | ||||
| // The term "key" is used to refer to the name associated with a particular | ||||
| // value, to disambiguate it from the general Logger name. | ||||
| // | ||||
| // For instance, suppose we're trying to reconcile the state of an object, and | ||||
| // we want to log that we've made some decision. | ||||
| // | ||||
| // With the traditional log package, we might write: | ||||
| //   log.Printf("decided to set field foo to value %q for object %s/%s", | ||||
| //       targetValue, object.Namespace, object.Name) | ||||
| // | ||||
| // With logr's structured logging, we'd write: | ||||
| //   // elsewhere in the file, set up the logger to log with the prefix of | ||||
| //   // "reconcilers", and the named value target-type=Foo, for extra context. | ||||
| //   log := mainLogger.WithName("reconcilers").WithValues("target-type", "Foo") | ||||
| // | ||||
| //   // later on... | ||||
| //   log.Info("setting foo on object", "value", targetValue, "object", object) | ||||
| // | ||||
| // Depending on our logging implementation, we could then make logging decisions | ||||
| // based on field values (like only logging such events for objects in a certain | ||||
| // namespace), or copy the structured information into a structured log store. | ||||
| // | ||||
| // For logging errors, Logger has a method called Error.  Suppose we wanted to | ||||
| // log an error while reconciling.  With the traditional log package, we might | ||||
| // write: | ||||
| //   log.Errorf("unable to reconcile object %s/%s: %v", object.Namespace, object.Name, err) | ||||
| // | ||||
| // With logr, we'd instead write: | ||||
| //   // assuming the above setup for log | ||||
| //   log.Error(err, "unable to reconcile object", "object", object) | ||||
| // | ||||
| // This functions similarly to: | ||||
| //   log.Info("unable to reconcile object", "error", err, "object", object) | ||||
| // | ||||
| // However, it ensures that a standard key for the error value ("error") is used | ||||
| // across all error logging.  Furthermore, certain implementations may choose to | ||||
| // attach additional information (such as stack traces) on calls to Error, so | ||||
| // it's preferred to use Error to log errors. | ||||
| // | ||||
| // Parts of a log line | ||||
| // | ||||
| // Each log message from a Logger has four types of context: | ||||
| // logger name, log verbosity, log message, and the named values. | ||||
| // | ||||
| // The Logger name consists of a series of name "segments" added by successive | ||||
| // calls to WithName.  These name segments will be joined in some way by the | ||||
| // underlying implementation.  It is strongly recommended that name segments | ||||
| // contain simple identifiers (letters, digits, and hyphen), and do not contain | ||||
| // characters that could muddle the log output or confuse the joining operation | ||||
| // (e.g.  whitespace, commas, periods, slashes, brackets, quotes, etc). | ||||
| // | ||||
| // Log verbosity represents how little a log matters.  Level zero, the default, | ||||
| // matters most.  Increasing levels matter less and less.  Try to avoid lots of | ||||
| // different verbosity levels, and instead provide useful keys, logger names, | ||||
| // and log messages for users to filter on.  It's illegal to pass a log level | ||||
| // below zero. | ||||
| // | ||||
| // The log message consists of a constant message attached to the log line. | ||||
| // This should generally be a simple description of what's occurring, and should | ||||
| // never be a format string. | ||||
| // | ||||
| // Variable information can then be attached using named values (key/value | ||||
| // pairs).  Keys are arbitrary strings, while values may be any Go value. | ||||
| // | ||||
| // Key Naming Conventions | ||||
| // | ||||
| // Keys are not strictly required to conform to any specification or regex, but | ||||
| // it is recommended that they: | ||||
| //   * be human-readable and meaningful (not auto-generated or simple ordinals) | ||||
| //   * be constant (not dependent on input data) | ||||
| //   * contain only printable characters | ||||
| //   * not contain whitespace or punctuation | ||||
| // | ||||
| // These guidelines help ensure that log data is processed properly regardless | ||||
| // of the log implementation.  For example, log implementations will try to | ||||
| // output JSON data or will store data for later database (e.g. SQL) queries. | ||||
| // | ||||
| // While users are generally free to use key names of their choice, it's | ||||
| // generally best to avoid using the following keys, as they're frequently used | ||||
| // by implementations: | ||||
| // | ||||
| // - `"caller"`: the calling information (file/line) of a particular log line. | ||||
| // - `"error"`: the underlying error value in the `Error` method. | ||||
| // - `"level"`: the log level. | ||||
| // - `"logger"`: the name of the associated logger. | ||||
| // - `"msg"`: the log message. | ||||
| // - `"stacktrace"`: the stack trace associated with a particular log line or | ||||
| //                   error (often from the `Error` message). | ||||
| // - `"ts"`: the timestamp for a log line. | ||||
| // | ||||
| // Implementations are encouraged to make use of these keys to represent the | ||||
| // above concepts, when necessary (for example, in a pure-JSON output form, it | ||||
| // would be necessary to represent at least message and timestamp as ordinary | ||||
| // named values). | ||||
| // | ||||
| // Implementations may choose to give callers access to the underlying | ||||
| // logging implementation.  The recommended pattern for this is: | ||||
| //   // Underlier exposes access to the underlying logging implementation. | ||||
| //   // Since callers only have a logr.Logger, they have to know which | ||||
| //   // implementation is in use, so this interface is less of an abstraction | ||||
| //   // and more of way to test type conversion. | ||||
| //   type Underlier interface { | ||||
| //       GetUnderlying() <underlying-type> | ||||
| //   } | ||||
| package logr | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| ) | ||||
|  | ||||
| // TODO: consider adding back in format strings if they're really needed | ||||
| // TODO: consider other bits of zap/zapcore functionality like ObjectMarshaller (for arbitrary objects) | ||||
| // TODO: consider other bits of glog functionality like Flush, InfoDepth, OutputStats | ||||
|  | ||||
| // Logger represents the ability to log messages, both errors and not. | ||||
| type Logger interface { | ||||
| 	// Enabled tests whether this Logger is enabled.  For example, commandline | ||||
| 	// flags might be used to set the logging verbosity and disable some info | ||||
| 	// logs. | ||||
| 	Enabled() bool | ||||
|  | ||||
| 	// Info logs a non-error message with the given key/value pairs as context. | ||||
| 	// | ||||
| 	// The msg argument should be used to add some constant description to | ||||
| 	// the log line.  The key/value pairs can then be used to add additional | ||||
| 	// variable information.  The key/value pairs should alternate string | ||||
| 	// keys and arbitrary values. | ||||
| 	Info(msg string, keysAndValues ...interface{}) | ||||
|  | ||||
| 	// Error logs an error, with the given message and key/value pairs as context. | ||||
| 	// It functions similarly to calling Info with the "error" named value, but may | ||||
| 	// have unique behavior, and should be preferred for logging errors (see the | ||||
| 	// package documentations for more information). | ||||
| 	// | ||||
| 	// The msg field should be used to add context to any underlying error, | ||||
| 	// while the err field should be used to attach the actual error that | ||||
| 	// triggered this log line, if present. | ||||
| 	Error(err error, msg string, keysAndValues ...interface{}) | ||||
|  | ||||
| 	// V returns an Logger value for a specific verbosity level, relative to | ||||
| 	// this Logger.  In other words, V values are additive.  V higher verbosity | ||||
| 	// level means a log message is less important.  It's illegal to pass a log | ||||
| 	// level less than zero. | ||||
| 	V(level int) Logger | ||||
|  | ||||
| 	// WithValues adds some key-value pairs of context to a logger. | ||||
| 	// See Info for documentation on how key/value pairs work. | ||||
| 	WithValues(keysAndValues ...interface{}) Logger | ||||
|  | ||||
| 	// WithName adds a new element to the logger's name. | ||||
| 	// Successive calls with WithName continue to append | ||||
| 	// suffixes to the logger's name.  It's strongly recommended | ||||
| 	// that name segments contain only letters, digits, and hyphens | ||||
| 	// (see the package documentation for more information). | ||||
| 	WithName(name string) Logger | ||||
| } | ||||
|  | ||||
| // InfoLogger provides compatibility with code that relies on the v0.1.0 interface | ||||
| // Deprecated: use Logger instead. This will be removed in a future release. | ||||
| type InfoLogger = Logger | ||||
|  | ||||
| type contextKey struct{} | ||||
|  | ||||
| // FromContext returns a Logger constructed from ctx or nil if no | ||||
| // logger details are found. | ||||
| func FromContext(ctx context.Context) Logger { | ||||
| 	if v, ok := ctx.Value(contextKey{}).(Logger); ok { | ||||
| 		return v | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // FromContextOrDiscard returns a Logger constructed from ctx or a Logger | ||||
| // that discards all messages if no logger details are found. | ||||
| func FromContextOrDiscard(ctx context.Context) Logger { | ||||
| 	if v, ok := ctx.Value(contextKey{}).(Logger); ok { | ||||
| 		return v | ||||
| 	} | ||||
|  | ||||
| 	return discardLogger{} | ||||
| } | ||||
|  | ||||
| // NewContext returns a new context derived from ctx that embeds the Logger. | ||||
| func NewContext(ctx context.Context, l Logger) context.Context { | ||||
| 	return context.WithValue(ctx, contextKey{}, l) | ||||
| } | ||||
							
								
								
									
										16
									
								
								vendor/github.com/go-ping/ping/.editorconfig
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								vendor/github.com/go-ping/ping/.editorconfig
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | ||||
| # https://editorconfig.org | ||||
|  | ||||
| root = true | ||||
|  | ||||
| [*] | ||||
| end_of_line = lf | ||||
| insert_final_newline = true | ||||
| trim_trailing_whitespace = true | ||||
| charset = utf-8 | ||||
| indent_style = space | ||||
|  | ||||
| [Makefile] | ||||
| indent_style = tab | ||||
|  | ||||
| [*.go] | ||||
| indent_style = tab | ||||
							
								
								
									
										2
									
								
								vendor/github.com/go-ping/ping/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/go-ping/ping/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | ||||
| /ping | ||||
| /dist | ||||
							
								
								
									
										6
									
								
								vendor/github.com/go-ping/ping/.golangci.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								vendor/github.com/go-ping/ping/.golangci.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| --- | ||||
| issues: | ||||
|   exclude-rules: | ||||
|   - path: _test.go | ||||
|     linters: | ||||
|     - errcheck | ||||
							
								
								
									
										46
									
								
								vendor/github.com/go-ping/ping/.goreleaser.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								vendor/github.com/go-ping/ping/.goreleaser.yml
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,46 @@ | ||||
| project_name: ping | ||||
| before: | ||||
|   hooks: | ||||
|   - go mod download | ||||
| builds: | ||||
| - binary: ping | ||||
|   dir: cmd/ping | ||||
|   goarch: | ||||
|   - amd64 | ||||
|   - arm | ||||
|   - arm64 | ||||
|   goarm: | ||||
|   - 6 | ||||
|   - 7 | ||||
|   goos: | ||||
|   - darwin | ||||
|   - freebsd | ||||
|   - linux | ||||
|   - windows | ||||
| archives: | ||||
| - files: | ||||
|   - LICENSE | ||||
|   - README.md | ||||
|   format_overrides: | ||||
|   - goos: windows | ||||
|     format: zip | ||||
|   wrap_in_directory: true | ||||
| # TODO: Decide if we want packages (name conflcits with /bin/ping?) | ||||
| # nfpms: | ||||
| #   homepage: https://github.com/go-ping/ping | ||||
| #   maintainer: 'Go Ping Maintainers <go-ping@example.com>' | ||||
| #   description: Ping written in Go. | ||||
| #   license: MIT | ||||
| #   formats: | ||||
| #   - deb | ||||
| #   - rpm | ||||
| checksum: | ||||
|   name_template: 'checksums.txt' | ||||
| snapshot: | ||||
|   name_template: "{{ .Tag }}-{{ .ShortCommit }}" | ||||
| changelog: | ||||
|   sort: asc | ||||
|   filters: | ||||
|     exclude: | ||||
|     - '^docs:' | ||||
|     - '^test:' | ||||
							
								
								
									
										21
									
								
								vendor/github.com/go-ping/ping/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/github.com/go-ping/ping/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2016 Cameron Sparr and contributors. | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
							
								
								
									
										32
									
								
								vendor/github.com/go-ping/ping/Makefile
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/github.com/go-ping/ping/Makefile
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | ||||
| GO           ?= go | ||||
| GOFMT        ?= $(GO)fmt | ||||
| GOOPTS       ?= | ||||
| GO111MODULE  := | ||||
| pkgs          = ./... | ||||
|  | ||||
| all: style vet build test | ||||
|  | ||||
| .PHONY: build | ||||
| build: | ||||
| 	@echo ">> building ping" | ||||
| 	GO111MODULE=$(GO111MODULE) $(GO) build $(GOOPTS) ./cmd/ping | ||||
|  | ||||
| .PHONY: style | ||||
| style: | ||||
| 	@echo ">> checking code style" | ||||
| 	@fmtRes=$$($(GOFMT) -d $$(find . -path ./vendor -prune -o -name '*.go' -print)); \ | ||||
| 	if [ -n "$${fmtRes}" ]; then \ | ||||
| 		echo "gofmt checking failed!"; echo "$${fmtRes}"; echo; \ | ||||
| 		echo "Please ensure you are using $$($(GO) version) for formatting code."; \ | ||||
| 		exit 1; \ | ||||
| 	fi | ||||
|  | ||||
| .PHONY: test | ||||
| test: | ||||
| 	@echo ">> running all tests" | ||||
| 	GO111MODULE=$(GO111MODULE) $(GO) test -race -cover $(GOOPTS) $(pkgs) | ||||
|  | ||||
| .PHONY: vet | ||||
| vet: | ||||
| 	@echo ">> vetting code" | ||||
| 	GO111MODULE=$(GO111MODULE) $(GO) vet $(GOOPTS) $(pkgs) | ||||
							
								
								
									
										130
									
								
								vendor/github.com/go-ping/ping/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								vendor/github.com/go-ping/ping/README.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,130 @@ | ||||
| # go-ping | ||||
| [](https://pkg.go.dev/github.com/go-ping/ping) | ||||
| [](https://circleci.com/gh/go-ping/ping) | ||||
|  | ||||
| A simple but powerful ICMP echo (ping) library for Go, inspired by | ||||
| [go-fastping](https://github.com/tatsushid/go-fastping). | ||||
|  | ||||
| Here is a very simple example that sends and receives three packets: | ||||
|  | ||||
| ```go | ||||
| pinger, err := ping.NewPinger("www.google.com") | ||||
| if err != nil { | ||||
| 	panic(err) | ||||
| } | ||||
| pinger.Count = 3 | ||||
| err = pinger.Run() // Blocks until finished. | ||||
| if err != nil { | ||||
| 	panic(err) | ||||
| } | ||||
| stats := pinger.Statistics() // get send/receive/rtt stats | ||||
| ``` | ||||
|  | ||||
| Here is an example that emulates the traditional UNIX ping command: | ||||
|  | ||||
| ```go | ||||
| pinger, err := ping.NewPinger("www.google.com") | ||||
| if err != nil { | ||||
| 	panic(err) | ||||
| } | ||||
|  | ||||
| // Listen for Ctrl-C. | ||||
| c := make(chan os.Signal, 1) | ||||
| signal.Notify(c, os.Interrupt) | ||||
| go func() { | ||||
| 	for _ = range c { | ||||
| 		pinger.Stop() | ||||
| 	} | ||||
| }() | ||||
|  | ||||
| pinger.OnRecv = func(pkt *ping.Packet) { | ||||
| 	fmt.Printf("%d bytes from %s: icmp_seq=%d time=%v\n", | ||||
| 		pkt.Nbytes, pkt.IPAddr, pkt.Seq, pkt.Rtt) | ||||
| } | ||||
|  | ||||
| pinger.OnFinish = func(stats *ping.Statistics) { | ||||
| 	fmt.Printf("\n--- %s ping statistics ---\n", stats.Addr) | ||||
| 	fmt.Printf("%d packets transmitted, %d packets received, %v%% packet loss\n", | ||||
| 		stats.PacketsSent, stats.PacketsRecv, stats.PacketLoss) | ||||
| 	fmt.Printf("round-trip min/avg/max/stddev = %v/%v/%v/%v\n", | ||||
| 		stats.MinRtt, stats.AvgRtt, stats.MaxRtt, stats.StdDevRtt) | ||||
| } | ||||
|  | ||||
| fmt.Printf("PING %s (%s):\n", pinger.Addr(), pinger.IPAddr()) | ||||
| err = pinger.Run() | ||||
| if err != nil { | ||||
| 	panic(err) | ||||
| } | ||||
| ``` | ||||
|  | ||||
| It sends ICMP Echo Request packet(s) and waits for an Echo Reply in | ||||
| response. If it receives a response, it calls the `OnRecv` callback. | ||||
| When it's finished, it calls the `OnFinish` callback. | ||||
|  | ||||
| For a full ping example, see | ||||
| [cmd/ping/ping.go](https://github.com/go-ping/ping/blob/master/cmd/ping/ping.go). | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| ``` | ||||
| go get -u github.com/go-ping/ping | ||||
| ``` | ||||
|  | ||||
| To install the native Go ping executable: | ||||
|  | ||||
| ```bash | ||||
| go get -u github.com/go-ping/ping/... | ||||
| $GOPATH/bin/ping | ||||
| ``` | ||||
|  | ||||
| ## Supported Operating Systems | ||||
|  | ||||
| ### Linux | ||||
| This library attempts to send an "unprivileged" ping via UDP. On Linux, | ||||
| this must be enabled with the following sysctl command: | ||||
|  | ||||
| ``` | ||||
| sudo sysctl -w net.ipv4.ping_group_range="0 2147483647" | ||||
| ``` | ||||
|  | ||||
| If you do not wish to do this, you can call `pinger.SetPrivileged(true)` | ||||
| in your code and then use setcap on your binary to allow it to bind to | ||||
| raw sockets (or just run it as root): | ||||
|  | ||||
| ``` | ||||
| setcap cap_net_raw=+ep /path/to/your/compiled/binary | ||||
| ``` | ||||
|  | ||||
| See [this blog](https://sturmflut.github.io/linux/ubuntu/2015/01/17/unprivileged-icmp-sockets-on-linux/) | ||||
| and the Go [x/net/icmp](https://godoc.org/golang.org/x/net/icmp) package | ||||
| for more details. | ||||
|  | ||||
| ### Windows | ||||
|  | ||||
| You must use `pinger.SetPrivileged(true)`, otherwise you will receive | ||||
| the following error: | ||||
|  | ||||
| ``` | ||||
| socket: The requested protocol has not been configured into the system, or no implementation for it exists. | ||||
| ``` | ||||
|  | ||||
| Despite the method name, this should work without the need to elevate | ||||
| privileges and has been tested on Windows 10. Please note that accessing | ||||
| packet TTL values is not supported due to limitations in the Go | ||||
| x/net/ipv4 and x/net/ipv6 packages. | ||||
|  | ||||
| ### Plan 9 from Bell Labs | ||||
|  | ||||
| There is no support for Plan 9. This is because the entire `x/net/ipv4`  | ||||
| and `x/net/ipv6` packages are not implemented by the Go programming  | ||||
| language. | ||||
|  | ||||
| ## Maintainers and Getting Help: | ||||
|  | ||||
| This repo was originally in the personal account of | ||||
| [sparrc](https://github.com/sparrc), but is now maintained by the | ||||
| [go-ping organization](https://github.com/go-ping). | ||||
|  | ||||
| For support and help, you usually find us in the #go-ping channel of | ||||
| Gophers Slack. See https://invite.slack.golangbridge.org/ for an invite | ||||
| to the Gophers Slack org. | ||||
							
								
								
									
										5
									
								
								vendor/github.com/go-ping/ping/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								vendor/github.com/go-ping/ping/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
| module github.com/go-ping/ping | ||||
|  | ||||
| go 1.14 | ||||
|  | ||||
| require golang.org/x/net v0.0.0-20200904194848-62affa334b73 | ||||
							
								
								
									
										10
									
								
								vendor/github.com/go-ping/ping/go.sum
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								vendor/github.com/go-ping/ping/go.sum
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20200904194848-62affa334b73 h1:MXfv8rhZWmFeqX3GNZRsd6vOLoaCHjYEX3qkRo3YBUA= | ||||
| golang.org/x/net v0.0.0-20200904194848-62affa334b73/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd h1:xhmwyvizuTgC2qz7ZlMluP20uW+C3Rm0FD/WLDX8884= | ||||
| golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
							
								
								
									
										669
									
								
								vendor/github.com/go-ping/ping/ping.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										669
									
								
								vendor/github.com/go-ping/ping/ping.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,669 @@ | ||||
| // Package ping is a simple but powerful ICMP echo (ping) library. | ||||
| // | ||||
| // Here is a very simple example that sends and receives three packets: | ||||
| // | ||||
| //	pinger, err := ping.NewPinger("www.google.com") | ||||
| //	if err != nil { | ||||
| //		panic(err) | ||||
| //	} | ||||
| //	pinger.Count = 3 | ||||
| //	err = pinger.Run() // blocks until finished | ||||
| //	if err != nil { | ||||
| //		panic(err) | ||||
| //	} | ||||
| //	stats := pinger.Statistics() // get send/receive/rtt stats | ||||
| // | ||||
| // Here is an example that emulates the traditional UNIX ping command: | ||||
| // | ||||
| //	pinger, err := ping.NewPinger("www.google.com") | ||||
| //	if err != nil { | ||||
| //		panic(err) | ||||
| //	} | ||||
| //	// Listen for Ctrl-C. | ||||
| //	c := make(chan os.Signal, 1) | ||||
| //	signal.Notify(c, os.Interrupt) | ||||
| //	go func() { | ||||
| //		for _ = range c { | ||||
| //			pinger.Stop() | ||||
| //		} | ||||
| //	}() | ||||
| //	pinger.OnRecv = func(pkt *ping.Packet) { | ||||
| //		fmt.Printf("%d bytes from %s: icmp_seq=%d time=%v\n", | ||||
| //			pkt.Nbytes, pkt.IPAddr, pkt.Seq, pkt.Rtt) | ||||
| //	} | ||||
| //	pinger.OnFinish = func(stats *ping.Statistics) { | ||||
| //		fmt.Printf("\n--- %s ping statistics ---\n", stats.Addr) | ||||
| //		fmt.Printf("%d packets transmitted, %d packets received, %v%% packet loss\n", | ||||
| //			stats.PacketsSent, stats.PacketsRecv, stats.PacketLoss) | ||||
| //		fmt.Printf("round-trip min/avg/max/stddev = %v/%v/%v/%v\n", | ||||
| //			stats.MinRtt, stats.AvgRtt, stats.MaxRtt, stats.StdDevRtt) | ||||
| //	} | ||||
| //	fmt.Printf("PING %s (%s):\n", pinger.Addr(), pinger.IPAddr()) | ||||
| //	err = pinger.Run() | ||||
| //	if err != nil { | ||||
| //		panic(err) | ||||
| //	} | ||||
| // | ||||
| // It sends ICMP Echo Request packet(s) and waits for an Echo Reply in response. | ||||
| // If it receives a response, it calls the OnRecv callback. When it's finished, | ||||
| // it calls the OnFinish callback. | ||||
| // | ||||
| // For a full ping example, see "cmd/ping/ping.go". | ||||
| // | ||||
| package ping | ||||
|  | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"encoding/binary" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"math" | ||||
| 	"math/rand" | ||||
| 	"net" | ||||
| 	"runtime" | ||||
| 	"sync" | ||||
| 	"syscall" | ||||
| 	"time" | ||||
|  | ||||
| 	"golang.org/x/net/icmp" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	timeSliceLength  = 8 | ||||
| 	trackerLength    = 8 | ||||
| 	protocolICMP     = 1 | ||||
| 	protocolIPv6ICMP = 58 | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| 	ipv4Proto = map[string]string{"icmp": "ip4:icmp", "udp": "udp4"} | ||||
| 	ipv6Proto = map[string]string{"icmp": "ip6:ipv6-icmp", "udp": "udp6"} | ||||
| ) | ||||
|  | ||||
| // New returns a new Pinger struct pointer. | ||||
| func New(addr string) *Pinger { | ||||
| 	r := rand.New(rand.NewSource(time.Now().UnixNano())) | ||||
| 	return &Pinger{ | ||||
| 		Count:      -1, | ||||
| 		Interval:   time.Second, | ||||
| 		RecordRtts: true, | ||||
| 		Size:       timeSliceLength, | ||||
| 		Timeout:    time.Second * 100000, | ||||
| 		Tracker:    r.Int63n(math.MaxInt64), | ||||
|  | ||||
| 		addr:     addr, | ||||
| 		done:     make(chan bool), | ||||
| 		id:       r.Intn(math.MaxInt16), | ||||
| 		ipaddr:   nil, | ||||
| 		ipv4:     false, | ||||
| 		network:  "ip", | ||||
| 		protocol: "udp", | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // NewPinger returns a new Pinger and resolves the address. | ||||
| func NewPinger(addr string) (*Pinger, error) { | ||||
| 	p := New(addr) | ||||
| 	return p, p.Resolve() | ||||
| } | ||||
|  | ||||
| // Pinger represents a packet sender/receiver. | ||||
| type Pinger struct { | ||||
| 	// Interval is the wait time between each packet send. Default is 1s. | ||||
| 	Interval time.Duration | ||||
|  | ||||
| 	// Timeout specifies a timeout before ping exits, regardless of how many | ||||
| 	// packets have been received. | ||||
| 	Timeout time.Duration | ||||
|  | ||||
| 	// Count tells pinger to stop after sending (and receiving) Count echo | ||||
| 	// packets. If this option is not specified, pinger will operate until | ||||
| 	// interrupted. | ||||
| 	Count int | ||||
|  | ||||
| 	// Debug runs in debug mode | ||||
| 	Debug bool | ||||
|  | ||||
| 	// Number of packets sent | ||||
| 	PacketsSent int | ||||
|  | ||||
| 	// Number of packets received | ||||
| 	PacketsRecv int | ||||
|  | ||||
| 	// If true, keep a record of rtts of all received packets. | ||||
| 	// Set to false to avoid memory bloat for long running pings. | ||||
| 	RecordRtts bool | ||||
|  | ||||
| 	// rtts is all of the Rtts | ||||
| 	rtts []time.Duration | ||||
|  | ||||
| 	// OnSend is called when Pinger sends a packet | ||||
| 	OnSend func(*Packet) | ||||
|  | ||||
| 	// OnRecv is called when Pinger receives and processes a packet | ||||
| 	OnRecv func(*Packet) | ||||
|  | ||||
| 	// OnFinish is called when Pinger exits | ||||
| 	OnFinish func(*Statistics) | ||||
|  | ||||
| 	// Size of packet being sent | ||||
| 	Size int | ||||
|  | ||||
| 	// Tracker: Used to uniquely identify packet when non-priviledged | ||||
| 	Tracker int64 | ||||
|  | ||||
| 	// Source is the source IP address | ||||
| 	Source string | ||||
|  | ||||
| 	// stop chan bool | ||||
| 	done chan bool | ||||
|  | ||||
| 	ipaddr *net.IPAddr | ||||
| 	addr   string | ||||
|  | ||||
| 	ipv4     bool | ||||
| 	id       int | ||||
| 	sequence int | ||||
| 	// network is one of "ip", "ip4", or "ip6". | ||||
| 	network string | ||||
| 	// protocol is "icmp" or "udp". | ||||
| 	protocol string | ||||
| } | ||||
|  | ||||
| type packet struct { | ||||
| 	bytes  []byte | ||||
| 	nbytes int | ||||
| 	ttl    int | ||||
| } | ||||
|  | ||||
| // Packet represents a received and processed ICMP echo packet. | ||||
| type Packet struct { | ||||
| 	// Rtt is the round-trip time it took to ping. | ||||
| 	Rtt time.Duration | ||||
|  | ||||
| 	// IPAddr is the address of the host being pinged. | ||||
| 	IPAddr *net.IPAddr | ||||
|  | ||||
| 	// Addr is the string address of the host being pinged. | ||||
| 	Addr string | ||||
|  | ||||
| 	// NBytes is the number of bytes in the message. | ||||
| 	Nbytes int | ||||
|  | ||||
| 	// Seq is the ICMP sequence number. | ||||
| 	Seq int | ||||
|  | ||||
| 	// TTL is the Time To Live on the packet. | ||||
| 	Ttl int | ||||
| } | ||||
|  | ||||
| // Statistics represent the stats of a currently running or finished | ||||
| // pinger operation. | ||||
| type Statistics struct { | ||||
| 	// PacketsRecv is the number of packets received. | ||||
| 	PacketsRecv int | ||||
|  | ||||
| 	// PacketsSent is the number of packets sent. | ||||
| 	PacketsSent int | ||||
|  | ||||
| 	// PacketLoss is the percentage of packets lost. | ||||
| 	PacketLoss float64 | ||||
|  | ||||
| 	// IPAddr is the address of the host being pinged. | ||||
| 	IPAddr *net.IPAddr | ||||
|  | ||||
| 	// Addr is the string address of the host being pinged. | ||||
| 	Addr string | ||||
|  | ||||
| 	// Rtts is all of the round-trip times sent via this pinger. | ||||
| 	Rtts []time.Duration | ||||
|  | ||||
| 	// MinRtt is the minimum round-trip time sent via this pinger. | ||||
| 	MinRtt time.Duration | ||||
|  | ||||
| 	// MaxRtt is the maximum round-trip time sent via this pinger. | ||||
| 	MaxRtt time.Duration | ||||
|  | ||||
| 	// AvgRtt is the average round-trip time sent via this pinger. | ||||
| 	AvgRtt time.Duration | ||||
|  | ||||
| 	// StdDevRtt is the standard deviation of the round-trip times sent via | ||||
| 	// this pinger. | ||||
| 	StdDevRtt time.Duration | ||||
| } | ||||
|  | ||||
| // SetIPAddr sets the ip address of the target host. | ||||
| func (p *Pinger) SetIPAddr(ipaddr *net.IPAddr) { | ||||
| 	p.ipv4 = isIPv4(ipaddr.IP) | ||||
|  | ||||
| 	p.ipaddr = ipaddr | ||||
| 	p.addr = ipaddr.String() | ||||
| } | ||||
|  | ||||
| // IPAddr returns the ip address of the target host. | ||||
| func (p *Pinger) IPAddr() *net.IPAddr { | ||||
| 	return p.ipaddr | ||||
| } | ||||
|  | ||||
| // Resolve does the DNS lookup for the Pinger address and sets IP protocol. | ||||
| func (p *Pinger) Resolve() error { | ||||
| 	if len(p.addr) == 0 { | ||||
| 		return errors.New("addr cannot be empty") | ||||
| 	} | ||||
| 	ipaddr, err := net.ResolveIPAddr(p.network, p.addr) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	p.ipv4 = isIPv4(ipaddr.IP) | ||||
|  | ||||
| 	p.ipaddr = ipaddr | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // SetAddr resolves and sets the ip address of the target host, addr can be a | ||||
| // DNS name like "www.google.com" or IP like "127.0.0.1". | ||||
| func (p *Pinger) SetAddr(addr string) error { | ||||
| 	oldAddr := p.addr | ||||
| 	p.addr = addr | ||||
| 	err := p.Resolve() | ||||
| 	if err != nil { | ||||
| 		p.addr = oldAddr | ||||
| 		return err | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // Addr returns the string ip address of the target host. | ||||
| func (p *Pinger) Addr() string { | ||||
| 	return p.addr | ||||
| } | ||||
|  | ||||
| // SetNetwork allows configuration of DNS resolution. | ||||
| // * "ip" will automatically select IPv4 or IPv6. | ||||
| // * "ip4" will select IPv4. | ||||
| // * "ip6" will select IPv6. | ||||
| func (p *Pinger) SetNetwork(n string) { | ||||
| 	switch n { | ||||
| 	case "ip4": | ||||
| 		p.network = "ip4" | ||||
| 	case "ip6": | ||||
| 		p.network = "ip6" | ||||
| 	default: | ||||
| 		p.network = "ip" | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // SetPrivileged sets the type of ping pinger will send. | ||||
| // false means pinger will send an "unprivileged" UDP ping. | ||||
| // true means pinger will send a "privileged" raw ICMP ping. | ||||
| // NOTE: setting to true requires that it be run with super-user privileges. | ||||
| func (p *Pinger) SetPrivileged(privileged bool) { | ||||
| 	if privileged { | ||||
| 		p.protocol = "icmp" | ||||
| 	} else { | ||||
| 		p.protocol = "udp" | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Privileged returns whether pinger is running in privileged mode. | ||||
| func (p *Pinger) Privileged() bool { | ||||
| 	return p.protocol == "icmp" | ||||
| } | ||||
|  | ||||
| // Run runs the pinger. This is a blocking function that will exit when it's | ||||
| // done. If Count or Interval are not specified, it will run continuously until | ||||
| // it is interrupted. | ||||
| func (p *Pinger) Run() error { | ||||
| 	var conn *icmp.PacketConn | ||||
| 	var err error | ||||
| 	if p.ipaddr == nil { | ||||
| 		err = p.Resolve() | ||||
| 	} | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if p.ipv4 { | ||||
| 		if conn, err = p.listen(ipv4Proto[p.protocol]); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if err = conn.IPv4PacketConn().SetControlMessage(ipv4.FlagTTL, true); runtime.GOOS != "windows" && err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		if conn, err = p.listen(ipv6Proto[p.protocol]); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if err = conn.IPv6PacketConn().SetControlMessage(ipv6.FlagHopLimit, true); runtime.GOOS != "windows" && err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	defer conn.Close() | ||||
| 	defer p.finish() | ||||
|  | ||||
| 	var wg sync.WaitGroup | ||||
| 	recv := make(chan *packet, 5) | ||||
| 	defer close(recv) | ||||
| 	wg.Add(1) | ||||
| 	//nolint:errcheck | ||||
| 	go p.recvICMP(conn, recv, &wg) | ||||
|  | ||||
| 	err = p.sendICMP(conn) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	timeout := time.NewTicker(p.Timeout) | ||||
| 	defer timeout.Stop() | ||||
| 	interval := time.NewTicker(p.Interval) | ||||
| 	defer interval.Stop() | ||||
|  | ||||
| 	for { | ||||
| 		select { | ||||
| 		case <-p.done: | ||||
| 			wg.Wait() | ||||
| 			return nil | ||||
| 		case <-timeout.C: | ||||
| 			close(p.done) | ||||
| 			wg.Wait() | ||||
| 			return nil | ||||
| 		case <-interval.C: | ||||
| 			if p.Count > 0 && p.PacketsSent >= p.Count { | ||||
| 				continue | ||||
| 			} | ||||
| 			err = p.sendICMP(conn) | ||||
| 			if err != nil { | ||||
| 				// FIXME: this logs as FATAL but continues | ||||
| 				fmt.Println("FATAL: ", err.Error()) | ||||
| 			} | ||||
| 		case r := <-recv: | ||||
| 			err := p.processPacket(r) | ||||
| 			if err != nil { | ||||
| 				// FIXME: this logs as FATAL but continues | ||||
| 				fmt.Println("FATAL: ", err.Error()) | ||||
| 			} | ||||
| 		} | ||||
| 		if p.Count > 0 && p.PacketsRecv >= p.Count { | ||||
| 			close(p.done) | ||||
| 			wg.Wait() | ||||
| 			return nil | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (p *Pinger) Stop() { | ||||
| 	close(p.done) | ||||
| } | ||||
|  | ||||
| func (p *Pinger) finish() { | ||||
| 	handler := p.OnFinish | ||||
| 	if handler != nil { | ||||
| 		s := p.Statistics() | ||||
| 		handler(s) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Statistics returns the statistics of the pinger. This can be run while the | ||||
| // pinger is running or after it is finished. OnFinish calls this function to | ||||
| // get it's finished statistics. | ||||
| func (p *Pinger) Statistics() *Statistics { | ||||
| 	loss := float64(p.PacketsSent-p.PacketsRecv) / float64(p.PacketsSent) * 100 | ||||
| 	var min, max, total time.Duration | ||||
| 	if len(p.rtts) > 0 { | ||||
| 		min = p.rtts[0] | ||||
| 		max = p.rtts[0] | ||||
| 	} | ||||
| 	for _, rtt := range p.rtts { | ||||
| 		if rtt < min { | ||||
| 			min = rtt | ||||
| 		} | ||||
| 		if rtt > max { | ||||
| 			max = rtt | ||||
| 		} | ||||
| 		total += rtt | ||||
| 	} | ||||
| 	s := Statistics{ | ||||
| 		PacketsSent: p.PacketsSent, | ||||
| 		PacketsRecv: p.PacketsRecv, | ||||
| 		PacketLoss:  loss, | ||||
| 		Rtts:        p.rtts, | ||||
| 		Addr:        p.addr, | ||||
| 		IPAddr:      p.ipaddr, | ||||
| 		MaxRtt:      max, | ||||
| 		MinRtt:      min, | ||||
| 	} | ||||
| 	if len(p.rtts) > 0 { | ||||
| 		s.AvgRtt = total / time.Duration(len(p.rtts)) | ||||
| 		var sumsquares time.Duration | ||||
| 		for _, rtt := range p.rtts { | ||||
| 			sumsquares += (rtt - s.AvgRtt) * (rtt - s.AvgRtt) | ||||
| 		} | ||||
| 		s.StdDevRtt = time.Duration(math.Sqrt( | ||||
| 			float64(sumsquares / time.Duration(len(p.rtts))))) | ||||
| 	} | ||||
| 	return &s | ||||
| } | ||||
|  | ||||
| func (p *Pinger) recvICMP( | ||||
| 	conn *icmp.PacketConn, | ||||
| 	recv chan<- *packet, | ||||
| 	wg *sync.WaitGroup, | ||||
| ) error { | ||||
| 	defer wg.Done() | ||||
| 	for { | ||||
| 		select { | ||||
| 		case <-p.done: | ||||
| 			return nil | ||||
| 		default: | ||||
| 			bytes := make([]byte, 512) | ||||
| 			if err := conn.SetReadDeadline(time.Now().Add(time.Millisecond * 100)); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			var n, ttl int | ||||
| 			var err error | ||||
| 			if p.ipv4 { | ||||
| 				var cm *ipv4.ControlMessage | ||||
| 				n, cm, _, err = conn.IPv4PacketConn().ReadFrom(bytes) | ||||
| 				if cm != nil { | ||||
| 					ttl = cm.TTL | ||||
| 				} | ||||
| 			} else { | ||||
| 				var cm *ipv6.ControlMessage | ||||
| 				n, cm, _, err = conn.IPv6PacketConn().ReadFrom(bytes) | ||||
| 				if cm != nil { | ||||
| 					ttl = cm.HopLimit | ||||
| 				} | ||||
| 			} | ||||
| 			if err != nil { | ||||
| 				if neterr, ok := err.(*net.OpError); ok { | ||||
| 					if neterr.Timeout() { | ||||
| 						// Read timeout | ||||
| 						continue | ||||
| 					} else { | ||||
| 						close(p.done) | ||||
| 						return err | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			select { | ||||
| 			case <-p.done: | ||||
| 				return nil | ||||
| 			case recv <- &packet{bytes: bytes, nbytes: n, ttl: ttl}: | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (p *Pinger) processPacket(recv *packet) error { | ||||
| 	receivedAt := time.Now() | ||||
| 	var proto int | ||||
| 	if p.ipv4 { | ||||
| 		proto = protocolICMP | ||||
| 	} else { | ||||
| 		proto = protocolIPv6ICMP | ||||
| 	} | ||||
|  | ||||
| 	var m *icmp.Message | ||||
| 	var err error | ||||
| 	if m, err = icmp.ParseMessage(proto, recv.bytes); err != nil { | ||||
| 		return fmt.Errorf("error parsing icmp message: %s", err.Error()) | ||||
| 	} | ||||
|  | ||||
| 	if m.Type != ipv4.ICMPTypeEchoReply && m.Type != ipv6.ICMPTypeEchoReply { | ||||
| 		// Not an echo reply, ignore it | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	outPkt := &Packet{ | ||||
| 		Nbytes: recv.nbytes, | ||||
| 		IPAddr: p.ipaddr, | ||||
| 		Addr:   p.addr, | ||||
| 		Ttl:    recv.ttl, | ||||
| 	} | ||||
|  | ||||
| 	switch pkt := m.Body.(type) { | ||||
| 	case *icmp.Echo: | ||||
| 		// If we are priviledged, we can match icmp.ID | ||||
| 		if p.protocol == "icmp" { | ||||
| 			// Check if reply from same ID | ||||
| 			if pkt.ID != p.id { | ||||
| 				return nil | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if len(pkt.Data) < timeSliceLength+trackerLength { | ||||
| 			return fmt.Errorf("insufficient data received; got: %d %v", | ||||
| 				len(pkt.Data), pkt.Data) | ||||
| 		} | ||||
|  | ||||
| 		tracker := bytesToInt(pkt.Data[timeSliceLength:]) | ||||
| 		timestamp := bytesToTime(pkt.Data[:timeSliceLength]) | ||||
|  | ||||
| 		if tracker != p.Tracker { | ||||
| 			return nil | ||||
| 		} | ||||
|  | ||||
| 		outPkt.Rtt = receivedAt.Sub(timestamp) | ||||
| 		outPkt.Seq = pkt.Seq | ||||
| 		p.PacketsRecv++ | ||||
| 	default: | ||||
| 		// Very bad, not sure how this can happen | ||||
| 		return fmt.Errorf("invalid ICMP echo reply; type: '%T', '%v'", pkt, pkt) | ||||
| 	} | ||||
|  | ||||
| 	if p.RecordRtts { | ||||
| 		p.rtts = append(p.rtts, outPkt.Rtt) | ||||
| 	} | ||||
| 	handler := p.OnRecv | ||||
| 	if handler != nil { | ||||
| 		handler(outPkt) | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (p *Pinger) sendICMP(conn *icmp.PacketConn) error { | ||||
| 	var typ icmp.Type | ||||
| 	if p.ipv4 { | ||||
| 		typ = ipv4.ICMPTypeEcho | ||||
| 	} else { | ||||
| 		typ = ipv6.ICMPTypeEchoRequest | ||||
| 	} | ||||
|  | ||||
| 	var dst net.Addr = p.ipaddr | ||||
| 	if p.protocol == "udp" { | ||||
| 		dst = &net.UDPAddr{IP: p.ipaddr.IP, Zone: p.ipaddr.Zone} | ||||
| 	} | ||||
|  | ||||
| 	t := append(timeToBytes(time.Now()), intToBytes(p.Tracker)...) | ||||
| 	if remainSize := p.Size - timeSliceLength - trackerLength; remainSize > 0 { | ||||
| 		t = append(t, bytes.Repeat([]byte{1}, remainSize)...) | ||||
| 	} | ||||
|  | ||||
| 	body := &icmp.Echo{ | ||||
| 		ID:   p.id, | ||||
| 		Seq:  p.sequence, | ||||
| 		Data: t, | ||||
| 	} | ||||
|  | ||||
| 	msg := &icmp.Message{ | ||||
| 		Type: typ, | ||||
| 		Code: 0, | ||||
| 		Body: body, | ||||
| 	} | ||||
|  | ||||
| 	msgBytes, err := msg.Marshal(nil) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	for { | ||||
| 		if _, err := conn.WriteTo(msgBytes, dst); err != nil { | ||||
| 			if neterr, ok := err.(*net.OpError); ok { | ||||
| 				if neterr.Err == syscall.ENOBUFS { | ||||
| 					continue | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		handler := p.OnSend | ||||
| 		if handler != nil { | ||||
| 			outPkt := &Packet{ | ||||
| 				Nbytes: len(msgBytes), | ||||
| 				IPAddr: p.ipaddr, | ||||
| 				Addr:   p.addr, | ||||
| 				Seq:    p.sequence, | ||||
| 			} | ||||
| 			handler(outPkt) | ||||
| 		} | ||||
|  | ||||
| 		p.PacketsSent++ | ||||
| 		p.sequence++ | ||||
| 		break | ||||
| 	} | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (p *Pinger) listen(netProto string) (*icmp.PacketConn, error) { | ||||
| 	conn, err := icmp.ListenPacket(netProto, p.Source) | ||||
| 	if err != nil { | ||||
| 		close(p.done) | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return conn, nil | ||||
| } | ||||
|  | ||||
| func bytesToTime(b []byte) time.Time { | ||||
| 	var nsec int64 | ||||
| 	for i := uint8(0); i < 8; i++ { | ||||
| 		nsec += int64(b[i]) << ((7 - i) * 8) | ||||
| 	} | ||||
| 	return time.Unix(nsec/1000000000, nsec%1000000000) | ||||
| } | ||||
|  | ||||
| func isIPv4(ip net.IP) bool { | ||||
| 	return len(ip.To4()) == net.IPv4len | ||||
| } | ||||
|  | ||||
| func timeToBytes(t time.Time) []byte { | ||||
| 	nsec := t.UnixNano() | ||||
| 	b := make([]byte, 8) | ||||
| 	for i := uint8(0); i < 8; i++ { | ||||
| 		b[i] = byte((nsec >> ((7 - i) * 8)) & 0xff) | ||||
| 	} | ||||
| 	return b | ||||
| } | ||||
|  | ||||
| func bytesToInt(b []byte) int64 { | ||||
| 	return int64(binary.BigEndian.Uint64(b)) | ||||
| } | ||||
|  | ||||
| func intToBytes(tracker int64) []byte { | ||||
| 	b := make([]byte, 8) | ||||
| 	binary.BigEndian.PutUint64(b, uint64(tracker)) | ||||
| 	return b | ||||
| } | ||||
							
								
								
									
										11
									
								
								vendor/github.com/google/gofuzz/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								vendor/github.com/google/gofuzz/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,13 +1,10 @@ | ||||
| language: go | ||||
|  | ||||
| go: | ||||
|   - 1.4 | ||||
|   - 1.3 | ||||
|   - 1.2 | ||||
|   - tip | ||||
|  | ||||
| install: | ||||
|   - if ! go get code.google.com/p/go.tools/cmd/cover; then go get golang.org/x/tools/cmd/cover; fi | ||||
|   - 1.11.x | ||||
|   - 1.12.x | ||||
|   - 1.13.x | ||||
|   - master | ||||
|  | ||||
| script: | ||||
|   - go test -cover | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/google/gofuzz/CONTRIBUTING.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/google/gofuzz/CONTRIBUTING.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,7 +1,7 @@ | ||||
| # How to contribute # | ||||
|  | ||||
| We'd love to accept your patches and contributions to this project.  There are | ||||
| a just a few small guidelines you need to follow. | ||||
| just a few small guidelines you need to follow. | ||||
|  | ||||
|  | ||||
| ## Contributor License Agreement ## | ||||
|  | ||||
							
								
								
									
										20
									
								
								vendor/github.com/google/gofuzz/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								vendor/github.com/google/gofuzz/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -3,7 +3,7 @@ gofuzz | ||||
|  | ||||
| gofuzz is a library for populating go objects with random values. | ||||
|  | ||||
| [](https://godoc.org/github.com/google/gofuzz) | ||||
| [](https://godoc.org/github.com/google/gofuzz) | ||||
| [](https://travis-ci.org/google/gofuzz) | ||||
|  | ||||
| This is useful for testing: | ||||
| @ -68,4 +68,22 @@ f.Fuzz(&myObject) // Type will correspond to whether A or B info is set. | ||||
|  | ||||
| See more examples in ```example_test.go```. | ||||
|  | ||||
| You can use this library for easier [go-fuzz](https://github.com/dvyukov/go-fuzz)ing. | ||||
| go-fuzz provides the user a byte-slice, which should be converted to different inputs | ||||
| for the tested function. This library can help convert the byte slice. Consider for | ||||
| example a fuzz test for a the function `mypackage.MyFunc` that takes an int arguments: | ||||
| ```go | ||||
| // +build gofuzz | ||||
| package mypackage | ||||
|  | ||||
| import fuzz "github.com/google/gofuzz" | ||||
|  | ||||
| func Fuzz(data []byte) int { | ||||
|         var i int | ||||
|         fuzz.NewFromGoFuzz(data).Fuzz(&i) | ||||
|         MyFunc(i) | ||||
|         return 0 | ||||
| } | ||||
| ``` | ||||
|  | ||||
| Happy testing! | ||||
|  | ||||
							
								
								
									
										81
									
								
								vendor/github.com/google/gofuzz/bytesource/bytesource.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								vendor/github.com/google/gofuzz/bytesource/bytesource.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,81 @@ | ||||
| /* | ||||
| Copyright 2014 Google Inc. All rights reserved. | ||||
|  | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| // Package bytesource provides a rand.Source64 that is determined by a slice of bytes. | ||||
| package bytesource | ||||
|  | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"encoding/binary" | ||||
| 	"io" | ||||
| 	"math/rand" | ||||
| ) | ||||
|  | ||||
| // ByteSource implements rand.Source64 determined by a slice of bytes. The random numbers are | ||||
| // generated from each 8 bytes in the slice, until the last bytes are consumed, from which a | ||||
| // fallback pseudo random source is created in case more random numbers are required. | ||||
| // It also exposes a `bytes.Reader` API, which lets callers consume the bytes directly. | ||||
| type ByteSource struct { | ||||
| 	*bytes.Reader | ||||
| 	fallback rand.Source | ||||
| } | ||||
|  | ||||
| // New returns a new ByteSource from a given slice of bytes. | ||||
| func New(input []byte) *ByteSource { | ||||
| 	s := &ByteSource{ | ||||
| 		Reader:   bytes.NewReader(input), | ||||
| 		fallback: rand.NewSource(0), | ||||
| 	} | ||||
| 	if len(input) > 0 { | ||||
| 		s.fallback = rand.NewSource(int64(s.consumeUint64())) | ||||
| 	} | ||||
| 	return s | ||||
| } | ||||
|  | ||||
| func (s *ByteSource) Uint64() uint64 { | ||||
| 	// Return from input if it was not exhausted. | ||||
| 	if s.Len() > 0 { | ||||
| 		return s.consumeUint64() | ||||
| 	} | ||||
|  | ||||
| 	// Input was exhausted, return random number from fallback (in this case fallback should not be | ||||
| 	// nil). Try first having a Uint64 output (Should work in current rand implementation), | ||||
| 	// otherwise return a conversion of Int63. | ||||
| 	if s64, ok := s.fallback.(rand.Source64); ok { | ||||
| 		return s64.Uint64() | ||||
| 	} | ||||
| 	return uint64(s.fallback.Int63()) | ||||
| } | ||||
|  | ||||
| func (s *ByteSource) Int63() int64 { | ||||
| 	return int64(s.Uint64() >> 1) | ||||
| } | ||||
|  | ||||
| func (s *ByteSource) Seed(seed int64) { | ||||
| 	s.fallback = rand.NewSource(seed) | ||||
| 	s.Reader = bytes.NewReader(nil) | ||||
| } | ||||
|  | ||||
| // consumeUint64 reads 8 bytes from the input and convert them to a uint64. It assumes that the the | ||||
| // bytes reader is not empty. | ||||
| func (s *ByteSource) consumeUint64() uint64 { | ||||
| 	var bytes [8]byte | ||||
| 	_, err := s.Read(bytes[:]) | ||||
| 	if err != nil && err != io.EOF { | ||||
| 		panic("failed reading source") // Should not happen. | ||||
| 	} | ||||
| 	return binary.BigEndian.Uint64(bytes[:]) | ||||
| } | ||||
							
								
								
									
										156
									
								
								vendor/github.com/google/gofuzz/fuzz.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										156
									
								
								vendor/github.com/google/gofuzz/fuzz.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -20,7 +20,11 @@ import ( | ||||
| 	"fmt" | ||||
| 	"math/rand" | ||||
| 	"reflect" | ||||
| 	"regexp" | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/google/gofuzz/bytesource" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // fuzzFuncMap is a map from a type to a fuzzFunc that handles that type. | ||||
| @ -35,6 +39,7 @@ type Fuzzer struct { | ||||
| 	minElements       int | ||||
| 	maxElements       int | ||||
| 	maxDepth          int | ||||
| 	skipFieldPatterns []*regexp.Regexp | ||||
| } | ||||
|  | ||||
| // New returns a new Fuzzer. Customize your Fuzzer further by calling Funcs, | ||||
| @ -59,6 +64,34 @@ func NewWithSeed(seed int64) *Fuzzer { | ||||
| 	return f | ||||
| } | ||||
|  | ||||
| // NewFromGoFuzz is a helper function that enables using gofuzz (this | ||||
| // project) with go-fuzz (https://github.com/dvyukov/go-fuzz) for continuous | ||||
| // fuzzing. Essentially, it enables translating the fuzzing bytes from | ||||
| // go-fuzz to any Go object using this library. | ||||
| // | ||||
| // This implementation promises a constant translation from a given slice of | ||||
| // bytes to the fuzzed objects. This promise will remain over future | ||||
| // versions of Go and of this library. | ||||
| // | ||||
| // Note: the returned Fuzzer should not be shared between multiple goroutines, | ||||
| // as its deterministic output will no longer be available. | ||||
| // | ||||
| // Example: use go-fuzz to test the function `MyFunc(int)` in the package | ||||
| // `mypackage`. Add the file: "mypacakge_fuzz.go" with the content: | ||||
| // | ||||
| // // +build gofuzz | ||||
| // package mypacakge | ||||
| // import fuzz "github.com/google/gofuzz" | ||||
| // func Fuzz(data []byte) int { | ||||
| // 	var i int | ||||
| // 	fuzz.NewFromGoFuzz(data).Fuzz(&i) | ||||
| // 	MyFunc(i) | ||||
| // 	return 0 | ||||
| // } | ||||
| func NewFromGoFuzz(data []byte) *Fuzzer { | ||||
| 	return New().RandSource(bytesource.New(data)) | ||||
| } | ||||
|  | ||||
| // Funcs adds each entry in fuzzFuncs as a custom fuzzing function. | ||||
| // | ||||
| // Each entry in fuzzFuncs must be a function taking two parameters. | ||||
| @ -139,7 +172,7 @@ func (f *Fuzzer) genElementCount() int { | ||||
| } | ||||
|  | ||||
| func (f *Fuzzer) genShouldFill() bool { | ||||
| 	return f.r.Float64() > f.nilChance | ||||
| 	return f.r.Float64() >= f.nilChance | ||||
| } | ||||
|  | ||||
| // MaxDepth sets the maximum number of recursive fuzz calls that will be made | ||||
| @ -150,6 +183,13 @@ func (f *Fuzzer) MaxDepth(d int) *Fuzzer { | ||||
| 	return f | ||||
| } | ||||
|  | ||||
| // Skip fields which match the supplied pattern. Call this multiple times if needed | ||||
| // This is useful to skip XXX_ fields generated by protobuf | ||||
| func (f *Fuzzer) SkipFieldsWithPattern(pattern *regexp.Regexp) *Fuzzer { | ||||
| 	f.skipFieldPatterns = append(f.skipFieldPatterns, pattern) | ||||
| 	return f | ||||
| } | ||||
|  | ||||
| // Fuzz recursively fills all of obj's fields with something random.  First | ||||
| // this tries to find a custom fuzz function (see Funcs).  If there is no | ||||
| // custom function this tests whether the object implements fuzz.Interface and, | ||||
| @ -231,6 +271,7 @@ func (fc *fuzzerContext) doFuzz(v reflect.Value, flags uint64) { | ||||
| 		fn(v, fc.fuzzer.r) | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	switch v.Kind() { | ||||
| 	case reflect.Map: | ||||
| 		if fc.fuzzer.genShouldFill() { | ||||
| @ -274,8 +315,18 @@ func (fc *fuzzerContext) doFuzz(v reflect.Value, flags uint64) { | ||||
| 		v.Set(reflect.Zero(v.Type())) | ||||
| 	case reflect.Struct: | ||||
| 		for i := 0; i < v.NumField(); i++ { | ||||
| 			skipField := false | ||||
| 			fieldName := v.Type().Field(i).Name | ||||
| 			for _, pattern := range fc.fuzzer.skipFieldPatterns { | ||||
| 				if pattern.MatchString(fieldName) { | ||||
| 					skipField = true | ||||
| 					break | ||||
| 				} | ||||
| 			} | ||||
| 			if !skipField { | ||||
| 				fc.doFuzz(v.Field(i), 0) | ||||
| 			} | ||||
| 		} | ||||
| 	case reflect.Chan: | ||||
| 		fallthrough | ||||
| 	case reflect.Func: | ||||
| @ -431,10 +482,10 @@ var fillFuncMap = map[reflect.Kind]func(reflect.Value, *rand.Rand){ | ||||
| 		v.SetFloat(r.Float64()) | ||||
| 	}, | ||||
| 	reflect.Complex64: func(v reflect.Value, r *rand.Rand) { | ||||
| 		panic("unimplemented") | ||||
| 		v.SetComplex(complex128(complex(r.Float32(), r.Float32()))) | ||||
| 	}, | ||||
| 	reflect.Complex128: func(v reflect.Value, r *rand.Rand) { | ||||
| 		panic("unimplemented") | ||||
| 		v.SetComplex(complex(r.Float64(), r.Float64())) | ||||
| 	}, | ||||
| 	reflect.String: func(v reflect.Value, r *rand.Rand) { | ||||
| 		v.SetString(randString(r)) | ||||
| @ -446,38 +497,105 @@ var fillFuncMap = map[reflect.Kind]func(reflect.Value, *rand.Rand){ | ||||
|  | ||||
| // randBool returns true or false randomly. | ||||
| func randBool(r *rand.Rand) bool { | ||||
| 	if r.Int()&1 == 1 { | ||||
| 		return true | ||||
| 	} | ||||
| 	return false | ||||
| 	return r.Int31()&(1<<30) == 0 | ||||
| } | ||||
|  | ||||
| type charRange struct { | ||||
| 	first, last rune | ||||
| type int63nPicker interface { | ||||
| 	Int63n(int64) int64 | ||||
| } | ||||
|  | ||||
| // UnicodeRange describes a sequential range of unicode characters. | ||||
| // Last must be numerically greater than First. | ||||
| type UnicodeRange struct { | ||||
| 	First, Last rune | ||||
| } | ||||
|  | ||||
| // UnicodeRanges describes an arbitrary number of sequential ranges of unicode characters. | ||||
| // To be useful, each range must have at least one character (First <= Last) and | ||||
| // there must be at least one range. | ||||
| type UnicodeRanges []UnicodeRange | ||||
|  | ||||
| // choose returns a random unicode character from the given range, using the | ||||
| // given randomness source. | ||||
| func (r *charRange) choose(rand *rand.Rand) rune { | ||||
| 	count := int64(r.last - r.first) | ||||
| 	return r.first + rune(rand.Int63n(count)) | ||||
| func (ur UnicodeRange) choose(r int63nPicker) rune { | ||||
| 	count := int64(ur.Last - ur.First + 1) | ||||
| 	return ur.First + rune(r.Int63n(count)) | ||||
| } | ||||
|  | ||||
| var unicodeRanges = []charRange{ | ||||
| // CustomStringFuzzFunc constructs a FuzzFunc which produces random strings. | ||||
| // Each character is selected from the range ur. If there are no characters | ||||
| // in the range (cr.Last < cr.First), this will panic. | ||||
| func (ur UnicodeRange) CustomStringFuzzFunc() func(s *string, c Continue) { | ||||
| 	ur.check() | ||||
| 	return func(s *string, c Continue) { | ||||
| 		*s = ur.randString(c.Rand) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // check is a function that used to check whether the first of ur(UnicodeRange) | ||||
| // is greater than the last one. | ||||
| func (ur UnicodeRange) check() { | ||||
| 	if ur.Last < ur.First { | ||||
| 		panic("The last encoding must be greater than the first one.") | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // randString of UnicodeRange makes a random string up to 20 characters long. | ||||
| // Each character is selected form ur(UnicodeRange). | ||||
| func (ur UnicodeRange) randString(r *rand.Rand) string { | ||||
| 	n := r.Intn(20) | ||||
| 	sb := strings.Builder{} | ||||
| 	sb.Grow(n) | ||||
| 	for i := 0; i < n; i++ { | ||||
| 		sb.WriteRune(ur.choose(r)) | ||||
| 	} | ||||
| 	return sb.String() | ||||
| } | ||||
|  | ||||
| // defaultUnicodeRanges sets a default unicode range when user do not set | ||||
| // CustomStringFuzzFunc() but wants fuzz string. | ||||
| var defaultUnicodeRanges = UnicodeRanges{ | ||||
| 	{' ', '~'},           // ASCII characters | ||||
| 	{'\u00a0', '\u02af'}, // Multi-byte encoded characters | ||||
| 	{'\u4e00', '\u9fff'}, // Common CJK (even longer encodings) | ||||
| } | ||||
|  | ||||
| // CustomStringFuzzFunc constructs a FuzzFunc which produces random strings. | ||||
| // Each character is selected from one of the ranges of ur(UnicodeRanges). | ||||
| // Each range has an equal probability of being chosen. If there are no ranges, | ||||
| // or a selected range has no characters (.Last < .First), this will panic. | ||||
| // Do not modify any of the ranges in ur after calling this function. | ||||
| func (ur UnicodeRanges) CustomStringFuzzFunc() func(s *string, c Continue) { | ||||
| 	// Check unicode ranges slice is empty. | ||||
| 	if len(ur) == 0 { | ||||
| 		panic("UnicodeRanges is empty.") | ||||
| 	} | ||||
| 	// if not empty, each range should be checked. | ||||
| 	for i := range ur { | ||||
| 		ur[i].check() | ||||
| 	} | ||||
| 	return func(s *string, c Continue) { | ||||
| 		*s = ur.randString(c.Rand) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // randString of UnicodeRanges makes a random string up to 20 characters long. | ||||
| // Each character is selected form one of the ranges of ur(UnicodeRanges), | ||||
| // and each range has an equal probability of being chosen. | ||||
| func (ur UnicodeRanges) randString(r *rand.Rand) string { | ||||
| 	n := r.Intn(20) | ||||
| 	sb := strings.Builder{} | ||||
| 	sb.Grow(n) | ||||
| 	for i := 0; i < n; i++ { | ||||
| 		sb.WriteRune(ur[r.Intn(len(ur))].choose(r)) | ||||
| 	} | ||||
| 	return sb.String() | ||||
| } | ||||
|  | ||||
| // randString makes a random string up to 20 characters long. The returned string | ||||
| // may include a variety of (valid) UTF-8 encodings. | ||||
| func randString(r *rand.Rand) string { | ||||
| 	n := r.Intn(20) | ||||
| 	runes := make([]rune, n) | ||||
| 	for i := range runes { | ||||
| 		runes[i] = unicodeRanges[r.Intn(len(unicodeRanges))].choose(r) | ||||
| 	} | ||||
| 	return string(runes) | ||||
| 	return defaultUnicodeRanges.randString(r) | ||||
| } | ||||
|  | ||||
| // randUint64 makes random 64 bit numbers. | ||||
|  | ||||
							
								
								
									
										20
									
								
								vendor/github.com/prometheus/client_golang/prometheus/counter.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								vendor/github.com/prometheus/client_golang/prometheus/counter.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -163,7 +163,7 @@ func (c *counter) updateExemplar(v float64, l Labels) { | ||||
| // (e.g. number of HTTP requests, partitioned by response code and | ||||
| // method). Create instances with NewCounterVec. | ||||
| type CounterVec struct { | ||||
| 	*metricVec | ||||
| 	*MetricVec | ||||
| } | ||||
|  | ||||
| // NewCounterVec creates a new CounterVec based on the provided CounterOpts and | ||||
| @ -176,11 +176,11 @@ func NewCounterVec(opts CounterOpts, labelNames []string) *CounterVec { | ||||
| 		opts.ConstLabels, | ||||
| 	) | ||||
| 	return &CounterVec{ | ||||
| 		metricVec: newMetricVec(desc, func(lvs ...string) Metric { | ||||
| 		MetricVec: NewMetricVec(desc, func(lvs ...string) Metric { | ||||
| 			if len(lvs) != len(desc.variableLabels) { | ||||
| 				panic(makeInconsistentCardinalityError(desc.fqName, desc.variableLabels, lvs)) | ||||
| 			} | ||||
| 			result := &counter{desc: desc, labelPairs: makeLabelPairs(desc, lvs), now: time.Now} | ||||
| 			result := &counter{desc: desc, labelPairs: MakeLabelPairs(desc, lvs), now: time.Now} | ||||
| 			result.init(result) // Init self-collection. | ||||
| 			return result | ||||
| 		}), | ||||
| @ -188,7 +188,7 @@ func NewCounterVec(opts CounterOpts, labelNames []string) *CounterVec { | ||||
| } | ||||
|  | ||||
| // GetMetricWithLabelValues returns the Counter for the given slice of label | ||||
| // values (same order as the VariableLabels in Desc). If that combination of | ||||
| // values (same order as the variable labels in Desc). If that combination of | ||||
| // label values is accessed for the first time, a new Counter is created. | ||||
| // | ||||
| // It is possible to call this method without using the returned Counter to only | ||||
| @ -202,7 +202,7 @@ func NewCounterVec(opts CounterOpts, labelNames []string) *CounterVec { | ||||
| // Counter with the same label values is created later. | ||||
| // | ||||
| // An error is returned if the number of label values is not the same as the | ||||
| // number of VariableLabels in Desc (minus any curried labels). | ||||
| // number of variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // Note that for more than one label value, this method is prone to mistakes | ||||
| // caused by an incorrect order of arguments. Consider GetMetricWith(Labels) as | ||||
| @ -211,7 +211,7 @@ func NewCounterVec(opts CounterOpts, labelNames []string) *CounterVec { | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| // See also the GaugeVec example. | ||||
| func (v *CounterVec) GetMetricWithLabelValues(lvs ...string) (Counter, error) { | ||||
| 	metric, err := v.metricVec.getMetricWithLabelValues(lvs...) | ||||
| 	metric, err := v.MetricVec.GetMetricWithLabelValues(lvs...) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Counter), err | ||||
| 	} | ||||
| @ -219,19 +219,19 @@ func (v *CounterVec) GetMetricWithLabelValues(lvs ...string) (Counter, error) { | ||||
| } | ||||
|  | ||||
| // GetMetricWith returns the Counter for the given Labels map (the label names | ||||
| // must match those of the VariableLabels in Desc). If that label map is | ||||
| // must match those of the variable labels in Desc). If that label map is | ||||
| // accessed for the first time, a new Counter is created. Implications of | ||||
| // creating a Counter without using it and keeping the Counter for later use are | ||||
| // the same as for GetMetricWithLabelValues. | ||||
| // | ||||
| // An error is returned if the number and names of the Labels are inconsistent | ||||
| // with those of the VariableLabels in Desc (minus any curried labels). | ||||
| // with those of the variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // This method is used for the same purpose as | ||||
| // GetMetricWithLabelValues(...string). See there for pros and cons of the two | ||||
| // methods. | ||||
| func (v *CounterVec) GetMetricWith(labels Labels) (Counter, error) { | ||||
| 	metric, err := v.metricVec.getMetricWith(labels) | ||||
| 	metric, err := v.MetricVec.GetMetricWith(labels) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Counter), err | ||||
| 	} | ||||
| @ -275,7 +275,7 @@ func (v *CounterVec) With(labels Labels) Counter { | ||||
| // registered with a given registry (usually the uncurried version). The Reset | ||||
| // method deletes all metrics, even if called on a curried vector. | ||||
| func (v *CounterVec) CurryWith(labels Labels) (*CounterVec, error) { | ||||
| 	vec, err := v.curryWith(labels) | ||||
| 	vec, err := v.MetricVec.CurryWith(labels) | ||||
| 	if vec != nil { | ||||
| 		return &CounterVec{vec}, err | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/desc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/desc.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -51,7 +51,7 @@ type Desc struct { | ||||
| 	// constLabelPairs contains precalculated DTO label pairs based on | ||||
| 	// the constant labels. | ||||
| 	constLabelPairs []*dto.LabelPair | ||||
| 	// VariableLabels contains names of labels for which the metric | ||||
| 	// variableLabels contains names of labels for which the metric | ||||
| 	// maintains variable values. | ||||
| 	variableLabels []string | ||||
| 	// id is a hash of the values of the ConstLabels and fqName. This | ||||
|  | ||||
							
								
								
									
										20
									
								
								vendor/github.com/prometheus/client_golang/prometheus/gauge.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								vendor/github.com/prometheus/client_golang/prometheus/gauge.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -132,7 +132,7 @@ func (g *gauge) Write(out *dto.Metric) error { | ||||
| // (e.g. number of operations queued, partitioned by user and operation | ||||
| // type). Create instances with NewGaugeVec. | ||||
| type GaugeVec struct { | ||||
| 	*metricVec | ||||
| 	*MetricVec | ||||
| } | ||||
|  | ||||
| // NewGaugeVec creates a new GaugeVec based on the provided GaugeOpts and | ||||
| @ -145,11 +145,11 @@ func NewGaugeVec(opts GaugeOpts, labelNames []string) *GaugeVec { | ||||
| 		opts.ConstLabels, | ||||
| 	) | ||||
| 	return &GaugeVec{ | ||||
| 		metricVec: newMetricVec(desc, func(lvs ...string) Metric { | ||||
| 		MetricVec: NewMetricVec(desc, func(lvs ...string) Metric { | ||||
| 			if len(lvs) != len(desc.variableLabels) { | ||||
| 				panic(makeInconsistentCardinalityError(desc.fqName, desc.variableLabels, lvs)) | ||||
| 			} | ||||
| 			result := &gauge{desc: desc, labelPairs: makeLabelPairs(desc, lvs)} | ||||
| 			result := &gauge{desc: desc, labelPairs: MakeLabelPairs(desc, lvs)} | ||||
| 			result.init(result) // Init self-collection. | ||||
| 			return result | ||||
| 		}), | ||||
| @ -157,7 +157,7 @@ func NewGaugeVec(opts GaugeOpts, labelNames []string) *GaugeVec { | ||||
| } | ||||
|  | ||||
| // GetMetricWithLabelValues returns the Gauge for the given slice of label | ||||
| // values (same order as the VariableLabels in Desc). If that combination of | ||||
| // values (same order as the variable labels in Desc). If that combination of | ||||
| // label values is accessed for the first time, a new Gauge is created. | ||||
| // | ||||
| // It is possible to call this method without using the returned Gauge to only | ||||
| @ -172,7 +172,7 @@ func NewGaugeVec(opts GaugeOpts, labelNames []string) *GaugeVec { | ||||
| // example. | ||||
| // | ||||
| // An error is returned if the number of label values is not the same as the | ||||
| // number of VariableLabels in Desc (minus any curried labels). | ||||
| // number of variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // Note that for more than one label value, this method is prone to mistakes | ||||
| // caused by an incorrect order of arguments. Consider GetMetricWith(Labels) as | ||||
| @ -180,7 +180,7 @@ func NewGaugeVec(opts GaugeOpts, labelNames []string) *GaugeVec { | ||||
| // latter has a much more readable (albeit more verbose) syntax, but it comes | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| func (v *GaugeVec) GetMetricWithLabelValues(lvs ...string) (Gauge, error) { | ||||
| 	metric, err := v.metricVec.getMetricWithLabelValues(lvs...) | ||||
| 	metric, err := v.MetricVec.GetMetricWithLabelValues(lvs...) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Gauge), err | ||||
| 	} | ||||
| @ -188,19 +188,19 @@ func (v *GaugeVec) GetMetricWithLabelValues(lvs ...string) (Gauge, error) { | ||||
| } | ||||
|  | ||||
| // GetMetricWith returns the Gauge for the given Labels map (the label names | ||||
| // must match those of the VariableLabels in Desc). If that label map is | ||||
| // must match those of the variable labels in Desc). If that label map is | ||||
| // accessed for the first time, a new Gauge is created. Implications of | ||||
| // creating a Gauge without using it and keeping the Gauge for later use are | ||||
| // the same as for GetMetricWithLabelValues. | ||||
| // | ||||
| // An error is returned if the number and names of the Labels are inconsistent | ||||
| // with those of the VariableLabels in Desc (minus any curried labels). | ||||
| // with those of the variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // This method is used for the same purpose as | ||||
| // GetMetricWithLabelValues(...string). See there for pros and cons of the two | ||||
| // methods. | ||||
| func (v *GaugeVec) GetMetricWith(labels Labels) (Gauge, error) { | ||||
| 	metric, err := v.metricVec.getMetricWith(labels) | ||||
| 	metric, err := v.MetricVec.GetMetricWith(labels) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Gauge), err | ||||
| 	} | ||||
| @ -244,7 +244,7 @@ func (v *GaugeVec) With(labels Labels) Gauge { | ||||
| // registered with a given registry (usually the uncurried version). The Reset | ||||
| // method deletes all metrics, even if called on a curried vector. | ||||
| func (v *GaugeVec) CurryWith(labels Labels) (*GaugeVec, error) { | ||||
| 	vec, err := v.curryWith(labels) | ||||
| 	vec, err := v.MetricVec.CurryWith(labels) | ||||
| 	if vec != nil { | ||||
| 		return &GaugeVec{vec}, err | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										7
									
								
								vendor/github.com/prometheus/client_golang/prometheus/go_collector.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/github.com/prometheus/client_golang/prometheus/go_collector.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -58,9 +58,10 @@ type goCollector struct { | ||||
| // collector will use the memstats from a previous collection if | ||||
| // runtime.ReadMemStats takes more than 1s. However, if there are no previously | ||||
| // collected memstats, or their collection is more than 5m ago, the collection | ||||
| // will block until runtime.ReadMemStats succeeds. (The problem might be solved | ||||
| // in Go1.13, see https://github.com/golang/go/issues/19812 for the related Go | ||||
| // issue.) | ||||
| // will block until runtime.ReadMemStats succeeds. | ||||
| // | ||||
| // NOTE: The problem is solved in Go 1.15, see | ||||
| // https://github.com/golang/go/issues/19812 for the related Go issue. | ||||
| func NewGoCollector() Collector { | ||||
| 	return &goCollector{ | ||||
| 		goroutinesDesc: NewDesc( | ||||
|  | ||||
							
								
								
									
										22
									
								
								vendor/github.com/prometheus/client_golang/prometheus/histogram.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								vendor/github.com/prometheus/client_golang/prometheus/histogram.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -192,7 +192,7 @@ func newHistogram(desc *Desc, opts HistogramOpts, labelValues ...string) Histogr | ||||
| 	h := &histogram{ | ||||
| 		desc:        desc, | ||||
| 		upperBounds: opts.Buckets, | ||||
| 		labelPairs:  makeLabelPairs(desc, labelValues), | ||||
| 		labelPairs:  MakeLabelPairs(desc, labelValues), | ||||
| 		counts:      [2]*histogramCounts{{}, {}}, | ||||
| 		now:         time.Now, | ||||
| 	} | ||||
| @ -409,7 +409,7 @@ func (h *histogram) updateExemplar(v float64, bucket int, l Labels) { | ||||
| // (e.g. HTTP request latencies, partitioned by status code and method). Create | ||||
| // instances with NewHistogramVec. | ||||
| type HistogramVec struct { | ||||
| 	*metricVec | ||||
| 	*MetricVec | ||||
| } | ||||
|  | ||||
| // NewHistogramVec creates a new HistogramVec based on the provided HistogramOpts and | ||||
| @ -422,14 +422,14 @@ func NewHistogramVec(opts HistogramOpts, labelNames []string) *HistogramVec { | ||||
| 		opts.ConstLabels, | ||||
| 	) | ||||
| 	return &HistogramVec{ | ||||
| 		metricVec: newMetricVec(desc, func(lvs ...string) Metric { | ||||
| 		MetricVec: NewMetricVec(desc, func(lvs ...string) Metric { | ||||
| 			return newHistogram(desc, opts, lvs...) | ||||
| 		}), | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // GetMetricWithLabelValues returns the Histogram for the given slice of label | ||||
| // values (same order as the VariableLabels in Desc). If that combination of | ||||
| // values (same order as the variable labels in Desc). If that combination of | ||||
| // label values is accessed for the first time, a new Histogram is created. | ||||
| // | ||||
| // It is possible to call this method without using the returned Histogram to only | ||||
| @ -444,7 +444,7 @@ func NewHistogramVec(opts HistogramOpts, labelNames []string) *HistogramVec { | ||||
| // example. | ||||
| // | ||||
| // An error is returned if the number of label values is not the same as the | ||||
| // number of VariableLabels in Desc (minus any curried labels). | ||||
| // number of variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // Note that for more than one label value, this method is prone to mistakes | ||||
| // caused by an incorrect order of arguments. Consider GetMetricWith(Labels) as | ||||
| @ -453,7 +453,7 @@ func NewHistogramVec(opts HistogramOpts, labelNames []string) *HistogramVec { | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| // See also the GaugeVec example. | ||||
| func (v *HistogramVec) GetMetricWithLabelValues(lvs ...string) (Observer, error) { | ||||
| 	metric, err := v.metricVec.getMetricWithLabelValues(lvs...) | ||||
| 	metric, err := v.MetricVec.GetMetricWithLabelValues(lvs...) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Observer), err | ||||
| 	} | ||||
| @ -461,19 +461,19 @@ func (v *HistogramVec) GetMetricWithLabelValues(lvs ...string) (Observer, error) | ||||
| } | ||||
|  | ||||
| // GetMetricWith returns the Histogram for the given Labels map (the label names | ||||
| // must match those of the VariableLabels in Desc). If that label map is | ||||
| // must match those of the variable labels in Desc). If that label map is | ||||
| // accessed for the first time, a new Histogram is created. Implications of | ||||
| // creating a Histogram without using it and keeping the Histogram for later use | ||||
| // are the same as for GetMetricWithLabelValues. | ||||
| // | ||||
| // An error is returned if the number and names of the Labels are inconsistent | ||||
| // with those of the VariableLabels in Desc (minus any curried labels). | ||||
| // with those of the variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // This method is used for the same purpose as | ||||
| // GetMetricWithLabelValues(...string). See there for pros and cons of the two | ||||
| // methods. | ||||
| func (v *HistogramVec) GetMetricWith(labels Labels) (Observer, error) { | ||||
| 	metric, err := v.metricVec.getMetricWith(labels) | ||||
| 	metric, err := v.MetricVec.GetMetricWith(labels) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Observer), err | ||||
| 	} | ||||
| @ -517,7 +517,7 @@ func (v *HistogramVec) With(labels Labels) Observer { | ||||
| // registered with a given registry (usually the uncurried version). The Reset | ||||
| // method deletes all metrics, even if called on a curried vector. | ||||
| func (v *HistogramVec) CurryWith(labels Labels) (ObserverVec, error) { | ||||
| 	vec, err := v.curryWith(labels) | ||||
| 	vec, err := v.MetricVec.CurryWith(labels) | ||||
| 	if vec != nil { | ||||
| 		return &HistogramVec{vec}, err | ||||
| 	} | ||||
| @ -602,7 +602,7 @@ func NewConstHistogram( | ||||
| 		count:      count, | ||||
| 		sum:        sum, | ||||
| 		buckets:    buckets, | ||||
| 		labelPairs: makeLabelPairs(desc, labelValues), | ||||
| 		labelPairs: MakeLabelPairs(desc, labelValues), | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/metric.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/metric.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -89,7 +89,7 @@ type Opts struct { | ||||
| 	// better covered by target labels set by the scraping Prometheus | ||||
| 	// server, or by one specific metric (e.g. a build_info or a | ||||
| 	// machine_role metric). See also | ||||
| 	// https://prometheus.io/docs/instrumenting/writing_exporters/#target-labels,-not-static-scraped-labels | ||||
| 	// https://prometheus.io/docs/instrumenting/writing_exporters/#target-labels-not-static-scraped-labels | ||||
| 	ConstLabels Labels | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										21
									
								
								vendor/github.com/prometheus/client_golang/prometheus/process_collector.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								vendor/github.com/prometheus/client_golang/prometheus/process_collector.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -15,7 +15,11 @@ package prometheus | ||||
|  | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"io/ioutil" | ||||
| 	"os" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| type processCollector struct { | ||||
| @ -149,3 +153,20 @@ func (c *processCollector) reportError(ch chan<- Metric, desc *Desc, err error) | ||||
| 	} | ||||
| 	ch <- NewInvalidMetric(desc, err) | ||||
| } | ||||
|  | ||||
| // NewPidFileFn returns a function that retrieves a pid from the specified file. | ||||
| // It is meant to be used for the PidFn field in ProcessCollectorOpts. | ||||
| func NewPidFileFn(pidFilePath string) func() (int, error) { | ||||
| 	return func() (int, error) { | ||||
| 		content, err := ioutil.ReadFile(pidFilePath) | ||||
| 		if err != nil { | ||||
| 			return 0, fmt.Errorf("can't read pid file %q: %+v", pidFilePath, err) | ||||
| 		} | ||||
| 		pid, err := strconv.Atoi(strings.TrimSpace(string(content))) | ||||
| 		if err != nil { | ||||
| 			return 0, fmt.Errorf("can't parse pid file %q: %+v", pidFilePath, err) | ||||
| 		} | ||||
|  | ||||
| 		return pid, nil | ||||
| 	} | ||||
| } | ||||
|  | ||||
							
								
								
									
										10
									
								
								vendor/github.com/prometheus/client_golang/prometheus/promhttp/http.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								vendor/github.com/prometheus/client_golang/prometheus/promhttp/http.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -99,7 +99,7 @@ func HandlerFor(reg prometheus.Gatherer, opts HandlerOpts) http.Handler { | ||||
| 		inFlightSem = make(chan struct{}, opts.MaxRequestsInFlight) | ||||
| 	} | ||||
| 	if opts.Registry != nil { | ||||
| 		// Initialize all possibilites that can occur below. | ||||
| 		// Initialize all possibilities that can occur below. | ||||
| 		errCnt.WithLabelValues("gathering") | ||||
| 		errCnt.WithLabelValues("encoding") | ||||
| 		if err := opts.Registry.Register(errCnt); err != nil { | ||||
| @ -303,8 +303,12 @@ type Logger interface { | ||||
| // HandlerOpts specifies options how to serve metrics via an http.Handler. The | ||||
| // zero value of HandlerOpts is a reasonable default. | ||||
| type HandlerOpts struct { | ||||
| 	// ErrorLog specifies an optional logger for errors collecting and | ||||
| 	// serving metrics. If nil, errors are not logged at all. | ||||
| 	// ErrorLog specifies an optional Logger for errors collecting and | ||||
| 	// serving metrics. If nil, errors are not logged at all. Note that the | ||||
| 	// type of a reported error is often prometheus.MultiError, which | ||||
| 	// formats into a multi-line error string. If you want to avoid the | ||||
| 	// latter, create a Logger implementation that detects a | ||||
| 	// prometheus.MultiError and formats the contained errors into one line. | ||||
| 	ErrorLog Logger | ||||
| 	// ErrorHandling defines how errors are handled. Note that errors are | ||||
| 	// logged regardless of the configured ErrorHandling provided ErrorLog | ||||
|  | ||||
							
								
								
									
										85
									
								
								vendor/github.com/prometheus/client_golang/prometheus/promhttp/instrument_server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										85
									
								
								vendor/github.com/prometheus/client_golang/prometheus/promhttp/instrument_server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -43,14 +43,14 @@ func InstrumentHandlerInFlight(g prometheus.Gauge, next http.Handler) http.Handl | ||||
|  | ||||
| // InstrumentHandlerDuration is a middleware that wraps the provided | ||||
| // http.Handler to observe the request duration with the provided ObserverVec. | ||||
| // The ObserverVec must have zero, one, or two non-const non-curried labels. For | ||||
| // those, the only allowed label names are "code" and "method". The function | ||||
| // panics otherwise. The Observe method of the Observer in the ObserverVec is | ||||
| // called with the request duration in seconds. Partitioning happens by HTTP | ||||
| // status code and/or HTTP method if the respective instance label names are | ||||
| // present in the ObserverVec. For unpartitioned observations, use an | ||||
| // ObserverVec with zero labels. Note that partitioning of Histograms is | ||||
| // expensive and should be used judiciously. | ||||
| // The ObserverVec must have valid metric and label names and must have zero, | ||||
| // one, or two non-const non-curried labels. For those, the only allowed label | ||||
| // names are "code" and "method". The function panics otherwise. The Observe | ||||
| // method of the Observer in the ObserverVec is called with the request duration | ||||
| // in seconds. Partitioning happens by HTTP status code and/or HTTP method if | ||||
| // the respective instance label names are present in the ObserverVec. For | ||||
| // unpartitioned observations, use an ObserverVec with zero labels. Note that | ||||
| // partitioning of Histograms is expensive and should be used judiciously. | ||||
| // | ||||
| // If the wrapped Handler does not set a status code, a status code of 200 is assumed. | ||||
| // | ||||
| @ -80,11 +80,12 @@ func InstrumentHandlerDuration(obs prometheus.ObserverVec, next http.Handler) ht | ||||
|  | ||||
| // InstrumentHandlerCounter is a middleware that wraps the provided http.Handler | ||||
| // to observe the request result with the provided CounterVec. The CounterVec | ||||
| // must have zero, one, or two non-const non-curried labels. For those, the only | ||||
| // allowed label names are "code" and "method". The function panics | ||||
| // otherwise. Partitioning of the CounterVec happens by HTTP status code and/or | ||||
| // HTTP method if the respective instance label names are present in the | ||||
| // CounterVec. For unpartitioned counting, use a CounterVec with zero labels. | ||||
| // must have valid metric and label names and must have zero, one, or two | ||||
| // non-const non-curried labels. For those, the only allowed label names are | ||||
| // "code" and "method". The function panics otherwise. Partitioning of the | ||||
| // CounterVec happens by HTTP status code and/or HTTP method if the respective | ||||
| // instance label names are present in the CounterVec. For unpartitioned | ||||
| // counting, use a CounterVec with zero labels. | ||||
| // | ||||
| // If the wrapped Handler does not set a status code, a status code of 200 is assumed. | ||||
| // | ||||
| @ -110,14 +111,15 @@ func InstrumentHandlerCounter(counter *prometheus.CounterVec, next http.Handler) | ||||
|  | ||||
| // InstrumentHandlerTimeToWriteHeader is a middleware that wraps the provided | ||||
| // http.Handler to observe with the provided ObserverVec the request duration | ||||
| // until the response headers are written. The ObserverVec must have zero, one, | ||||
| // or two non-const non-curried labels. For those, the only allowed label names | ||||
| // are "code" and "method". The function panics otherwise. The Observe method of | ||||
| // the Observer in the ObserverVec is called with the request duration in | ||||
| // seconds. Partitioning happens by HTTP status code and/or HTTP method if the | ||||
| // respective instance label names are present in the ObserverVec. For | ||||
| // unpartitioned observations, use an ObserverVec with zero labels. Note that | ||||
| // partitioning of Histograms is expensive and should be used judiciously. | ||||
| // until the response headers are written. The ObserverVec must have valid | ||||
| // metric and label names and must have zero, one, or two non-const non-curried | ||||
| // labels. For those, the only allowed label names are "code" and "method". The | ||||
| // function panics otherwise. The Observe method of the Observer in the | ||||
| // ObserverVec is called with the request duration in seconds. Partitioning | ||||
| // happens by HTTP status code and/or HTTP method if the respective instance | ||||
| // label names are present in the ObserverVec. For unpartitioned observations, | ||||
| // use an ObserverVec with zero labels. Note that partitioning of Histograms is | ||||
| // expensive and should be used judiciously. | ||||
| // | ||||
| // If the wrapped Handler panics before calling WriteHeader, no value is | ||||
| // reported. | ||||
| @ -140,14 +142,14 @@ func InstrumentHandlerTimeToWriteHeader(obs prometheus.ObserverVec, next http.Ha | ||||
|  | ||||
| // InstrumentHandlerRequestSize is a middleware that wraps the provided | ||||
| // http.Handler to observe the request size with the provided ObserverVec. The | ||||
| // ObserverVec must have zero, one, or two non-const non-curried labels. For | ||||
| // those, the only allowed label names are "code" and "method". The function | ||||
| // panics otherwise. The Observe method of the Observer in the ObserverVec is | ||||
| // called with the request size in bytes. Partitioning happens by HTTP status | ||||
| // code and/or HTTP method if the respective instance label names are present in | ||||
| // the ObserverVec. For unpartitioned observations, use an ObserverVec with zero | ||||
| // labels. Note that partitioning of Histograms is expensive and should be used | ||||
| // judiciously. | ||||
| // ObserverVec must have valid metric and label names and must have zero, one, | ||||
| // or two non-const non-curried labels. For those, the only allowed label names | ||||
| // are "code" and "method". The function panics otherwise. The Observe method of | ||||
| // the Observer in the ObserverVec is called with the request size in | ||||
| // bytes. Partitioning happens by HTTP status code and/or HTTP method if the | ||||
| // respective instance label names are present in the ObserverVec. For | ||||
| // unpartitioned observations, use an ObserverVec with zero labels. Note that | ||||
| // partitioning of Histograms is expensive and should be used judiciously. | ||||
| // | ||||
| // If the wrapped Handler does not set a status code, a status code of 200 is assumed. | ||||
| // | ||||
| @ -175,14 +177,14 @@ func InstrumentHandlerRequestSize(obs prometheus.ObserverVec, next http.Handler) | ||||
|  | ||||
| // InstrumentHandlerResponseSize is a middleware that wraps the provided | ||||
| // http.Handler to observe the response size with the provided ObserverVec. The | ||||
| // ObserverVec must have zero, one, or two non-const non-curried labels. For | ||||
| // those, the only allowed label names are "code" and "method". The function | ||||
| // panics otherwise. The Observe method of the Observer in the ObserverVec is | ||||
| // called with the response size in bytes. Partitioning happens by HTTP status | ||||
| // code and/or HTTP method if the respective instance label names are present in | ||||
| // the ObserverVec. For unpartitioned observations, use an ObserverVec with zero | ||||
| // labels. Note that partitioning of Histograms is expensive and should be used | ||||
| // judiciously. | ||||
| // ObserverVec must have valid metric and label names and must have zero, one, | ||||
| // or two non-const non-curried labels. For those, the only allowed label names | ||||
| // are "code" and "method". The function panics otherwise. The Observe method of | ||||
| // the Observer in the ObserverVec is called with the response size in | ||||
| // bytes. Partitioning happens by HTTP status code and/or HTTP method if the | ||||
| // respective instance label names are present in the ObserverVec. For | ||||
| // unpartitioned observations, use an ObserverVec with zero labels. Note that | ||||
| // partitioning of Histograms is expensive and should be used judiciously. | ||||
| // | ||||
| // If the wrapped Handler does not set a status code, a status code of 200 is assumed. | ||||
| // | ||||
| @ -198,6 +200,11 @@ func InstrumentHandlerResponseSize(obs prometheus.ObserverVec, next http.Handler | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| // checkLabels returns whether the provided Collector has a non-const, | ||||
| // non-curried label named "code" and/or "method". It panics if the provided | ||||
| // Collector does not have a Desc or has more than one Desc or its Desc is | ||||
| // invalid. It also panics if the Collector has any non-const, non-curried | ||||
| // labels that are not named "code" or "method". | ||||
| func checkLabels(c prometheus.Collector) (code bool, method bool) { | ||||
| 	// TODO(beorn7): Remove this hacky way to check for instance labels | ||||
| 	// once Descriptors can have their dimensionality queried. | ||||
| @ -225,6 +232,10 @@ func checkLabels(c prometheus.Collector) (code bool, method bool) { | ||||
|  | ||||
| 	close(descc) | ||||
|  | ||||
| 	// Make sure the Collector has a valid Desc by registering it with a | ||||
| 	// temporary registry. | ||||
| 	prometheus.NewRegistry().MustRegister(c) | ||||
|  | ||||
| 	// Create a ConstMetric with the Desc. Since we don't know how many | ||||
| 	// variable labels there are, try for as long as it needs. | ||||
| 	for err := errors.New("dummy"); err != nil; lvs = append(lvs, magicString) { | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/registry.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/prometheus/client_golang/prometheus/registry.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -215,6 +215,8 @@ func (err AlreadyRegisteredError) Error() string { | ||||
| // by a Gatherer to report multiple errors during MetricFamily gathering. | ||||
| type MultiError []error | ||||
|  | ||||
| // Error formats the contained errors as a bullet point list, preceded by the | ||||
| // total number of errors. Note that this results in a multi-line string. | ||||
| func (errs MultiError) Error() string { | ||||
| 	if len(errs) == 0 { | ||||
| 		return "" | ||||
|  | ||||
							
								
								
									
										26
									
								
								vendor/github.com/prometheus/client_golang/prometheus/summary.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								vendor/github.com/prometheus/client_golang/prometheus/summary.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -110,7 +110,7 @@ type SummaryOpts struct { | ||||
| 	// better covered by target labels set by the scraping Prometheus | ||||
| 	// server, or by one specific metric (e.g. a build_info or a | ||||
| 	// machine_role metric). See also | ||||
| 	// https://prometheus.io/docs/instrumenting/writing_exporters/#target-labels,-not-static-scraped-labels | ||||
| 	// https://prometheus.io/docs/instrumenting/writing_exporters/#target-labels-not-static-scraped-labels | ||||
| 	ConstLabels Labels | ||||
|  | ||||
| 	// Objectives defines the quantile rank estimates with their respective | ||||
| @ -208,7 +208,7 @@ func newSummary(desc *Desc, opts SummaryOpts, labelValues ...string) Summary { | ||||
| 		// Use the lock-free implementation of a Summary without objectives. | ||||
| 		s := &noObjectivesSummary{ | ||||
| 			desc:       desc, | ||||
| 			labelPairs: makeLabelPairs(desc, labelValues), | ||||
| 			labelPairs: MakeLabelPairs(desc, labelValues), | ||||
| 			counts:     [2]*summaryCounts{{}, {}}, | ||||
| 		} | ||||
| 		s.init(s) // Init self-collection. | ||||
| @ -221,7 +221,7 @@ func newSummary(desc *Desc, opts SummaryOpts, labelValues ...string) Summary { | ||||
| 		objectives:       opts.Objectives, | ||||
| 		sortedObjectives: make([]float64, 0, len(opts.Objectives)), | ||||
|  | ||||
| 		labelPairs: makeLabelPairs(desc, labelValues), | ||||
| 		labelPairs: MakeLabelPairs(desc, labelValues), | ||||
|  | ||||
| 		hotBuf:         make([]float64, 0, opts.BufCap), | ||||
| 		coldBuf:        make([]float64, 0, opts.BufCap), | ||||
| @ -513,7 +513,7 @@ func (s quantSort) Less(i, j int) bool { | ||||
| // (e.g. HTTP request latencies, partitioned by status code and method). Create | ||||
| // instances with NewSummaryVec. | ||||
| type SummaryVec struct { | ||||
| 	*metricVec | ||||
| 	*MetricVec | ||||
| } | ||||
|  | ||||
| // NewSummaryVec creates a new SummaryVec based on the provided SummaryOpts and | ||||
| @ -535,14 +535,14 @@ func NewSummaryVec(opts SummaryOpts, labelNames []string) *SummaryVec { | ||||
| 		opts.ConstLabels, | ||||
| 	) | ||||
| 	return &SummaryVec{ | ||||
| 		metricVec: newMetricVec(desc, func(lvs ...string) Metric { | ||||
| 		MetricVec: NewMetricVec(desc, func(lvs ...string) Metric { | ||||
| 			return newSummary(desc, opts, lvs...) | ||||
| 		}), | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // GetMetricWithLabelValues returns the Summary for the given slice of label | ||||
| // values (same order as the VariableLabels in Desc). If that combination of | ||||
| // values (same order as the variable labels in Desc). If that combination of | ||||
| // label values is accessed for the first time, a new Summary is created. | ||||
| // | ||||
| // It is possible to call this method without using the returned Summary to only | ||||
| @ -557,7 +557,7 @@ func NewSummaryVec(opts SummaryOpts, labelNames []string) *SummaryVec { | ||||
| // example. | ||||
| // | ||||
| // An error is returned if the number of label values is not the same as the | ||||
| // number of VariableLabels in Desc (minus any curried labels). | ||||
| // number of variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // Note that for more than one label value, this method is prone to mistakes | ||||
| // caused by an incorrect order of arguments. Consider GetMetricWith(Labels) as | ||||
| @ -566,7 +566,7 @@ func NewSummaryVec(opts SummaryOpts, labelNames []string) *SummaryVec { | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| // See also the GaugeVec example. | ||||
| func (v *SummaryVec) GetMetricWithLabelValues(lvs ...string) (Observer, error) { | ||||
| 	metric, err := v.metricVec.getMetricWithLabelValues(lvs...) | ||||
| 	metric, err := v.MetricVec.GetMetricWithLabelValues(lvs...) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Observer), err | ||||
| 	} | ||||
| @ -574,19 +574,19 @@ func (v *SummaryVec) GetMetricWithLabelValues(lvs ...string) (Observer, error) { | ||||
| } | ||||
|  | ||||
| // GetMetricWith returns the Summary for the given Labels map (the label names | ||||
| // must match those of the VariableLabels in Desc). If that label map is | ||||
| // must match those of the variable labels in Desc). If that label map is | ||||
| // accessed for the first time, a new Summary is created. Implications of | ||||
| // creating a Summary without using it and keeping the Summary for later use are | ||||
| // the same as for GetMetricWithLabelValues. | ||||
| // | ||||
| // An error is returned if the number and names of the Labels are inconsistent | ||||
| // with those of the VariableLabels in Desc (minus any curried labels). | ||||
| // with those of the variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // This method is used for the same purpose as | ||||
| // GetMetricWithLabelValues(...string). See there for pros and cons of the two | ||||
| // methods. | ||||
| func (v *SummaryVec) GetMetricWith(labels Labels) (Observer, error) { | ||||
| 	metric, err := v.metricVec.getMetricWith(labels) | ||||
| 	metric, err := v.MetricVec.GetMetricWith(labels) | ||||
| 	if metric != nil { | ||||
| 		return metric.(Observer), err | ||||
| 	} | ||||
| @ -630,7 +630,7 @@ func (v *SummaryVec) With(labels Labels) Observer { | ||||
| // registered with a given registry (usually the uncurried version). The Reset | ||||
| // method deletes all metrics, even if called on a curried vector. | ||||
| func (v *SummaryVec) CurryWith(labels Labels) (ObserverVec, error) { | ||||
| 	vec, err := v.curryWith(labels) | ||||
| 	vec, err := v.MetricVec.CurryWith(labels) | ||||
| 	if vec != nil { | ||||
| 		return &SummaryVec{vec}, err | ||||
| 	} | ||||
| @ -716,7 +716,7 @@ func NewConstSummary( | ||||
| 		count:      count, | ||||
| 		sum:        sum, | ||||
| 		quantiles:  quantiles, | ||||
| 		labelPairs: makeLabelPairs(desc, labelValues), | ||||
| 		labelPairs: MakeLabelPairs(desc, labelValues), | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										13
									
								
								vendor/github.com/prometheus/client_golang/prometheus/value.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								vendor/github.com/prometheus/client_golang/prometheus/value.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -63,7 +63,7 @@ func newValueFunc(desc *Desc, valueType ValueType, function func() float64) *val | ||||
| 		desc:       desc, | ||||
| 		valType:    valueType, | ||||
| 		function:   function, | ||||
| 		labelPairs: makeLabelPairs(desc, nil), | ||||
| 		labelPairs: MakeLabelPairs(desc, nil), | ||||
| 	} | ||||
| 	result.init(result) | ||||
| 	return result | ||||
| @ -95,7 +95,7 @@ func NewConstMetric(desc *Desc, valueType ValueType, value float64, labelValues | ||||
| 		desc:       desc, | ||||
| 		valType:    valueType, | ||||
| 		val:        value, | ||||
| 		labelPairs: makeLabelPairs(desc, labelValues), | ||||
| 		labelPairs: MakeLabelPairs(desc, labelValues), | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
| @ -145,7 +145,14 @@ func populateMetric( | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func makeLabelPairs(desc *Desc, labelValues []string) []*dto.LabelPair { | ||||
| // MakeLabelPairs is a helper function to create protobuf LabelPairs from the | ||||
| // variable and constant labels in the provided Desc. The values for the | ||||
| // variable labels are defined by the labelValues slice, which must be in the | ||||
| // same order as the corresponding variable labels in the Desc. | ||||
| // | ||||
| // This function is only needed for custom Metric implementations. See MetricVec | ||||
| // example. | ||||
| func MakeLabelPairs(desc *Desc, labelValues []string) []*dto.LabelPair { | ||||
| 	totalLen := len(desc.variableLabels) + len(desc.constLabelPairs) | ||||
| 	if totalLen == 0 { | ||||
| 		// Super fast path. | ||||
|  | ||||
							
								
								
									
										112
									
								
								vendor/github.com/prometheus/client_golang/prometheus/vec.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										112
									
								
								vendor/github.com/prometheus/client_golang/prometheus/vec.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -20,12 +20,20 @@ import ( | ||||
| 	"github.com/prometheus/common/model" | ||||
| ) | ||||
|  | ||||
| // metricVec is a Collector to bundle metrics of the same name that differ in | ||||
| // their label values. metricVec is not used directly (and therefore | ||||
| // unexported). It is used as a building block for implementations of vectors of | ||||
| // a given metric type, like GaugeVec, CounterVec, SummaryVec, and HistogramVec. | ||||
| // It also handles label currying. | ||||
| type metricVec struct { | ||||
| // MetricVec is a Collector to bundle metrics of the same name that differ in | ||||
| // their label values. MetricVec is not used directly but as a building block | ||||
| // for implementations of vectors of a given metric type, like GaugeVec, | ||||
| // CounterVec, SummaryVec, and HistogramVec. It is exported so that it can be | ||||
| // used for custom Metric implementations. | ||||
| // | ||||
| // To create a FooVec for custom Metric Foo, embed a pointer to MetricVec in | ||||
| // FooVec and initialize it with NewMetricVec. Implement wrappers for | ||||
| // GetMetricWithLabelValues and GetMetricWith that return (Foo, error) rather | ||||
| // than (Metric, error). Similarly, create a wrapper for CurryWith that returns | ||||
| // (*FooVec, error) rather than (*MetricVec, error). It is recommended to also | ||||
| // add the convenience methods WithLabelValues, With, and MustCurryWith, which | ||||
| // panic instead of returning errors. See also the MetricVec example. | ||||
| type MetricVec struct { | ||||
| 	*metricMap | ||||
|  | ||||
| 	curry []curriedLabelValue | ||||
| @ -35,9 +43,9 @@ type metricVec struct { | ||||
| 	hashAddByte func(h uint64, b byte) uint64 | ||||
| } | ||||
|  | ||||
| // newMetricVec returns an initialized metricVec. | ||||
| func newMetricVec(desc *Desc, newMetric func(lvs ...string) Metric) *metricVec { | ||||
| 	return &metricVec{ | ||||
| // NewMetricVec returns an initialized metricVec. | ||||
| func NewMetricVec(desc *Desc, newMetric func(lvs ...string) Metric) *MetricVec { | ||||
| 	return &MetricVec{ | ||||
| 		metricMap: &metricMap{ | ||||
| 			metrics:   map[uint64][]metricWithLabelValues{}, | ||||
| 			desc:      desc, | ||||
| @ -63,7 +71,7 @@ func newMetricVec(desc *Desc, newMetric func(lvs ...string) Metric) *metricVec { | ||||
| // latter has a much more readable (albeit more verbose) syntax, but it comes | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| // See also the CounterVec example. | ||||
| func (m *metricVec) DeleteLabelValues(lvs ...string) bool { | ||||
| func (m *MetricVec) DeleteLabelValues(lvs ...string) bool { | ||||
| 	h, err := m.hashLabelValues(lvs) | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| @ -82,7 +90,7 @@ func (m *metricVec) DeleteLabelValues(lvs ...string) bool { | ||||
| // | ||||
| // This method is used for the same purpose as DeleteLabelValues(...string). See | ||||
| // there for pros and cons of the two methods. | ||||
| func (m *metricVec) Delete(labels Labels) bool { | ||||
| func (m *MetricVec) Delete(labels Labels) bool { | ||||
| 	h, err := m.hashLabels(labels) | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| @ -95,15 +103,32 @@ func (m *metricVec) Delete(labels Labels) bool { | ||||
| // show up in GoDoc. | ||||
|  | ||||
| // Describe implements Collector. | ||||
| func (m *metricVec) Describe(ch chan<- *Desc) { m.metricMap.Describe(ch) } | ||||
| func (m *MetricVec) Describe(ch chan<- *Desc) { m.metricMap.Describe(ch) } | ||||
|  | ||||
| // Collect implements Collector. | ||||
| func (m *metricVec) Collect(ch chan<- Metric) { m.metricMap.Collect(ch) } | ||||
| func (m *MetricVec) Collect(ch chan<- Metric) { m.metricMap.Collect(ch) } | ||||
|  | ||||
| // Reset deletes all metrics in this vector. | ||||
| func (m *metricVec) Reset() { m.metricMap.Reset() } | ||||
| func (m *MetricVec) Reset() { m.metricMap.Reset() } | ||||
|  | ||||
| func (m *metricVec) curryWith(labels Labels) (*metricVec, error) { | ||||
| // CurryWith returns a vector curried with the provided labels, i.e. the | ||||
| // returned vector has those labels pre-set for all labeled operations performed | ||||
| // on it. The cardinality of the curried vector is reduced accordingly. The | ||||
| // order of the remaining labels stays the same (just with the curried labels | ||||
| // taken out of the sequence – which is relevant for the | ||||
| // (GetMetric)WithLabelValues methods). It is possible to curry a curried | ||||
| // vector, but only with labels not yet used for currying before. | ||||
| // | ||||
| // The metrics contained in the MetricVec are shared between the curried and | ||||
| // uncurried vectors. They are just accessed differently. Curried and uncurried | ||||
| // vectors behave identically in terms of collection. Only one must be | ||||
| // registered with a given registry (usually the uncurried version). The Reset | ||||
| // method deletes all metrics, even if called on a curried vector. | ||||
| // | ||||
| // Note that CurryWith is usually not called directly but through a wrapper | ||||
| // around MetricVec, implementing a vector for a specific Metric | ||||
| // implementation, for example GaugeVec. | ||||
| func (m *MetricVec) CurryWith(labels Labels) (*MetricVec, error) { | ||||
| 	var ( | ||||
| 		newCurry []curriedLabelValue | ||||
| 		oldCurry = m.curry | ||||
| @ -128,7 +153,7 @@ func (m *metricVec) curryWith(labels Labels) (*metricVec, error) { | ||||
| 		return nil, fmt.Errorf("%d unknown label(s) found during currying", l) | ||||
| 	} | ||||
|  | ||||
| 	return &metricVec{ | ||||
| 	return &MetricVec{ | ||||
| 		metricMap:   m.metricMap, | ||||
| 		curry:       newCurry, | ||||
| 		hashAdd:     m.hashAdd, | ||||
| @ -136,7 +161,34 @@ func (m *metricVec) curryWith(labels Labels) (*metricVec, error) { | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
| func (m *metricVec) getMetricWithLabelValues(lvs ...string) (Metric, error) { | ||||
| // GetMetricWithLabelValues returns the Metric for the given slice of label | ||||
| // values (same order as the variable labels in Desc). If that combination of | ||||
| // label values is accessed for the first time, a new Metric is created (by | ||||
| // calling the newMetric function provided during construction of the | ||||
| // MetricVec). | ||||
| // | ||||
| // It is possible to call this method without using the returned Metry to only | ||||
| // create the new Metric but leave it in its intitial state. | ||||
| // | ||||
| // Keeping the Metric for later use is possible (and should be considered if | ||||
| // performance is critical), but keep in mind that Reset, DeleteLabelValues and | ||||
| // Delete can be used to delete the Metric from the MetricVec. In that case, the | ||||
| // Metric will still exist, but it will not be exported anymore, even if a | ||||
| // Metric with the same label values is created later. | ||||
| // | ||||
| // An error is returned if the number of label values is not the same as the | ||||
| // number of variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // Note that for more than one label value, this method is prone to mistakes | ||||
| // caused by an incorrect order of arguments. Consider GetMetricWith(Labels) as | ||||
| // an alternative to avoid that type of mistake. For higher label numbers, the | ||||
| // latter has a much more readable (albeit more verbose) syntax, but it comes | ||||
| // with a performance overhead (for creating and processing the Labels map). | ||||
| // | ||||
| // Note that GetMetricWithLabelValues is usually not called directly but through | ||||
| // a wrapper around MetricVec, implementing a vector for a specific Metric | ||||
| // implementation, for example GaugeVec. | ||||
| func (m *MetricVec) GetMetricWithLabelValues(lvs ...string) (Metric, error) { | ||||
| 	h, err := m.hashLabelValues(lvs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -145,7 +197,23 @@ func (m *metricVec) getMetricWithLabelValues(lvs ...string) (Metric, error) { | ||||
| 	return m.metricMap.getOrCreateMetricWithLabelValues(h, lvs, m.curry), nil | ||||
| } | ||||
|  | ||||
| func (m *metricVec) getMetricWith(labels Labels) (Metric, error) { | ||||
| // GetMetricWith returns the Metric for the given Labels map (the label names | ||||
| // must match those of the variable labels in Desc). If that label map is | ||||
| // accessed for the first time, a new Metric is created. Implications of | ||||
| // creating a Metric without using it and keeping the Metric for later use | ||||
| // are the same as for GetMetricWithLabelValues. | ||||
| // | ||||
| // An error is returned if the number and names of the Labels are inconsistent | ||||
| // with those of the variable labels in Desc (minus any curried labels). | ||||
| // | ||||
| // This method is used for the same purpose as | ||||
| // GetMetricWithLabelValues(...string). See there for pros and cons of the two | ||||
| // methods. | ||||
| // | ||||
| // Note that GetMetricWith is usually not called directly but through a wrapper | ||||
| // around MetricVec, implementing a vector for a specific Metric implementation, | ||||
| // for example GaugeVec. | ||||
| func (m *MetricVec) GetMetricWith(labels Labels) (Metric, error) { | ||||
| 	h, err := m.hashLabels(labels) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -154,7 +222,7 @@ func (m *metricVec) getMetricWith(labels Labels) (Metric, error) { | ||||
| 	return m.metricMap.getOrCreateMetricWithLabels(h, labels, m.curry), nil | ||||
| } | ||||
|  | ||||
| func (m *metricVec) hashLabelValues(vals []string) (uint64, error) { | ||||
| func (m *MetricVec) hashLabelValues(vals []string) (uint64, error) { | ||||
| 	if err := validateLabelValues(vals, len(m.desc.variableLabels)-len(m.curry)); err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| @ -177,7 +245,7 @@ func (m *metricVec) hashLabelValues(vals []string) (uint64, error) { | ||||
| 	return h, nil | ||||
| } | ||||
|  | ||||
| func (m *metricVec) hashLabels(labels Labels) (uint64, error) { | ||||
| func (m *MetricVec) hashLabels(labels Labels) (uint64, error) { | ||||
| 	if err := validateValuesInLabels(labels, len(m.desc.variableLabels)-len(m.curry)); err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| @ -276,7 +344,9 @@ func (m *metricMap) deleteByHashWithLabelValues( | ||||
| 	} | ||||
|  | ||||
| 	if len(metrics) > 1 { | ||||
| 		old := metrics | ||||
| 		m.metrics[h] = append(metrics[:i], metrics[i+1:]...) | ||||
| 		old[len(old)-1] = metricWithLabelValues{} | ||||
| 	} else { | ||||
| 		delete(m.metrics, h) | ||||
| 	} | ||||
| @ -302,7 +372,9 @@ func (m *metricMap) deleteByHashWithLabels( | ||||
| 	} | ||||
|  | ||||
| 	if len(metrics) > 1 { | ||||
| 		old := metrics | ||||
| 		m.metrics[h] = append(metrics[:i], metrics[i+1:]...) | ||||
| 		old[len(old)-1] = metricWithLabelValues{} | ||||
| 	} else { | ||||
| 		delete(m.metrics, h) | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										4
									
								
								vendor/github.com/prometheus/client_golang/prometheus/wrap.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/github.com/prometheus/client_golang/prometheus/wrap.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -32,7 +32,9 @@ import ( | ||||
| // in a no-op Registerer. | ||||
| // | ||||
| // WrapRegistererWith provides a way to add fixed labels to a subset of | ||||
| // Collectors. It should not be used to add fixed labels to all metrics exposed. | ||||
| // Collectors. It should not be used to add fixed labels to all metrics | ||||
| // exposed. See also | ||||
| // https://prometheus.io/docs/instrumenting/writing_exporters/#target-labels-not-static-scraped-labels | ||||
| // | ||||
| // Conflicts between Collectors registered through the original Registerer with | ||||
| // Collectors registered through the wrapping Registerer will still be | ||||
|  | ||||
							
								
								
									
										11
									
								
								vendor/github.com/prometheus/common/expfmt/text_parse.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								vendor/github.com/prometheus/common/expfmt/text_parse.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -299,6 +299,17 @@ func (p *TextParser) startLabelName() stateFn { | ||||
| 		p.parseError(fmt.Sprintf("expected '=' after label name, found %q", p.currentByte)) | ||||
| 		return nil | ||||
| 	} | ||||
| 	// Check for duplicate label names. | ||||
| 	labels := make(map[string]struct{}) | ||||
| 	for _, l := range p.currentMetric.Label { | ||||
| 		lName := l.GetName() | ||||
| 		if _, exists := labels[lName]; !exists { | ||||
| 			labels[lName] = struct{}{} | ||||
| 		} else { | ||||
| 			p.parseError(fmt.Sprintf("duplicate label names for metric %q", p.currentMF.GetName())) | ||||
| 			return nil | ||||
| 		} | ||||
| 	} | ||||
| 	return p.startLabelValue | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										3
									
								
								vendor/github.com/prometheus/procfs/CODE_OF_CONDUCT.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								vendor/github.com/prometheus/procfs/CODE_OF_CONDUCT.md
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| ## Prometheus Community Code of Conduct | ||||
|  | ||||
| Prometheus follows the [CNCF Code of Conduct](https://github.com/cncf/foundation/blob/master/code-of-conduct.md). | ||||
							
								
								
									
										44
									
								
								vendor/github.com/prometheus/procfs/cpuinfo.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										44
									
								
								vendor/github.com/prometheus/procfs/cpuinfo.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -407,6 +407,50 @@ func parseCPUInfoPPC(info []byte) ([]CPUInfo, error) { | ||||
| 	return cpuinfo, nil | ||||
| } | ||||
|  | ||||
| func parseCPUInfoRISCV(info []byte) ([]CPUInfo, error) { | ||||
| 	scanner := bufio.NewScanner(bytes.NewReader(info)) | ||||
|  | ||||
| 	firstLine := firstNonEmptyLine(scanner) | ||||
| 	if !strings.HasPrefix(firstLine, "processor") || !strings.Contains(firstLine, ":") { | ||||
| 		return nil, errors.New("invalid cpuinfo file: " + firstLine) | ||||
| 	} | ||||
| 	field := strings.SplitN(firstLine, ": ", 2) | ||||
| 	v, err := strconv.ParseUint(field[1], 0, 32) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	firstcpu := CPUInfo{Processor: uint(v)} | ||||
| 	cpuinfo := []CPUInfo{firstcpu} | ||||
| 	i := 0 | ||||
|  | ||||
| 	for scanner.Scan() { | ||||
| 		line := scanner.Text() | ||||
| 		if !strings.Contains(line, ":") { | ||||
| 			continue | ||||
| 		} | ||||
| 		field := strings.SplitN(line, ": ", 2) | ||||
| 		switch strings.TrimSpace(field[0]) { | ||||
| 		case "processor": | ||||
| 			v, err := strconv.ParseUint(field[1], 0, 32) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
| 			i = int(v) | ||||
| 			cpuinfo = append(cpuinfo, CPUInfo{}) // start of the next processor | ||||
| 			cpuinfo[i].Processor = uint(v) | ||||
| 		case "hart": | ||||
| 			cpuinfo[i].CoreID = field[1] | ||||
| 		case "isa": | ||||
| 			cpuinfo[i].ModelName = field[1] | ||||
| 		} | ||||
| 	} | ||||
| 	return cpuinfo, nil | ||||
| } | ||||
|  | ||||
| func parseCPUInfoDummy(_ []byte) ([]CPUInfo, error) { // nolint:unused,deadcode | ||||
| 	return nil, errors.New("not implemented") | ||||
| } | ||||
|  | ||||
| // firstNonEmptyLine advances the scanner to the first non-empty line | ||||
| // and returns the contents of that line | ||||
| func firstNonEmptyLine(scanner *bufio.Scanner) string { | ||||
|  | ||||
							
								
								
									
										19
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_arm64.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_arm64.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,19 +0,0 @@ | ||||
| // Copyright 2020 The Prometheus 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. | ||||
|  | ||||
| // +build linux | ||||
| // +build arm64 | ||||
|  | ||||
| package procfs | ||||
|  | ||||
| var parseCPUInfo = parseCPUInfoARM | ||||
| @ -12,6 +12,7 @@ | ||||
| // limitations under the License. | ||||
| 
 | ||||
| // +build linux | ||||
| // +build arm arm64 | ||||
| 
 | ||||
| package procfs | ||||
| 
 | ||||
							
								
								
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_mips64le.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_mips64le.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,18 +0,0 @@ | ||||
| // Copyright 2020 The Prometheus 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. | ||||
|  | ||||
| // +build linux | ||||
|  | ||||
| package procfs | ||||
|  | ||||
| var parseCPUInfo = parseCPUInfoMips | ||||
							
								
								
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_mipsle.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_mipsle.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,18 +0,0 @@ | ||||
| // Copyright 2020 The Prometheus 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. | ||||
|  | ||||
| // +build linux | ||||
|  | ||||
| package procfs | ||||
|  | ||||
| var parseCPUInfo = parseCPUInfoMips | ||||
| @ -12,6 +12,7 @@ | ||||
| // limitations under the License. | ||||
| 
 | ||||
| // +build linux | ||||
| // +build mips mipsle mips64 mips64le | ||||
| 
 | ||||
| package procfs | ||||
| 
 | ||||
| @ -12,7 +12,8 @@ | ||||
| // limitations under the License. | ||||
| 
 | ||||
| // +build linux | ||||
| // +build !386,!amd64,!arm,!arm64,!mips,!mips64,!mips64le,!mipsle,!ppc64,!ppc64le,!riscv64,!s390x | ||||
| 
 | ||||
| package procfs | ||||
| 
 | ||||
| var parseCPUInfo = parseCPUInfoMips | ||||
| var parseCPUInfo = parseCPUInfoDummy | ||||
							
								
								
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_ppc64le.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								vendor/github.com/prometheus/procfs/cpuinfo_ppc64le.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,18 +0,0 @@ | ||||
| // Copyright 2020 The Prometheus 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. | ||||
|  | ||||
| // +build linux | ||||
|  | ||||
| package procfs | ||||
|  | ||||
| var parseCPUInfo = parseCPUInfoPPC | ||||
| @ -12,6 +12,7 @@ | ||||
| // limitations under the License. | ||||
| 
 | ||||
| // +build linux | ||||
| // +build ppc64 ppc64le | ||||
| 
 | ||||
| package procfs | ||||
| 
 | ||||
							
								
								
									
										75
									
								
								vendor/github.com/prometheus/procfs/fixtures.ttar
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										75
									
								
								vendor/github.com/prometheus/procfs/fixtures.ttar
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -467,7 +467,7 @@ Pid:	26231 | ||||
| PPid:	1 | ||||
| TracerPid:	0 | ||||
| Uid:	1000	1000	1000	0 | ||||
| Gid:	0	0	0	0 | ||||
| Gid:	1001	1001	1001	0 | ||||
| FDSize:	128 | ||||
| Groups: | ||||
| NStgid:	1 | ||||
| @ -1966,7 +1966,7 @@ Lines: 1 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/proc/mdstat | ||||
| Lines: 56 | ||||
| Lines: 60 | ||||
| Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10] | ||||
|  | ||||
| md3 : active raid6 sda1[8] sdh1[7] sdg1[6] sdf1[5] sde1[11] sdd1[3] sdc1[10] sdb1[9] sdd1[10](S) sdd2[11](S) | ||||
| @ -1989,6 +1989,10 @@ md8 : active raid1 sdb1[1] sda1[0] sdc[2](S) sde[3](S) | ||||
|       195310144 blocks [2/2] [UU] | ||||
|       [=>...................]  resync =  8.5% (16775552/195310144) finish=17.0min speed=259783K/sec | ||||
|  | ||||
| md201 : active raid1 sda3[0] sdb3[1] | ||||
|       1993728 blocks super 1.2 [2/2] [UU] | ||||
|       [=>...................]  check =  5.7% (114176/1993728) finish=0.2min speed=114176K/sec | ||||
|  | ||||
| md7 : active raid6 sdb1[0] sde1[3] sdd1[2] sdc1[1](F) | ||||
|       7813735424 blocks super 1.2 level 6, 512k chunk, algorithm 2 [4/3] [U_UU] | ||||
|       bitmap: 0/30 pages [0KB], 65536KB chunk | ||||
| @ -3754,6 +3758,73 @@ Path: fixtures/sys/class/powercap/intel-rapl:0:0/uevent | ||||
| Lines: 0 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Directory: fixtures/sys/class/powercap/intel-rapl:a | ||||
| Mode: 755 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_0_max_power_uw | ||||
| Lines: 1 | ||||
| 95000000 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_0_name | ||||
| Lines: 1 | ||||
| long_term | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_0_power_limit_uw | ||||
| Lines: 1 | ||||
| 4090000000 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_0_time_window_us | ||||
| Lines: 1 | ||||
| 999424 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_1_max_power_uw | ||||
| Lines: 1 | ||||
| 0 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_1_name | ||||
| Lines: 1 | ||||
| short_term | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_1_power_limit_uw | ||||
| Lines: 1 | ||||
| 4090000000 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/constraint_1_time_window_us | ||||
| Lines: 1 | ||||
| 2440 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/enabled | ||||
| Lines: 1 | ||||
| 1 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/energy_uj | ||||
| Lines: 1 | ||||
| 240422366267 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/max_energy_range_uj | ||||
| Lines: 1 | ||||
| 262143328850 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/name | ||||
| Lines: 1 | ||||
| package-10 | ||||
| Mode: 444 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Path: fixtures/sys/class/powercap/intel-rapl:a/uevent | ||||
| Lines: 0 | ||||
| Mode: 644 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
| Directory: fixtures/sys/class/thermal | ||||
| Mode: 775 | ||||
| # ttar - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||||
|  | ||||
							
								
								
									
										2
									
								
								vendor/github.com/prometheus/procfs/kernel_random.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/prometheus/procfs/kernel_random.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -25,7 +25,7 @@ import ( | ||||
| type KernelRandom struct { | ||||
| 	// EntropyAvaliable gives the available entropy, in bits. | ||||
| 	EntropyAvaliable *uint64 | ||||
| 	// PoolSize gives the size of the entropy pool, in bytes. | ||||
| 	// PoolSize gives the size of the entropy pool, in bits. | ||||
| 	PoolSize *uint64 | ||||
| 	// URandomMinReseedSeconds is the number of seconds after which the DRNG will be reseeded. | ||||
| 	URandomMinReseedSeconds *uint64 | ||||
|  | ||||
							
								
								
									
										5
									
								
								vendor/github.com/prometheus/procfs/mdstat.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								vendor/github.com/prometheus/procfs/mdstat.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -107,11 +107,14 @@ func parseMDStat(mdStatData []byte) ([]MDStat, error) { | ||||
| 		syncedBlocks := size | ||||
| 		recovering := strings.Contains(lines[syncLineIdx], "recovery") | ||||
| 		resyncing := strings.Contains(lines[syncLineIdx], "resync") | ||||
| 		checking := strings.Contains(lines[syncLineIdx], "check") | ||||
|  | ||||
| 		// Append recovery and resyncing state info. | ||||
| 		if recovering || resyncing { | ||||
| 		if recovering || resyncing || checking { | ||||
| 			if recovering { | ||||
| 				state = "recovering" | ||||
| 			} else if checking { | ||||
| 				state = "checking" | ||||
| 			} else { | ||||
| 				state = "resyncing" | ||||
| 			} | ||||
|  | ||||
							
								
								
									
										6
									
								
								vendor/github.com/prometheus/procfs/proc_status.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								vendor/github.com/prometheus/procfs/proc_status.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -72,8 +72,10 @@ type ProcStatus struct { | ||||
| 	// Number of involuntary context switches. | ||||
| 	NonVoluntaryCtxtSwitches uint64 | ||||
|  | ||||
| 	// UIDs of the process (Real, effective, saved set, and filesystem UIDs (GIDs)) | ||||
| 	// UIDs of the process (Real, effective, saved set, and filesystem UIDs) | ||||
| 	UIDs [4]string | ||||
| 	// GIDs of the process (Real, effective, saved set, and filesystem GIDs) | ||||
| 	GIDs [4]string | ||||
| } | ||||
|  | ||||
| // NewStatus returns the current status information of the process. | ||||
| @ -119,6 +121,8 @@ func (s *ProcStatus) fillStatus(k string, vString string, vUint uint64, vUintByt | ||||
| 		s.Name = vString | ||||
| 	case "Uid": | ||||
| 		copy(s.UIDs[:], strings.Split(vString, "\t")) | ||||
| 	case "Gid": | ||||
| 		copy(s.GIDs[:], strings.Split(vString, "\t")) | ||||
| 	case "VmPeak": | ||||
| 		s.VmPeak = vUintBytes | ||||
| 	case "VmSize": | ||||
|  | ||||
							
								
								
									
										7
									
								
								vendor/github.com/spf13/pflag/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/github.com/spf13/pflag/.travis.yml
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -3,8 +3,9 @@ sudo: false | ||||
| language: go | ||||
|  | ||||
| go: | ||||
|   - 1.7.3 | ||||
|   - 1.8.1 | ||||
|   - 1.9.x | ||||
|   - 1.10.x | ||||
|   - 1.11.x | ||||
|   - tip | ||||
|  | ||||
| matrix: | ||||
| @ -12,7 +13,7 @@ matrix: | ||||
|     - go: tip | ||||
|  | ||||
| install: | ||||
|   - go get github.com/golang/lint/golint | ||||
|   - go get golang.org/x/lint/golint | ||||
|   - export PATH=$GOPATH/bin:$PATH | ||||
|   - go install ./... | ||||
|  | ||||
|  | ||||
							
								
								
									
										4
									
								
								vendor/github.com/spf13/pflag/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/github.com/spf13/pflag/README.md
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -86,8 +86,8 @@ fmt.Println("ip has value ", *ip) | ||||
| fmt.Println("flagvar has value ", flagvar) | ||||
| ``` | ||||
|  | ||||
| There are helpers function to get values later if you have the FlagSet but | ||||
| it was difficult to keep up with all of the flag pointers in your code. | ||||
| There are helper functions available to get the value stored in a Flag if you have a FlagSet but find | ||||
| it difficult to keep up with all of the pointers in your code. | ||||
| If you have a pflag.FlagSet with a flag called 'flagname' of type int you | ||||
| can use GetInt() to get the int value. But notice that 'flagname' must exist | ||||
| and it must be an int. GetString("flagname") will fail. | ||||
|  | ||||
							
								
								
									
										38
									
								
								vendor/github.com/spf13/pflag/bool_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								vendor/github.com/spf13/pflag/bool_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -71,6 +71,44 @@ func (s *boolSliceValue) String() string { | ||||
| 	return "[" + out + "]" | ||||
| } | ||||
|  | ||||
| func (s *boolSliceValue) fromString(val string) (bool, error) { | ||||
| 	return strconv.ParseBool(val) | ||||
| } | ||||
|  | ||||
| func (s *boolSliceValue) toString(val bool) string { | ||||
| 	return strconv.FormatBool(val) | ||||
| } | ||||
|  | ||||
| func (s *boolSliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *boolSliceValue) Replace(val []string) error { | ||||
| 	out := make([]bool, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *boolSliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func boolSliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
|  | ||||
							
								
								
									
										104
									
								
								vendor/github.com/spf13/pflag/bytes.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										104
									
								
								vendor/github.com/spf13/pflag/bytes.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,6 +1,7 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"encoding/base64" | ||||
| 	"encoding/hex" | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| @ -9,10 +10,12 @@ import ( | ||||
| // BytesHex adapts []byte for use as a flag. Value of flag is HEX encoded | ||||
| type bytesHexValue []byte | ||||
|  | ||||
| // String implements pflag.Value.String. | ||||
| func (bytesHex bytesHexValue) String() string { | ||||
| 	return fmt.Sprintf("%X", []byte(bytesHex)) | ||||
| } | ||||
|  | ||||
| // Set implements pflag.Value.Set. | ||||
| func (bytesHex *bytesHexValue) Set(value string) error { | ||||
| 	bin, err := hex.DecodeString(strings.TrimSpace(value)) | ||||
|  | ||||
| @ -25,6 +28,7 @@ func (bytesHex *bytesHexValue) Set(value string) error { | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // Type implements pflag.Value.Type. | ||||
| func (*bytesHexValue) Type() string { | ||||
| 	return "bytesHex" | ||||
| } | ||||
| @ -103,3 +107,103 @@ func BytesHex(name string, value []byte, usage string) *[]byte { | ||||
| func BytesHexP(name, shorthand string, value []byte, usage string) *[]byte { | ||||
| 	return CommandLine.BytesHexP(name, shorthand, value, usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64 adapts []byte for use as a flag. Value of flag is Base64 encoded | ||||
| type bytesBase64Value []byte | ||||
|  | ||||
| // String implements pflag.Value.String. | ||||
| func (bytesBase64 bytesBase64Value) String() string { | ||||
| 	return base64.StdEncoding.EncodeToString([]byte(bytesBase64)) | ||||
| } | ||||
|  | ||||
| // Set implements pflag.Value.Set. | ||||
| func (bytesBase64 *bytesBase64Value) Set(value string) error { | ||||
| 	bin, err := base64.StdEncoding.DecodeString(strings.TrimSpace(value)) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	*bytesBase64 = bin | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // Type implements pflag.Value.Type. | ||||
| func (*bytesBase64Value) Type() string { | ||||
| 	return "bytesBase64" | ||||
| } | ||||
|  | ||||
| func newBytesBase64Value(val []byte, p *[]byte) *bytesBase64Value { | ||||
| 	*p = val | ||||
| 	return (*bytesBase64Value)(p) | ||||
| } | ||||
|  | ||||
| func bytesBase64ValueConv(sval string) (interface{}, error) { | ||||
|  | ||||
| 	bin, err := base64.StdEncoding.DecodeString(sval) | ||||
| 	if err == nil { | ||||
| 		return bin, nil | ||||
| 	} | ||||
|  | ||||
| 	return nil, fmt.Errorf("invalid string being converted to Bytes: %s %s", sval, err) | ||||
| } | ||||
|  | ||||
| // GetBytesBase64 return the []byte value of a flag with the given name | ||||
| func (f *FlagSet) GetBytesBase64(name string) ([]byte, error) { | ||||
| 	val, err := f.getFlagType(name, "bytesBase64", bytesBase64ValueConv) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return []byte{}, err | ||||
| 	} | ||||
|  | ||||
| 	return val.([]byte), nil | ||||
| } | ||||
|  | ||||
| // BytesBase64Var defines an []byte flag with specified name, default value, and usage string. | ||||
| // The argument p points to an []byte variable in which to store the value of the flag. | ||||
| func (f *FlagSet) BytesBase64Var(p *[]byte, name string, value []byte, usage string) { | ||||
| 	f.VarP(newBytesBase64Value(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64VarP is like BytesBase64Var, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) BytesBase64VarP(p *[]byte, name, shorthand string, value []byte, usage string) { | ||||
| 	f.VarP(newBytesBase64Value(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64Var defines an []byte flag with specified name, default value, and usage string. | ||||
| // The argument p points to an []byte variable in which to store the value of the flag. | ||||
| func BytesBase64Var(p *[]byte, name string, value []byte, usage string) { | ||||
| 	CommandLine.VarP(newBytesBase64Value(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64VarP is like BytesBase64Var, but accepts a shorthand letter that can be used after a single dash. | ||||
| func BytesBase64VarP(p *[]byte, name, shorthand string, value []byte, usage string) { | ||||
| 	CommandLine.VarP(newBytesBase64Value(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64 defines an []byte flag with specified name, default value, and usage string. | ||||
| // The return value is the address of an []byte variable that stores the value of the flag. | ||||
| func (f *FlagSet) BytesBase64(name string, value []byte, usage string) *[]byte { | ||||
| 	p := new([]byte) | ||||
| 	f.BytesBase64VarP(p, name, "", value, usage) | ||||
| 	return p | ||||
| } | ||||
|  | ||||
| // BytesBase64P is like BytesBase64, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) BytesBase64P(name, shorthand string, value []byte, usage string) *[]byte { | ||||
| 	p := new([]byte) | ||||
| 	f.BytesBase64VarP(p, name, shorthand, value, usage) | ||||
| 	return p | ||||
| } | ||||
|  | ||||
| // BytesBase64 defines an []byte flag with specified name, default value, and usage string. | ||||
| // The return value is the address of an []byte variable that stores the value of the flag. | ||||
| func BytesBase64(name string, value []byte, usage string) *[]byte { | ||||
| 	return CommandLine.BytesBase64P(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // BytesBase64P is like BytesBase64, but accepts a shorthand letter that can be used after a single dash. | ||||
| func BytesBase64P(name, shorthand string, value []byte, usage string) *[]byte { | ||||
| 	return CommandLine.BytesBase64P(name, shorthand, value, usage) | ||||
| } | ||||
|  | ||||
							
								
								
									
										4
									
								
								vendor/github.com/spf13/pflag/count.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/github.com/spf13/pflag/count.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -46,7 +46,7 @@ func (f *FlagSet) GetCount(name string) (int, error) { | ||||
|  | ||||
| // CountVar defines a count flag with specified name, default value, and usage string. | ||||
| // The argument p points to an int variable in which to store the value of the flag. | ||||
| // A count flag will add 1 to its value evey time it is found on the command line | ||||
| // A count flag will add 1 to its value every time it is found on the command line | ||||
| func (f *FlagSet) CountVar(p *int, name string, usage string) { | ||||
| 	f.CountVarP(p, name, "", usage) | ||||
| } | ||||
| @ -69,7 +69,7 @@ func CountVarP(p *int, name, shorthand string, usage string) { | ||||
|  | ||||
| // Count defines a count flag with specified name, default value, and usage string. | ||||
| // The return value is the address of an int variable that stores the value of the flag. | ||||
| // A count flag will add 1 to its value evey time it is found on the command line | ||||
| // A count flag will add 1 to its value every time it is found on the command line | ||||
| func (f *FlagSet) Count(name string, usage string) *int { | ||||
| 	p := new(int) | ||||
| 	f.CountVarP(p, name, "", usage) | ||||
|  | ||||
							
								
								
									
										38
									
								
								vendor/github.com/spf13/pflag/duration_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								vendor/github.com/spf13/pflag/duration_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -51,6 +51,44 @@ func (s *durationSliceValue) String() string { | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *durationSliceValue) fromString(val string) (time.Duration, error) { | ||||
| 	return time.ParseDuration(val) | ||||
| } | ||||
|  | ||||
| func (s *durationSliceValue) toString(val time.Duration) string { | ||||
| 	return fmt.Sprintf("%s", val) | ||||
| } | ||||
|  | ||||
| func (s *durationSliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *durationSliceValue) Replace(val []string) error { | ||||
| 	out := make([]time.Duration, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *durationSliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func durationSliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
|  | ||||
							
								
								
									
										24
									
								
								vendor/github.com/spf13/pflag/flag.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								vendor/github.com/spf13/pflag/flag.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -57,9 +57,9 @@ that give one-letter shorthands for flags. You can use these by appending | ||||
| 	var ip = flag.IntP("flagname", "f", 1234, "help message") | ||||
| 	var flagvar bool | ||||
| 	func init() { | ||||
| 		flag.BoolVarP("boolname", "b", true, "help message") | ||||
| 		flag.BoolVarP(&flagvar, "boolname", "b", true, "help message") | ||||
| 	} | ||||
| 	flag.VarP(&flagVar, "varname", "v", 1234, "help message") | ||||
| 	flag.VarP(&flagval, "varname", "v", "help message") | ||||
| Shorthand letters can be used with single dashes on the command line. | ||||
| Boolean shorthand flags can be combined with other shorthand flags. | ||||
|  | ||||
| @ -190,6 +190,18 @@ type Value interface { | ||||
| 	Type() string | ||||
| } | ||||
|  | ||||
| // SliceValue is a secondary interface to all flags which hold a list | ||||
| // of values.  This allows full control over the value of list flags, | ||||
| // and avoids complicated marshalling and unmarshalling to csv. | ||||
| type SliceValue interface { | ||||
| 	// Append adds the specified value to the end of the flag value list. | ||||
| 	Append(string) error | ||||
| 	// Replace will fully overwrite any data currently in the flag value list. | ||||
| 	Replace([]string) error | ||||
| 	// GetSlice returns the flag value list as an array of strings. | ||||
| 	GetSlice() []string | ||||
| } | ||||
|  | ||||
| // sortFlags returns the flags as a slice in lexicographical sorted order. | ||||
| func sortFlags(flags map[NormalizedName]*Flag) []*Flag { | ||||
| 	list := make(sort.StringSlice, len(flags)) | ||||
| @ -925,14 +937,17 @@ func stripUnknownFlagValue(args []string) []string { | ||||
| 	} | ||||
|  | ||||
| 	first := args[0] | ||||
| 	if first[0] == '-' { | ||||
| 	if len(first) > 0 && first[0] == '-' { | ||||
| 		//--unknown --next-flag ... | ||||
| 		return args | ||||
| 	} | ||||
|  | ||||
| 	//--unknown arg ... (args will be arg ...) | ||||
| 	if len(args) > 1 { | ||||
| 		return args[1:] | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (f *FlagSet) parseLongArg(s string, args []string, fn parseFunc) (a []string, err error) { | ||||
| 	a = args | ||||
| @ -990,11 +1005,12 @@ func (f *FlagSet) parseLongArg(s string, args []string, fn parseFunc) (a []strin | ||||
| } | ||||
|  | ||||
| func (f *FlagSet) parseSingleShortArg(shorthands string, args []string, fn parseFunc) (outShorts string, outArgs []string, err error) { | ||||
| 	outArgs = args | ||||
|  | ||||
| 	if strings.HasPrefix(shorthands, "test.") { | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	outArgs = args | ||||
| 	outShorts = shorthands[1:] | ||||
| 	c := shorthands[0] | ||||
|  | ||||
|  | ||||
							
								
								
									
										174
									
								
								vendor/github.com/spf13/pflag/float32_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								vendor/github.com/spf13/pflag/float32_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,174 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- float32Slice Value | ||||
| type float32SliceValue struct { | ||||
| 	value   *[]float32 | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newFloat32SliceValue(val []float32, p *[]float32) *float32SliceValue { | ||||
| 	isv := new(float32SliceValue) | ||||
| 	isv.value = p | ||||
| 	*isv.value = val | ||||
| 	return isv | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]float32, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		var temp64 float64 | ||||
| 		temp64, err = strconv.ParseFloat(d, 32) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		out[i] = float32(temp64) | ||||
|  | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		*s.value = append(*s.value, out...) | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) Type() string { | ||||
| 	return "float32Slice" | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) String() string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = fmt.Sprintf("%f", d) | ||||
| 	} | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) fromString(val string) (float32, error) { | ||||
| 	t64, err := strconv.ParseFloat(val, 32) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return float32(t64), nil | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) toString(val float32) string { | ||||
| 	return fmt.Sprintf("%f", val) | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) Replace(val []string) error { | ||||
| 	out := make([]float32, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float32SliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func float32SliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
| 	if len(val) == 0 { | ||||
| 		return []float32{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]float32, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		var temp64 float64 | ||||
| 		temp64, err = strconv.ParseFloat(d, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		out[i] = float32(temp64) | ||||
|  | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetFloat32Slice return the []float32 value of a flag with the given name | ||||
| func (f *FlagSet) GetFloat32Slice(name string) ([]float32, error) { | ||||
| 	val, err := f.getFlagType(name, "float32Slice", float32SliceConv) | ||||
| 	if err != nil { | ||||
| 		return []float32{}, err | ||||
| 	} | ||||
| 	return val.([]float32), nil | ||||
| } | ||||
|  | ||||
| // Float32SliceVar defines a float32Slice flag with specified name, default value, and usage string. | ||||
| // The argument p points to a []float32 variable in which to store the value of the flag. | ||||
| func (f *FlagSet) Float32SliceVar(p *[]float32, name string, value []float32, usage string) { | ||||
| 	f.VarP(newFloat32SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Float32SliceVarP is like Float32SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Float32SliceVarP(p *[]float32, name, shorthand string, value []float32, usage string) { | ||||
| 	f.VarP(newFloat32SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Float32SliceVar defines a float32[] flag with specified name, default value, and usage string. | ||||
| // The argument p points to a float32[] variable in which to store the value of the flag. | ||||
| func Float32SliceVar(p *[]float32, name string, value []float32, usage string) { | ||||
| 	CommandLine.VarP(newFloat32SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Float32SliceVarP is like Float32SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Float32SliceVarP(p *[]float32, name, shorthand string, value []float32, usage string) { | ||||
| 	CommandLine.VarP(newFloat32SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Float32Slice defines a []float32 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []float32 variable that stores the value of the flag. | ||||
| func (f *FlagSet) Float32Slice(name string, value []float32, usage string) *[]float32 { | ||||
| 	p := []float32{} | ||||
| 	f.Float32SliceVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Float32SliceP is like Float32Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Float32SliceP(name, shorthand string, value []float32, usage string) *[]float32 { | ||||
| 	p := []float32{} | ||||
| 	f.Float32SliceVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Float32Slice defines a []float32 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []float32 variable that stores the value of the flag. | ||||
| func Float32Slice(name string, value []float32, usage string) *[]float32 { | ||||
| 	return CommandLine.Float32SliceP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // Float32SliceP is like Float32Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Float32SliceP(name, shorthand string, value []float32, usage string) *[]float32 { | ||||
| 	return CommandLine.Float32SliceP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										166
									
								
								vendor/github.com/spf13/pflag/float64_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								vendor/github.com/spf13/pflag/float64_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,166 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- float64Slice Value | ||||
| type float64SliceValue struct { | ||||
| 	value   *[]float64 | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newFloat64SliceValue(val []float64, p *[]float64) *float64SliceValue { | ||||
| 	isv := new(float64SliceValue) | ||||
| 	isv.value = p | ||||
| 	*isv.value = val | ||||
| 	return isv | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]float64, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		out[i], err = strconv.ParseFloat(d, 64) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		*s.value = append(*s.value, out...) | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) Type() string { | ||||
| 	return "float64Slice" | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) String() string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = fmt.Sprintf("%f", d) | ||||
| 	} | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) fromString(val string) (float64, error) { | ||||
| 	return strconv.ParseFloat(val, 64) | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) toString(val float64) string { | ||||
| 	return fmt.Sprintf("%f", val) | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) Replace(val []string) error { | ||||
| 	out := make([]float64, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *float64SliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func float64SliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
| 	if len(val) == 0 { | ||||
| 		return []float64{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]float64, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		out[i], err = strconv.ParseFloat(d, 64) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
|  | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetFloat64Slice return the []float64 value of a flag with the given name | ||||
| func (f *FlagSet) GetFloat64Slice(name string) ([]float64, error) { | ||||
| 	val, err := f.getFlagType(name, "float64Slice", float64SliceConv) | ||||
| 	if err != nil { | ||||
| 		return []float64{}, err | ||||
| 	} | ||||
| 	return val.([]float64), nil | ||||
| } | ||||
|  | ||||
| // Float64SliceVar defines a float64Slice flag with specified name, default value, and usage string. | ||||
| // The argument p points to a []float64 variable in which to store the value of the flag. | ||||
| func (f *FlagSet) Float64SliceVar(p *[]float64, name string, value []float64, usage string) { | ||||
| 	f.VarP(newFloat64SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Float64SliceVarP is like Float64SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Float64SliceVarP(p *[]float64, name, shorthand string, value []float64, usage string) { | ||||
| 	f.VarP(newFloat64SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Float64SliceVar defines a float64[] flag with specified name, default value, and usage string. | ||||
| // The argument p points to a float64[] variable in which to store the value of the flag. | ||||
| func Float64SliceVar(p *[]float64, name string, value []float64, usage string) { | ||||
| 	CommandLine.VarP(newFloat64SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Float64SliceVarP is like Float64SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Float64SliceVarP(p *[]float64, name, shorthand string, value []float64, usage string) { | ||||
| 	CommandLine.VarP(newFloat64SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Float64Slice defines a []float64 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []float64 variable that stores the value of the flag. | ||||
| func (f *FlagSet) Float64Slice(name string, value []float64, usage string) *[]float64 { | ||||
| 	p := []float64{} | ||||
| 	f.Float64SliceVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Float64SliceP is like Float64Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Float64SliceP(name, shorthand string, value []float64, usage string) *[]float64 { | ||||
| 	p := []float64{} | ||||
| 	f.Float64SliceVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Float64Slice defines a []float64 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []float64 variable that stores the value of the flag. | ||||
| func Float64Slice(name string, value []float64, usage string) *[]float64 { | ||||
| 	return CommandLine.Float64SliceP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // Float64SliceP is like Float64Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Float64SliceP(name, shorthand string, value []float64, usage string) *[]float64 { | ||||
| 	return CommandLine.Float64SliceP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										3
									
								
								vendor/github.com/spf13/pflag/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								vendor/github.com/spf13/pflag/go.mod
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| module github.com/spf13/pflag | ||||
|  | ||||
| go 1.12 | ||||
							
								
								
									
										0
									
								
								vendor/github.com/spf13/pflag/go.sum
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								vendor/github.com/spf13/pflag/go.sum
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
								
								
									
										174
									
								
								vendor/github.com/spf13/pflag/int32_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								vendor/github.com/spf13/pflag/int32_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,174 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- int32Slice Value | ||||
| type int32SliceValue struct { | ||||
| 	value   *[]int32 | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newInt32SliceValue(val []int32, p *[]int32) *int32SliceValue { | ||||
| 	isv := new(int32SliceValue) | ||||
| 	isv.value = p | ||||
| 	*isv.value = val | ||||
| 	return isv | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]int32, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		var temp64 int64 | ||||
| 		temp64, err = strconv.ParseInt(d, 0, 32) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		out[i] = int32(temp64) | ||||
|  | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		*s.value = append(*s.value, out...) | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) Type() string { | ||||
| 	return "int32Slice" | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) String() string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = fmt.Sprintf("%d", d) | ||||
| 	} | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) fromString(val string) (int32, error) { | ||||
| 	t64, err := strconv.ParseInt(val, 0, 32) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return int32(t64), nil | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) toString(val int32) string { | ||||
| 	return fmt.Sprintf("%d", val) | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) Replace(val []string) error { | ||||
| 	out := make([]int32, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int32SliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func int32SliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
| 	if len(val) == 0 { | ||||
| 		return []int32{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]int32, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		var temp64 int64 | ||||
| 		temp64, err = strconv.ParseInt(d, 0, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		out[i] = int32(temp64) | ||||
|  | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetInt32Slice return the []int32 value of a flag with the given name | ||||
| func (f *FlagSet) GetInt32Slice(name string) ([]int32, error) { | ||||
| 	val, err := f.getFlagType(name, "int32Slice", int32SliceConv) | ||||
| 	if err != nil { | ||||
| 		return []int32{}, err | ||||
| 	} | ||||
| 	return val.([]int32), nil | ||||
| } | ||||
|  | ||||
| // Int32SliceVar defines a int32Slice flag with specified name, default value, and usage string. | ||||
| // The argument p points to a []int32 variable in which to store the value of the flag. | ||||
| func (f *FlagSet) Int32SliceVar(p *[]int32, name string, value []int32, usage string) { | ||||
| 	f.VarP(newInt32SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Int32SliceVarP is like Int32SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Int32SliceVarP(p *[]int32, name, shorthand string, value []int32, usage string) { | ||||
| 	f.VarP(newInt32SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Int32SliceVar defines a int32[] flag with specified name, default value, and usage string. | ||||
| // The argument p points to a int32[] variable in which to store the value of the flag. | ||||
| func Int32SliceVar(p *[]int32, name string, value []int32, usage string) { | ||||
| 	CommandLine.VarP(newInt32SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Int32SliceVarP is like Int32SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Int32SliceVarP(p *[]int32, name, shorthand string, value []int32, usage string) { | ||||
| 	CommandLine.VarP(newInt32SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Int32Slice defines a []int32 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []int32 variable that stores the value of the flag. | ||||
| func (f *FlagSet) Int32Slice(name string, value []int32, usage string) *[]int32 { | ||||
| 	p := []int32{} | ||||
| 	f.Int32SliceVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Int32SliceP is like Int32Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Int32SliceP(name, shorthand string, value []int32, usage string) *[]int32 { | ||||
| 	p := []int32{} | ||||
| 	f.Int32SliceVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Int32Slice defines a []int32 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []int32 variable that stores the value of the flag. | ||||
| func Int32Slice(name string, value []int32, usage string) *[]int32 { | ||||
| 	return CommandLine.Int32SliceP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // Int32SliceP is like Int32Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Int32SliceP(name, shorthand string, value []int32, usage string) *[]int32 { | ||||
| 	return CommandLine.Int32SliceP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										166
									
								
								vendor/github.com/spf13/pflag/int64_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								vendor/github.com/spf13/pflag/int64_slice.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,166 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- int64Slice Value | ||||
| type int64SliceValue struct { | ||||
| 	value   *[]int64 | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newInt64SliceValue(val []int64, p *[]int64) *int64SliceValue { | ||||
| 	isv := new(int64SliceValue) | ||||
| 	isv.value = p | ||||
| 	*isv.value = val | ||||
| 	return isv | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]int64, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		out[i], err = strconv.ParseInt(d, 0, 64) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		*s.value = append(*s.value, out...) | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) Type() string { | ||||
| 	return "int64Slice" | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) String() string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = fmt.Sprintf("%d", d) | ||||
| 	} | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) fromString(val string) (int64, error) { | ||||
| 	return strconv.ParseInt(val, 0, 64) | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) toString(val int64) string { | ||||
| 	return fmt.Sprintf("%d", val) | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) Replace(val []string) error { | ||||
| 	out := make([]int64, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *int64SliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func int64SliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
| 	if len(val) == 0 { | ||||
| 		return []int64{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make([]int64, len(ss)) | ||||
| 	for i, d := range ss { | ||||
| 		var err error | ||||
| 		out[i], err = strconv.ParseInt(d, 0, 64) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
|  | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetInt64Slice return the []int64 value of a flag with the given name | ||||
| func (f *FlagSet) GetInt64Slice(name string) ([]int64, error) { | ||||
| 	val, err := f.getFlagType(name, "int64Slice", int64SliceConv) | ||||
| 	if err != nil { | ||||
| 		return []int64{}, err | ||||
| 	} | ||||
| 	return val.([]int64), nil | ||||
| } | ||||
|  | ||||
| // Int64SliceVar defines a int64Slice flag with specified name, default value, and usage string. | ||||
| // The argument p points to a []int64 variable in which to store the value of the flag. | ||||
| func (f *FlagSet) Int64SliceVar(p *[]int64, name string, value []int64, usage string) { | ||||
| 	f.VarP(newInt64SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Int64SliceVarP is like Int64SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Int64SliceVarP(p *[]int64, name, shorthand string, value []int64, usage string) { | ||||
| 	f.VarP(newInt64SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Int64SliceVar defines a int64[] flag with specified name, default value, and usage string. | ||||
| // The argument p points to a int64[] variable in which to store the value of the flag. | ||||
| func Int64SliceVar(p *[]int64, name string, value []int64, usage string) { | ||||
| 	CommandLine.VarP(newInt64SliceValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // Int64SliceVarP is like Int64SliceVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Int64SliceVarP(p *[]int64, name, shorthand string, value []int64, usage string) { | ||||
| 	CommandLine.VarP(newInt64SliceValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // Int64Slice defines a []int64 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []int64 variable that stores the value of the flag. | ||||
| func (f *FlagSet) Int64Slice(name string, value []int64, usage string) *[]int64 { | ||||
| 	p := []int64{} | ||||
| 	f.Int64SliceVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Int64SliceP is like Int64Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) Int64SliceP(name, shorthand string, value []int64, usage string) *[]int64 { | ||||
| 	p := []int64{} | ||||
| 	f.Int64SliceVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // Int64Slice defines a []int64 flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a []int64 variable that stores the value of the flag. | ||||
| func Int64Slice(name string, value []int64, usage string) *[]int64 { | ||||
| 	return CommandLine.Int64SliceP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // Int64SliceP is like Int64Slice, but accepts a shorthand letter that can be used after a single dash. | ||||
| func Int64SliceP(name, shorthand string, value []int64, usage string) *[]int64 { | ||||
| 	return CommandLine.Int64SliceP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										30
									
								
								vendor/github.com/spf13/pflag/int_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										30
									
								
								vendor/github.com/spf13/pflag/int_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -51,6 +51,36 @@ func (s *intSliceValue) String() string { | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *intSliceValue) Append(val string) error { | ||||
| 	i, err := strconv.Atoi(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *intSliceValue) Replace(val []string) error { | ||||
| 	out := make([]int, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = strconv.Atoi(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *intSliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = strconv.Itoa(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func intSliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
|  | ||||
							
								
								
									
										40
									
								
								vendor/github.com/spf13/pflag/ip_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								vendor/github.com/spf13/pflag/ip_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -72,9 +72,47 @@ func (s *ipSliceValue) String() string { | ||||
| 	return "[" + out + "]" | ||||
| } | ||||
|  | ||||
| func (s *ipSliceValue) fromString(val string) (net.IP, error) { | ||||
| 	return net.ParseIP(strings.TrimSpace(val)), nil | ||||
| } | ||||
|  | ||||
| func (s *ipSliceValue) toString(val net.IP) string { | ||||
| 	return val.String() | ||||
| } | ||||
|  | ||||
| func (s *ipSliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *ipSliceValue) Replace(val []string) error { | ||||
| 	out := make([]net.IP, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *ipSliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func ipSliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Emtpy string would cause a slice with one (empty) entry | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
| 	if len(val) == 0 { | ||||
| 		return []net.IP{}, nil | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										26
									
								
								vendor/github.com/spf13/pflag/string_array.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								vendor/github.com/spf13/pflag/string_array.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -23,6 +23,32 @@ func (s *stringArrayValue) Set(val string) error { | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringArrayValue) Append(val string) error { | ||||
| 	*s.value = append(*s.value, val) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringArrayValue) Replace(val []string) error { | ||||
| 	out := make([]string, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i] = d | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringArrayValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = d | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func (s *stringArrayValue) Type() string { | ||||
| 	return "stringArray" | ||||
| } | ||||
|  | ||||
							
								
								
									
										22
									
								
								vendor/github.com/spf13/pflag/string_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								vendor/github.com/spf13/pflag/string_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -62,6 +62,20 @@ func (s *stringSliceValue) String() string { | ||||
| 	return "[" + str + "]" | ||||
| } | ||||
|  | ||||
| func (s *stringSliceValue) Append(val string) error { | ||||
| 	*s.value = append(*s.value, val) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringSliceValue) Replace(val []string) error { | ||||
| 	*s.value = val | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringSliceValue) GetSlice() []string { | ||||
| 	return *s.value | ||||
| } | ||||
|  | ||||
| func stringSliceConv(sval string) (interface{}, error) { | ||||
| 	sval = sval[1 : len(sval)-1] | ||||
| 	// An empty string would cause a slice with one (empty) string | ||||
| @ -84,7 +98,7 @@ func (f *FlagSet) GetStringSlice(name string) ([]string, error) { | ||||
| // The argument p points to a []string variable in which to store the value of the flag. | ||||
| // Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. | ||||
| // For example: | ||||
| //   --ss="v1,v2" -ss="v3" | ||||
| //   --ss="v1,v2" --ss="v3" | ||||
| // will result in | ||||
| //   []string{"v1", "v2", "v3"} | ||||
| func (f *FlagSet) StringSliceVar(p *[]string, name string, value []string, usage string) { | ||||
| @ -100,7 +114,7 @@ func (f *FlagSet) StringSliceVarP(p *[]string, name, shorthand string, value []s | ||||
| // The argument p points to a []string variable in which to store the value of the flag. | ||||
| // Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. | ||||
| // For example: | ||||
| //   --ss="v1,v2" -ss="v3" | ||||
| //   --ss="v1,v2" --ss="v3" | ||||
| // will result in | ||||
| //   []string{"v1", "v2", "v3"} | ||||
| func StringSliceVar(p *[]string, name string, value []string, usage string) { | ||||
| @ -116,7 +130,7 @@ func StringSliceVarP(p *[]string, name, shorthand string, value []string, usage | ||||
| // The return value is the address of a []string variable that stores the value of the flag. | ||||
| // Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. | ||||
| // For example: | ||||
| //   --ss="v1,v2" -ss="v3" | ||||
| //   --ss="v1,v2" --ss="v3" | ||||
| // will result in | ||||
| //   []string{"v1", "v2", "v3"} | ||||
| func (f *FlagSet) StringSlice(name string, value []string, usage string) *[]string { | ||||
| @ -136,7 +150,7 @@ func (f *FlagSet) StringSliceP(name, shorthand string, value []string, usage str | ||||
| // The return value is the address of a []string variable that stores the value of the flag. | ||||
| // Compared to StringArray flags, StringSlice flags take comma-separated value as arguments and split them accordingly. | ||||
| // For example: | ||||
| //   --ss="v1,v2" -ss="v3" | ||||
| //   --ss="v1,v2" --ss="v3" | ||||
| // will result in | ||||
| //   []string{"v1", "v2", "v3"} | ||||
| func StringSlice(name string, value []string, usage string) *[]string { | ||||
|  | ||||
							
								
								
									
										149
									
								
								vendor/github.com/spf13/pflag/string_to_int.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								vendor/github.com/spf13/pflag/string_to_int.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,149 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- stringToInt Value | ||||
| type stringToIntValue struct { | ||||
| 	value   *map[string]int | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newStringToIntValue(val map[string]int, p *map[string]int) *stringToIntValue { | ||||
| 	ssv := new(stringToIntValue) | ||||
| 	ssv.value = p | ||||
| 	*ssv.value = val | ||||
| 	return ssv | ||||
| } | ||||
|  | ||||
| // Format: a=1,b=2 | ||||
| func (s *stringToIntValue) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make(map[string]int, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		var err error | ||||
| 		out[kv[0]], err = strconv.Atoi(kv[1]) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		for k, v := range out { | ||||
| 			(*s.value)[k] = v | ||||
| 		} | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringToIntValue) Type() string { | ||||
| 	return "stringToInt" | ||||
| } | ||||
|  | ||||
| func (s *stringToIntValue) String() string { | ||||
| 	var buf bytes.Buffer | ||||
| 	i := 0 | ||||
| 	for k, v := range *s.value { | ||||
| 		if i > 0 { | ||||
| 			buf.WriteRune(',') | ||||
| 		} | ||||
| 		buf.WriteString(k) | ||||
| 		buf.WriteRune('=') | ||||
| 		buf.WriteString(strconv.Itoa(v)) | ||||
| 		i++ | ||||
| 	} | ||||
| 	return "[" + buf.String() + "]" | ||||
| } | ||||
|  | ||||
| func stringToIntConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// An empty string would cause an empty map | ||||
| 	if len(val) == 0 { | ||||
| 		return map[string]int{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make(map[string]int, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return nil, fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		var err error | ||||
| 		out[kv[0]], err = strconv.Atoi(kv[1]) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetStringToInt return the map[string]int value of a flag with the given name | ||||
| func (f *FlagSet) GetStringToInt(name string) (map[string]int, error) { | ||||
| 	val, err := f.getFlagType(name, "stringToInt", stringToIntConv) | ||||
| 	if err != nil { | ||||
| 		return map[string]int{}, err | ||||
| 	} | ||||
| 	return val.(map[string]int), nil | ||||
| } | ||||
|  | ||||
| // StringToIntVar defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p points to a map[string]int variable in which to store the values of the multiple flags. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToIntVar(p *map[string]int, name string, value map[string]int, usage string) { | ||||
| 	f.VarP(newStringToIntValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToIntVarP is like StringToIntVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToIntVarP(p *map[string]int, name, shorthand string, value map[string]int, usage string) { | ||||
| 	f.VarP(newStringToIntValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToIntVar defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p points to a map[string]int variable in which to store the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToIntVar(p *map[string]int, name string, value map[string]int, usage string) { | ||||
| 	CommandLine.VarP(newStringToIntValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToIntVarP is like StringToIntVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToIntVarP(p *map[string]int, name, shorthand string, value map[string]int, usage string) { | ||||
| 	CommandLine.VarP(newStringToIntValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToInt defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]int variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToInt(name string, value map[string]int, usage string) *map[string]int { | ||||
| 	p := map[string]int{} | ||||
| 	f.StringToIntVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToIntP is like StringToInt, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToIntP(name, shorthand string, value map[string]int, usage string) *map[string]int { | ||||
| 	p := map[string]int{} | ||||
| 	f.StringToIntVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToInt defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]int variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToInt(name string, value map[string]int, usage string) *map[string]int { | ||||
| 	return CommandLine.StringToIntP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // StringToIntP is like StringToInt, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToIntP(name, shorthand string, value map[string]int, usage string) *map[string]int { | ||||
| 	return CommandLine.StringToIntP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										149
									
								
								vendor/github.com/spf13/pflag/string_to_int64.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								vendor/github.com/spf13/pflag/string_to_int64.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,149 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- stringToInt64 Value | ||||
| type stringToInt64Value struct { | ||||
| 	value   *map[string]int64 | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newStringToInt64Value(val map[string]int64, p *map[string]int64) *stringToInt64Value { | ||||
| 	ssv := new(stringToInt64Value) | ||||
| 	ssv.value = p | ||||
| 	*ssv.value = val | ||||
| 	return ssv | ||||
| } | ||||
|  | ||||
| // Format: a=1,b=2 | ||||
| func (s *stringToInt64Value) Set(val string) error { | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make(map[string]int64, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		var err error | ||||
| 		out[kv[0]], err = strconv.ParseInt(kv[1], 10, 64) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		for k, v := range out { | ||||
| 			(*s.value)[k] = v | ||||
| 		} | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringToInt64Value) Type() string { | ||||
| 	return "stringToInt64" | ||||
| } | ||||
|  | ||||
| func (s *stringToInt64Value) String() string { | ||||
| 	var buf bytes.Buffer | ||||
| 	i := 0 | ||||
| 	for k, v := range *s.value { | ||||
| 		if i > 0 { | ||||
| 			buf.WriteRune(',') | ||||
| 		} | ||||
| 		buf.WriteString(k) | ||||
| 		buf.WriteRune('=') | ||||
| 		buf.WriteString(strconv.FormatInt(v, 10)) | ||||
| 		i++ | ||||
| 	} | ||||
| 	return "[" + buf.String() + "]" | ||||
| } | ||||
|  | ||||
| func stringToInt64Conv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// An empty string would cause an empty map | ||||
| 	if len(val) == 0 { | ||||
| 		return map[string]int64{}, nil | ||||
| 	} | ||||
| 	ss := strings.Split(val, ",") | ||||
| 	out := make(map[string]int64, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return nil, fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		var err error | ||||
| 		out[kv[0]], err = strconv.ParseInt(kv[1], 10, 64) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetStringToInt64 return the map[string]int64 value of a flag with the given name | ||||
| func (f *FlagSet) GetStringToInt64(name string) (map[string]int64, error) { | ||||
| 	val, err := f.getFlagType(name, "stringToInt64", stringToInt64Conv) | ||||
| 	if err != nil { | ||||
| 		return map[string]int64{}, err | ||||
| 	} | ||||
| 	return val.(map[string]int64), nil | ||||
| } | ||||
|  | ||||
| // StringToInt64Var defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p point64s to a map[string]int64 variable in which to store the values of the multiple flags. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToInt64Var(p *map[string]int64, name string, value map[string]int64, usage string) { | ||||
| 	f.VarP(newStringToInt64Value(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToInt64VarP is like StringToInt64Var, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToInt64VarP(p *map[string]int64, name, shorthand string, value map[string]int64, usage string) { | ||||
| 	f.VarP(newStringToInt64Value(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToInt64Var defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p point64s to a map[string]int64 variable in which to store the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToInt64Var(p *map[string]int64, name string, value map[string]int64, usage string) { | ||||
| 	CommandLine.VarP(newStringToInt64Value(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToInt64VarP is like StringToInt64Var, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToInt64VarP(p *map[string]int64, name, shorthand string, value map[string]int64, usage string) { | ||||
| 	CommandLine.VarP(newStringToInt64Value(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToInt64 defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]int64 variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToInt64(name string, value map[string]int64, usage string) *map[string]int64 { | ||||
| 	p := map[string]int64{} | ||||
| 	f.StringToInt64VarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToInt64P is like StringToInt64, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToInt64P(name, shorthand string, value map[string]int64, usage string) *map[string]int64 { | ||||
| 	p := map[string]int64{} | ||||
| 	f.StringToInt64VarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToInt64 defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]int64 variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToInt64(name string, value map[string]int64, usage string) *map[string]int64 { | ||||
| 	return CommandLine.StringToInt64P(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // StringToInt64P is like StringToInt64, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToInt64P(name, shorthand string, value map[string]int64, usage string) *map[string]int64 { | ||||
| 	return CommandLine.StringToInt64P(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										160
									
								
								vendor/github.com/spf13/pflag/string_to_string.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								vendor/github.com/spf13/pflag/string_to_string.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,160 @@ | ||||
| package pflag | ||||
|  | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"encoding/csv" | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| // -- stringToString Value | ||||
| type stringToStringValue struct { | ||||
| 	value   *map[string]string | ||||
| 	changed bool | ||||
| } | ||||
|  | ||||
| func newStringToStringValue(val map[string]string, p *map[string]string) *stringToStringValue { | ||||
| 	ssv := new(stringToStringValue) | ||||
| 	ssv.value = p | ||||
| 	*ssv.value = val | ||||
| 	return ssv | ||||
| } | ||||
|  | ||||
| // Format: a=1,b=2 | ||||
| func (s *stringToStringValue) Set(val string) error { | ||||
| 	var ss []string | ||||
| 	n := strings.Count(val, "=") | ||||
| 	switch n { | ||||
| 	case 0: | ||||
| 		return fmt.Errorf("%s must be formatted as key=value", val) | ||||
| 	case 1: | ||||
| 		ss = append(ss, strings.Trim(val, `"`)) | ||||
| 	default: | ||||
| 		r := csv.NewReader(strings.NewReader(val)) | ||||
| 		var err error | ||||
| 		ss, err = r.Read() | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	out := make(map[string]string, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		out[kv[0]] = kv[1] | ||||
| 	} | ||||
| 	if !s.changed { | ||||
| 		*s.value = out | ||||
| 	} else { | ||||
| 		for k, v := range out { | ||||
| 			(*s.value)[k] = v | ||||
| 		} | ||||
| 	} | ||||
| 	s.changed = true | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *stringToStringValue) Type() string { | ||||
| 	return "stringToString" | ||||
| } | ||||
|  | ||||
| func (s *stringToStringValue) String() string { | ||||
| 	records := make([]string, 0, len(*s.value)>>1) | ||||
| 	for k, v := range *s.value { | ||||
| 		records = append(records, k+"="+v) | ||||
| 	} | ||||
|  | ||||
| 	var buf bytes.Buffer | ||||
| 	w := csv.NewWriter(&buf) | ||||
| 	if err := w.Write(records); err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 	w.Flush() | ||||
| 	return "[" + strings.TrimSpace(buf.String()) + "]" | ||||
| } | ||||
|  | ||||
| func stringToStringConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// An empty string would cause an empty map | ||||
| 	if len(val) == 0 { | ||||
| 		return map[string]string{}, nil | ||||
| 	} | ||||
| 	r := csv.NewReader(strings.NewReader(val)) | ||||
| 	ss, err := r.Read() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	out := make(map[string]string, len(ss)) | ||||
| 	for _, pair := range ss { | ||||
| 		kv := strings.SplitN(pair, "=", 2) | ||||
| 		if len(kv) != 2 { | ||||
| 			return nil, fmt.Errorf("%s must be formatted as key=value", pair) | ||||
| 		} | ||||
| 		out[kv[0]] = kv[1] | ||||
| 	} | ||||
| 	return out, nil | ||||
| } | ||||
|  | ||||
| // GetStringToString return the map[string]string value of a flag with the given name | ||||
| func (f *FlagSet) GetStringToString(name string) (map[string]string, error) { | ||||
| 	val, err := f.getFlagType(name, "stringToString", stringToStringConv) | ||||
| 	if err != nil { | ||||
| 		return map[string]string{}, err | ||||
| 	} | ||||
| 	return val.(map[string]string), nil | ||||
| } | ||||
|  | ||||
| // StringToStringVar defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p points to a map[string]string variable in which to store the values of the multiple flags. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToStringVar(p *map[string]string, name string, value map[string]string, usage string) { | ||||
| 	f.VarP(newStringToStringValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToStringVarP is like StringToStringVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToStringVarP(p *map[string]string, name, shorthand string, value map[string]string, usage string) { | ||||
| 	f.VarP(newStringToStringValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToStringVar defines a string flag with specified name, default value, and usage string. | ||||
| // The argument p points to a map[string]string variable in which to store the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToStringVar(p *map[string]string, name string, value map[string]string, usage string) { | ||||
| 	CommandLine.VarP(newStringToStringValue(value, p), name, "", usage) | ||||
| } | ||||
|  | ||||
| // StringToStringVarP is like StringToStringVar, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToStringVarP(p *map[string]string, name, shorthand string, value map[string]string, usage string) { | ||||
| 	CommandLine.VarP(newStringToStringValue(value, p), name, shorthand, usage) | ||||
| } | ||||
|  | ||||
| // StringToString defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]string variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func (f *FlagSet) StringToString(name string, value map[string]string, usage string) *map[string]string { | ||||
| 	p := map[string]string{} | ||||
| 	f.StringToStringVarP(&p, name, "", value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToStringP is like StringToString, but accepts a shorthand letter that can be used after a single dash. | ||||
| func (f *FlagSet) StringToStringP(name, shorthand string, value map[string]string, usage string) *map[string]string { | ||||
| 	p := map[string]string{} | ||||
| 	f.StringToStringVarP(&p, name, shorthand, value, usage) | ||||
| 	return &p | ||||
| } | ||||
|  | ||||
| // StringToString defines a string flag with specified name, default value, and usage string. | ||||
| // The return value is the address of a map[string]string variable that stores the value of the flag. | ||||
| // The value of each argument will not try to be separated by comma | ||||
| func StringToString(name string, value map[string]string, usage string) *map[string]string { | ||||
| 	return CommandLine.StringToStringP(name, "", value, usage) | ||||
| } | ||||
|  | ||||
| // StringToStringP is like StringToString, but accepts a shorthand letter that can be used after a single dash. | ||||
| func StringToStringP(name, shorthand string, value map[string]string, usage string) *map[string]string { | ||||
| 	return CommandLine.StringToStringP(name, shorthand, value, usage) | ||||
| } | ||||
							
								
								
									
										42
									
								
								vendor/github.com/spf13/pflag/uint_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								vendor/github.com/spf13/pflag/uint_slice.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -50,6 +50,48 @@ func (s *uintSliceValue) String() string { | ||||
| 	return "[" + strings.Join(out, ",") + "]" | ||||
| } | ||||
|  | ||||
| func (s *uintSliceValue) fromString(val string) (uint, error) { | ||||
| 	t, err := strconv.ParseUint(val, 10, 0) | ||||
| 	if err != nil { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	return uint(t), nil | ||||
| } | ||||
|  | ||||
| func (s *uintSliceValue) toString(val uint) string { | ||||
| 	return fmt.Sprintf("%d", val) | ||||
| } | ||||
|  | ||||
| func (s *uintSliceValue) Append(val string) error { | ||||
| 	i, err := s.fromString(val) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*s.value = append(*s.value, i) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *uintSliceValue) Replace(val []string) error { | ||||
| 	out := make([]uint, len(val)) | ||||
| 	for i, d := range val { | ||||
| 		var err error | ||||
| 		out[i], err = s.fromString(d) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	*s.value = out | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (s *uintSliceValue) GetSlice() []string { | ||||
| 	out := make([]string, len(*s.value)) | ||||
| 	for i, d := range *s.value { | ||||
| 		out[i] = s.toString(d) | ||||
| 	} | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| func uintSliceConv(val string) (interface{}, error) { | ||||
| 	val = strings.Trim(val, "[]") | ||||
| 	// Empty string would cause a slice with one (empty) entry | ||||
|  | ||||
							
								
								
									
										985
									
								
								vendor/golang.org/x/crypto/ssh/terminal/terminal.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										985
									
								
								vendor/golang.org/x/crypto/ssh/terminal/terminal.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										12
									
								
								vendor/golang.org/x/net/http2/server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								vendor/golang.org/x/net/http2/server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1694,6 +1694,7 @@ func (sc *serverConn) processData(f *DataFrame) error { | ||||
| 		if len(data) > 0 { | ||||
| 			wrote, err := st.body.Write(data) | ||||
| 			if err != nil { | ||||
| 				sc.sendWindowUpdate(nil, int(f.Length)-wrote) | ||||
| 				return streamError(id, ErrCodeStreamClosed) | ||||
| 			} | ||||
| 			if wrote != len(data) { | ||||
| @ -2020,7 +2021,11 @@ func (sc *serverConn) newWriterAndRequest(st *stream, f *MetaHeadersFrame) (*res | ||||
| 	} | ||||
| 	if bodyOpen { | ||||
| 		if vv, ok := rp.header["Content-Length"]; ok { | ||||
| 			req.ContentLength, _ = strconv.ParseInt(vv[0], 10, 64) | ||||
| 			if cl, err := strconv.ParseUint(vv[0], 10, 63); err == nil { | ||||
| 				req.ContentLength = int64(cl) | ||||
| 			} else { | ||||
| 				req.ContentLength = 0 | ||||
| 			} | ||||
| 		} else { | ||||
| 			req.ContentLength = -1 | ||||
| 		} | ||||
| @ -2403,9 +2408,8 @@ func (rws *responseWriterState) writeChunk(p []byte) (n int, err error) { | ||||
| 		var ctype, clen string | ||||
| 		if clen = rws.snapHeader.Get("Content-Length"); clen != "" { | ||||
| 			rws.snapHeader.Del("Content-Length") | ||||
| 			clen64, err := strconv.ParseInt(clen, 10, 64) | ||||
| 			if err == nil && clen64 >= 0 { | ||||
| 				rws.sentContentLen = clen64 | ||||
| 			if cl, err := strconv.ParseUint(clen, 10, 63); err == nil { | ||||
| 				rws.sentContentLen = int64(cl) | ||||
| 			} else { | ||||
| 				clen = "" | ||||
| 			} | ||||
|  | ||||
							
								
								
									
										40
									
								
								vendor/golang.org/x/net/http2/transport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								vendor/golang.org/x/net/http2/transport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -154,12 +154,21 @@ func (t *Transport) pingTimeout() time.Duration { | ||||
|  | ||||
| // ConfigureTransport configures a net/http HTTP/1 Transport to use HTTP/2. | ||||
| // It returns an error if t1 has already been HTTP/2-enabled. | ||||
| // | ||||
| // Use ConfigureTransports instead to configure the HTTP/2 Transport. | ||||
| func ConfigureTransport(t1 *http.Transport) error { | ||||
| 	_, err := configureTransport(t1) | ||||
| 	_, err := ConfigureTransports(t1) | ||||
| 	return err | ||||
| } | ||||
|  | ||||
| func configureTransport(t1 *http.Transport) (*Transport, error) { | ||||
| // ConfigureTransports configures a net/http HTTP/1 Transport to use HTTP/2. | ||||
| // It returns a new HTTP/2 Transport for further configuration. | ||||
| // It returns an error if t1 has already been HTTP/2-enabled. | ||||
| func ConfigureTransports(t1 *http.Transport) (*Transport, error) { | ||||
| 	return configureTransports(t1) | ||||
| } | ||||
|  | ||||
| func configureTransports(t1 *http.Transport) (*Transport, error) { | ||||
| 	connPool := new(clientConnPool) | ||||
| 	t2 := &Transport{ | ||||
| 		ConnPool: noDialClientConnPool{connPool}, | ||||
| @ -689,6 +698,7 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro | ||||
| 	cc.inflow.add(transportDefaultConnFlow + initialWindowSize) | ||||
| 	cc.bw.Flush() | ||||
| 	if cc.werr != nil { | ||||
| 		cc.Close() | ||||
| 		return nil, cc.werr | ||||
| 	} | ||||
|  | ||||
| @ -1080,6 +1090,15 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 	bodyWriter := cc.t.getBodyWriterState(cs, body) | ||||
| 	cs.on100 = bodyWriter.on100 | ||||
|  | ||||
| 	defer func() { | ||||
| 		cc.wmu.Lock() | ||||
| 		werr := cc.werr | ||||
| 		cc.wmu.Unlock() | ||||
| 		if werr != nil { | ||||
| 			cc.Close() | ||||
| 		} | ||||
| 	}() | ||||
|  | ||||
| 	cc.wmu.Lock() | ||||
| 	endStream := !hasBody && !hasTrailers | ||||
| 	werr := cc.writeHeaders(cs.ID, endStream, int(cc.maxFrameSize), hdrs) | ||||
| @ -1129,6 +1148,9 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 			// we can keep it. | ||||
| 			bodyWriter.cancel() | ||||
| 			cs.abortRequestBodyWrite(errStopReqBodyWrite) | ||||
| 			if hasBody && !bodyWritten { | ||||
| 				<-bodyWriter.resc | ||||
| 			} | ||||
| 		} | ||||
| 		if re.err != nil { | ||||
| 			cc.forgetStreamID(cs.ID) | ||||
| @ -1149,6 +1171,7 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 			} else { | ||||
| 				bodyWriter.cancel() | ||||
| 				cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) | ||||
| 				<-bodyWriter.resc | ||||
| 			} | ||||
| 			cc.forgetStreamID(cs.ID) | ||||
| 			return nil, cs.getStartedWrite(), errTimeout | ||||
| @ -1158,6 +1181,7 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 			} else { | ||||
| 				bodyWriter.cancel() | ||||
| 				cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) | ||||
| 				<-bodyWriter.resc | ||||
| 			} | ||||
| 			cc.forgetStreamID(cs.ID) | ||||
| 			return nil, cs.getStartedWrite(), ctx.Err() | ||||
| @ -1167,6 +1191,7 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 			} else { | ||||
| 				bodyWriter.cancel() | ||||
| 				cs.abortRequestBodyWrite(errStopReqBodyWriteAndCancel) | ||||
| 				<-bodyWriter.resc | ||||
| 			} | ||||
| 			cc.forgetStreamID(cs.ID) | ||||
| 			return nil, cs.getStartedWrite(), errRequestCanceled | ||||
| @ -1176,6 +1201,7 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 			// forgetStreamID. | ||||
| 			return nil, cs.getStartedWrite(), cs.resetErr | ||||
| 		case err := <-bodyWriter.resc: | ||||
| 			bodyWritten = true | ||||
| 			// Prefer the read loop's response, if available. Issue 16102. | ||||
| 			select { | ||||
| 			case re := <-readLoopResCh: | ||||
| @ -1186,7 +1212,6 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | ||||
| 				cc.forgetStreamID(cs.ID) | ||||
| 				return nil, cs.getStartedWrite(), err | ||||
| 			} | ||||
| 			bodyWritten = true | ||||
| 			if d := cc.responseHeaderTimeout(); d != 0 { | ||||
| 				timer := time.NewTimer(d) | ||||
| 				defer timer.Stop() | ||||
| @ -2006,8 +2031,8 @@ func (rl *clientConnReadLoop) handleResponse(cs *clientStream, f *MetaHeadersFra | ||||
| 	if !streamEnded || isHead { | ||||
| 		res.ContentLength = -1 | ||||
| 		if clens := res.Header["Content-Length"]; len(clens) == 1 { | ||||
| 			if clen64, err := strconv.ParseInt(clens[0], 10, 64); err == nil { | ||||
| 				res.ContentLength = clen64 | ||||
| 			if cl, err := strconv.ParseUint(clens[0], 10, 63); err == nil { | ||||
| 				res.ContentLength = int64(cl) | ||||
| 			} else { | ||||
| 				// TODO: care? unlike http/1, it won't mess up our framing, so it's | ||||
| 				// more safe smuggling-wise to ignore. | ||||
| @ -2525,6 +2550,7 @@ func strSliceContains(ss []string, s string) bool { | ||||
|  | ||||
| type erringRoundTripper struct{ err error } | ||||
|  | ||||
| func (rt erringRoundTripper) RoundTripErr() error                             { return rt.err } | ||||
| func (rt erringRoundTripper) RoundTrip(*http.Request) (*http.Response, error) { return nil, rt.err } | ||||
|  | ||||
| // gzipReader wraps a response body so it can lazily | ||||
| @ -2606,7 +2632,9 @@ func (t *Transport) getBodyWriterState(cs *clientStream, body io.Reader) (s body | ||||
|  | ||||
| func (s bodyWriterState) cancel() { | ||||
| 	if s.timer != nil { | ||||
| 		s.timer.Stop() | ||||
| 		if s.timer.Stop() { | ||||
| 			s.resc <- nil | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										59
									
								
								vendor/golang.org/x/net/icmp/dstunreach.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								vendor/golang.org/x/net/icmp/dstunreach.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,59 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| // A DstUnreach represents an ICMP destination unreachable message | ||||
| // body. | ||||
| type DstUnreach struct { | ||||
| 	Data       []byte      // data, known as original datagram field | ||||
| 	Extensions []Extension // extensions | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *DstUnreach) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	l, _ := multipartMessageBodyDataLen(proto, true, p.Data, p.Extensions) | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *DstUnreach) Marshal(proto int) ([]byte, error) { | ||||
| 	var typ Type | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		typ = ipv4.ICMPTypeDestinationUnreachable | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		typ = ipv6.ICMPTypeDestinationUnreachable | ||||
| 	default: | ||||
| 		return nil, errInvalidProtocol | ||||
| 	} | ||||
| 	if !validExtensions(typ, p.Extensions) { | ||||
| 		return nil, errInvalidExtension | ||||
| 	} | ||||
| 	return marshalMultipartMessageBody(proto, true, p.Data, p.Extensions) | ||||
| } | ||||
|  | ||||
| // parseDstUnreach parses b as an ICMP destination unreachable message | ||||
| // body. | ||||
| func parseDstUnreach(proto int, typ Type, b []byte) (MessageBody, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	p := &DstUnreach{} | ||||
| 	var err error | ||||
| 	p.Data, p.Extensions, err = parseMultipartMessageBody(proto, typ, b) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return p, nil | ||||
| } | ||||
							
								
								
									
										173
									
								
								vendor/golang.org/x/net/icmp/echo.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								vendor/golang.org/x/net/icmp/echo.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,173 @@ | ||||
| // Copyright 2012 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
|  | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| // An Echo represents an ICMP echo request or reply message body. | ||||
| type Echo struct { | ||||
| 	ID   int    // identifier | ||||
| 	Seq  int    // sequence number | ||||
| 	Data []byte // data | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *Echo) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return 4 + len(p.Data) | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *Echo) Marshal(proto int) ([]byte, error) { | ||||
| 	b := make([]byte, 4+len(p.Data)) | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(p.ID)) | ||||
| 	binary.BigEndian.PutUint16(b[2:4], uint16(p.Seq)) | ||||
| 	copy(b[4:], p.Data) | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // parseEcho parses b as an ICMP echo request or reply message body. | ||||
| func parseEcho(proto int, _ Type, b []byte) (MessageBody, error) { | ||||
| 	bodyLen := len(b) | ||||
| 	if bodyLen < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	p := &Echo{ID: int(binary.BigEndian.Uint16(b[:2])), Seq: int(binary.BigEndian.Uint16(b[2:4]))} | ||||
| 	if bodyLen > 4 { | ||||
| 		p.Data = make([]byte, bodyLen-4) | ||||
| 		copy(p.Data, b[4:]) | ||||
| 	} | ||||
| 	return p, nil | ||||
| } | ||||
|  | ||||
| // An ExtendedEchoRequest represents an ICMP extended echo request | ||||
| // message body. | ||||
| type ExtendedEchoRequest struct { | ||||
| 	ID         int         // identifier | ||||
| 	Seq        int         // sequence number | ||||
| 	Local      bool        // must be true when identifying by name or index | ||||
| 	Extensions []Extension // extensions | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *ExtendedEchoRequest) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	l, _ := multipartMessageBodyDataLen(proto, false, nil, p.Extensions) | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *ExtendedEchoRequest) Marshal(proto int) ([]byte, error) { | ||||
| 	var typ Type | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		typ = ipv4.ICMPTypeExtendedEchoRequest | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		typ = ipv6.ICMPTypeExtendedEchoRequest | ||||
| 	default: | ||||
| 		return nil, errInvalidProtocol | ||||
| 	} | ||||
| 	if !validExtensions(typ, p.Extensions) { | ||||
| 		return nil, errInvalidExtension | ||||
| 	} | ||||
| 	b, err := marshalMultipartMessageBody(proto, false, nil, p.Extensions) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(p.ID)) | ||||
| 	b[2] = byte(p.Seq) | ||||
| 	if p.Local { | ||||
| 		b[3] |= 0x01 | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // parseExtendedEchoRequest parses b as an ICMP extended echo request | ||||
| // message body. | ||||
| func parseExtendedEchoRequest(proto int, typ Type, b []byte) (MessageBody, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	p := &ExtendedEchoRequest{ID: int(binary.BigEndian.Uint16(b[:2])), Seq: int(b[2])} | ||||
| 	if b[3]&0x01 != 0 { | ||||
| 		p.Local = true | ||||
| 	} | ||||
| 	var err error | ||||
| 	_, p.Extensions, err = parseMultipartMessageBody(proto, typ, b) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return p, nil | ||||
| } | ||||
|  | ||||
| // An ExtendedEchoReply represents an ICMP extended echo reply message | ||||
| // body. | ||||
| type ExtendedEchoReply struct { | ||||
| 	ID     int  // identifier | ||||
| 	Seq    int  // sequence number | ||||
| 	State  int  // 3-bit state working together with Message.Code | ||||
| 	Active bool // probed interface is active | ||||
| 	IPv4   bool // probed interface runs IPv4 | ||||
| 	IPv6   bool // probed interface runs IPv6 | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *ExtendedEchoReply) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return 4 | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *ExtendedEchoReply) Marshal(proto int) ([]byte, error) { | ||||
| 	b := make([]byte, 4) | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(p.ID)) | ||||
| 	b[2] = byte(p.Seq) | ||||
| 	b[3] = byte(p.State<<5) & 0xe0 | ||||
| 	if p.Active { | ||||
| 		b[3] |= 0x04 | ||||
| 	} | ||||
| 	if p.IPv4 { | ||||
| 		b[3] |= 0x02 | ||||
| 	} | ||||
| 	if p.IPv6 { | ||||
| 		b[3] |= 0x01 | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // parseExtendedEchoReply parses b as an ICMP extended echo reply | ||||
| // message body. | ||||
| func parseExtendedEchoReply(proto int, _ Type, b []byte) (MessageBody, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	p := &ExtendedEchoReply{ | ||||
| 		ID:    int(binary.BigEndian.Uint16(b[:2])), | ||||
| 		Seq:   int(b[2]), | ||||
| 		State: int(b[3]) >> 5, | ||||
| 	} | ||||
| 	if b[3]&0x04 != 0 { | ||||
| 		p.Active = true | ||||
| 	} | ||||
| 	if b[3]&0x02 != 0 { | ||||
| 		p.IPv4 = true | ||||
| 	} | ||||
| 	if b[3]&0x01 != 0 { | ||||
| 		p.IPv6 = true | ||||
| 	} | ||||
| 	return p, nil | ||||
| } | ||||
							
								
								
									
										113
									
								
								vendor/golang.org/x/net/icmp/endpoint.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								vendor/golang.org/x/net/icmp/endpoint.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,113 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"net" | ||||
| 	"runtime" | ||||
| 	"time" | ||||
|  | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| var _ net.PacketConn = &PacketConn{} | ||||
|  | ||||
| // A PacketConn represents a packet network endpoint that uses either | ||||
| // ICMPv4 or ICMPv6. | ||||
| type PacketConn struct { | ||||
| 	c  net.PacketConn | ||||
| 	p4 *ipv4.PacketConn | ||||
| 	p6 *ipv6.PacketConn | ||||
| } | ||||
|  | ||||
| func (c *PacketConn) ok() bool { return c != nil && c.c != nil } | ||||
|  | ||||
| // IPv4PacketConn returns the ipv4.PacketConn of c. | ||||
| // It returns nil when c is not created as the endpoint for ICMPv4. | ||||
| func (c *PacketConn) IPv4PacketConn() *ipv4.PacketConn { | ||||
| 	if !c.ok() { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return c.p4 | ||||
| } | ||||
|  | ||||
| // IPv6PacketConn returns the ipv6.PacketConn of c. | ||||
| // It returns nil when c is not created as the endpoint for ICMPv6. | ||||
| func (c *PacketConn) IPv6PacketConn() *ipv6.PacketConn { | ||||
| 	if !c.ok() { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return c.p6 | ||||
| } | ||||
|  | ||||
| // ReadFrom reads an ICMP message from the connection. | ||||
| func (c *PacketConn) ReadFrom(b []byte) (int, net.Addr, error) { | ||||
| 	if !c.ok() { | ||||
| 		return 0, nil, errInvalidConn | ||||
| 	} | ||||
| 	// Please be informed that ipv4.NewPacketConn enables | ||||
| 	// IP_STRIPHDR option by default on Darwin. | ||||
| 	// See golang.org/issue/9395 for further information. | ||||
| 	if (runtime.GOOS == "darwin" || runtime.GOOS == "ios") && c.p4 != nil { | ||||
| 		n, _, peer, err := c.p4.ReadFrom(b) | ||||
| 		return n, peer, err | ||||
| 	} | ||||
| 	return c.c.ReadFrom(b) | ||||
| } | ||||
|  | ||||
| // WriteTo writes the ICMP message b to dst. | ||||
| // The provided dst must be net.UDPAddr when c is a non-privileged | ||||
| // datagram-oriented ICMP endpoint. | ||||
| // Otherwise it must be net.IPAddr. | ||||
| func (c *PacketConn) WriteTo(b []byte, dst net.Addr) (int, error) { | ||||
| 	if !c.ok() { | ||||
| 		return 0, errInvalidConn | ||||
| 	} | ||||
| 	return c.c.WriteTo(b, dst) | ||||
| } | ||||
|  | ||||
| // Close closes the endpoint. | ||||
| func (c *PacketConn) Close() error { | ||||
| 	if !c.ok() { | ||||
| 		return errInvalidConn | ||||
| 	} | ||||
| 	return c.c.Close() | ||||
| } | ||||
|  | ||||
| // LocalAddr returns the local network address. | ||||
| func (c *PacketConn) LocalAddr() net.Addr { | ||||
| 	if !c.ok() { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return c.c.LocalAddr() | ||||
| } | ||||
|  | ||||
| // SetDeadline sets the read and write deadlines associated with the | ||||
| // endpoint. | ||||
| func (c *PacketConn) SetDeadline(t time.Time) error { | ||||
| 	if !c.ok() { | ||||
| 		return errInvalidConn | ||||
| 	} | ||||
| 	return c.c.SetDeadline(t) | ||||
| } | ||||
|  | ||||
| // SetReadDeadline sets the read deadline associated with the | ||||
| // endpoint. | ||||
| func (c *PacketConn) SetReadDeadline(t time.Time) error { | ||||
| 	if !c.ok() { | ||||
| 		return errInvalidConn | ||||
| 	} | ||||
| 	return c.c.SetReadDeadline(t) | ||||
| } | ||||
|  | ||||
| // SetWriteDeadline sets the write deadline associated with the | ||||
| // endpoint. | ||||
| func (c *PacketConn) SetWriteDeadline(t time.Time) error { | ||||
| 	if !c.ok() { | ||||
| 		return errInvalidConn | ||||
| 	} | ||||
| 	return c.c.SetWriteDeadline(t) | ||||
| } | ||||
							
								
								
									
										170
									
								
								vendor/golang.org/x/net/icmp/extension.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										170
									
								
								vendor/golang.org/x/net/icmp/extension.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,170 @@ | ||||
| // Copyright 2015 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
|  | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| // An Extension represents an ICMP extension. | ||||
| type Extension interface { | ||||
| 	// Len returns the length of ICMP extension. | ||||
| 	// The provided proto must be either the ICMPv4 or ICMPv6 | ||||
| 	// protocol number. | ||||
| 	Len(proto int) int | ||||
|  | ||||
| 	// Marshal returns the binary encoding of ICMP extension. | ||||
| 	// The provided proto must be either the ICMPv4 or ICMPv6 | ||||
| 	// protocol number. | ||||
| 	Marshal(proto int) ([]byte, error) | ||||
| } | ||||
|  | ||||
| const extensionVersion = 2 | ||||
|  | ||||
| func validExtensionHeader(b []byte) bool { | ||||
| 	v := int(b[0]&0xf0) >> 4 | ||||
| 	s := binary.BigEndian.Uint16(b[2:4]) | ||||
| 	if s != 0 { | ||||
| 		s = checksum(b) | ||||
| 	} | ||||
| 	if v != extensionVersion || s != 0 { | ||||
| 		return false | ||||
| 	} | ||||
| 	return true | ||||
| } | ||||
|  | ||||
| // parseExtensions parses b as a list of ICMP extensions. | ||||
| // The length attribute l must be the length attribute field in | ||||
| // received icmp messages. | ||||
| // | ||||
| // It will return a list of ICMP extensions and an adjusted length | ||||
| // attribute that represents the length of the padded original | ||||
| // datagram field. Otherwise, it returns an error. | ||||
| func parseExtensions(typ Type, b []byte, l int) ([]Extension, int, error) { | ||||
| 	// Still a lot of non-RFC 4884 compliant implementations are | ||||
| 	// out there. Set the length attribute l to 128 when it looks | ||||
| 	// inappropriate for backwards compatibility. | ||||
| 	// | ||||
| 	// A minimal extension at least requires 8 octets; 4 octets | ||||
| 	// for an extension header, and 4 octets for a single object | ||||
| 	// header. | ||||
| 	// | ||||
| 	// See RFC 4884 for further information. | ||||
| 	switch typ { | ||||
| 	case ipv4.ICMPTypeExtendedEchoRequest, ipv6.ICMPTypeExtendedEchoRequest: | ||||
| 		if len(b) < 8 || !validExtensionHeader(b) { | ||||
| 			return nil, -1, errNoExtension | ||||
| 		} | ||||
| 		l = 0 | ||||
| 	default: | ||||
| 		if 128 > l || l+8 > len(b) { | ||||
| 			l = 128 | ||||
| 		} | ||||
| 		if l+8 > len(b) { | ||||
| 			return nil, -1, errNoExtension | ||||
| 		} | ||||
| 		if !validExtensionHeader(b[l:]) { | ||||
| 			if l == 128 { | ||||
| 				return nil, -1, errNoExtension | ||||
| 			} | ||||
| 			l = 128 | ||||
| 			if !validExtensionHeader(b[l:]) { | ||||
| 				return nil, -1, errNoExtension | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	var exts []Extension | ||||
| 	for b = b[l+4:]; len(b) >= 4; { | ||||
| 		ol := int(binary.BigEndian.Uint16(b[:2])) | ||||
| 		if 4 > ol || ol > len(b) { | ||||
| 			break | ||||
| 		} | ||||
| 		switch b[2] { | ||||
| 		case classMPLSLabelStack: | ||||
| 			ext, err := parseMPLSLabelStack(b[:ol]) | ||||
| 			if err != nil { | ||||
| 				return nil, -1, err | ||||
| 			} | ||||
| 			exts = append(exts, ext) | ||||
| 		case classInterfaceInfo: | ||||
| 			ext, err := parseInterfaceInfo(b[:ol]) | ||||
| 			if err != nil { | ||||
| 				return nil, -1, err | ||||
| 			} | ||||
| 			exts = append(exts, ext) | ||||
| 		case classInterfaceIdent: | ||||
| 			ext, err := parseInterfaceIdent(b[:ol]) | ||||
| 			if err != nil { | ||||
| 				return nil, -1, err | ||||
| 			} | ||||
| 			exts = append(exts, ext) | ||||
| 		default: | ||||
| 			ext := &RawExtension{Data: make([]byte, ol)} | ||||
| 			copy(ext.Data, b[:ol]) | ||||
| 			exts = append(exts, ext) | ||||
| 		} | ||||
| 		b = b[ol:] | ||||
| 	} | ||||
| 	return exts, l, nil | ||||
| } | ||||
|  | ||||
| func validExtensions(typ Type, exts []Extension) bool { | ||||
| 	switch typ { | ||||
| 	case ipv4.ICMPTypeDestinationUnreachable, ipv4.ICMPTypeTimeExceeded, ipv4.ICMPTypeParameterProblem, | ||||
| 		ipv6.ICMPTypeDestinationUnreachable, ipv6.ICMPTypeTimeExceeded: | ||||
| 		for i := range exts { | ||||
| 			switch exts[i].(type) { | ||||
| 			case *MPLSLabelStack, *InterfaceInfo, *RawExtension: | ||||
| 			default: | ||||
| 				return false | ||||
| 			} | ||||
| 		} | ||||
| 		return true | ||||
| 	case ipv4.ICMPTypeExtendedEchoRequest, ipv6.ICMPTypeExtendedEchoRequest: | ||||
| 		var n int | ||||
| 		for i := range exts { | ||||
| 			switch exts[i].(type) { | ||||
| 			case *InterfaceIdent: | ||||
| 				n++ | ||||
| 			case *RawExtension: | ||||
| 			default: | ||||
| 				return false | ||||
| 			} | ||||
| 		} | ||||
| 		// Not a single InterfaceIdent object or a combo of | ||||
| 		// RawExtension and InterfaceIdent objects is not | ||||
| 		// allowed. | ||||
| 		if n == 1 && len(exts) > 1 { | ||||
| 			return false | ||||
| 		} | ||||
| 		return true | ||||
| 	default: | ||||
| 		return false | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // A RawExtension represents a raw extension. | ||||
| // | ||||
| // A raw extension is excluded from message processing and can be used | ||||
| // to construct applications such as protocol conformance testing. | ||||
| type RawExtension struct { | ||||
| 	Data []byte // data | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of Extension interface. | ||||
| func (p *RawExtension) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return len(p.Data) | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of Extension interface. | ||||
| func (p *RawExtension) Marshal(proto int) ([]byte, error) { | ||||
| 	return p.Data, nil | ||||
| } | ||||
							
								
								
									
										75
									
								
								vendor/golang.org/x/net/icmp/helper_posix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								vendor/golang.org/x/net/icmp/helper_posix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| // +build aix darwin dragonfly freebsd linux netbsd openbsd solaris windows | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"net" | ||||
| 	"strconv" | ||||
| 	"syscall" | ||||
| ) | ||||
|  | ||||
| func sockaddr(family int, address string) (syscall.Sockaddr, error) { | ||||
| 	switch family { | ||||
| 	case syscall.AF_INET: | ||||
| 		a, err := net.ResolveIPAddr("ip4", address) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		if len(a.IP) == 0 { | ||||
| 			a.IP = net.IPv4zero | ||||
| 		} | ||||
| 		if a.IP = a.IP.To4(); a.IP == nil { | ||||
| 			return nil, net.InvalidAddrError("non-ipv4 address") | ||||
| 		} | ||||
| 		sa := &syscall.SockaddrInet4{} | ||||
| 		copy(sa.Addr[:], a.IP) | ||||
| 		return sa, nil | ||||
| 	case syscall.AF_INET6: | ||||
| 		a, err := net.ResolveIPAddr("ip6", address) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		if len(a.IP) == 0 { | ||||
| 			a.IP = net.IPv6unspecified | ||||
| 		} | ||||
| 		if a.IP.Equal(net.IPv4zero) { | ||||
| 			a.IP = net.IPv6unspecified | ||||
| 		} | ||||
| 		if a.IP = a.IP.To16(); a.IP == nil || a.IP.To4() != nil { | ||||
| 			return nil, net.InvalidAddrError("non-ipv6 address") | ||||
| 		} | ||||
| 		sa := &syscall.SockaddrInet6{ZoneId: zoneToUint32(a.Zone)} | ||||
| 		copy(sa.Addr[:], a.IP) | ||||
| 		return sa, nil | ||||
| 	default: | ||||
| 		return nil, net.InvalidAddrError("unexpected family") | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func zoneToUint32(zone string) uint32 { | ||||
| 	if zone == "" { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	if ifi, err := net.InterfaceByName(zone); err == nil { | ||||
| 		return uint32(ifi.Index) | ||||
| 	} | ||||
| 	n, err := strconv.Atoi(zone) | ||||
| 	if err != nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return uint32(n) | ||||
| } | ||||
|  | ||||
| func last(s string, b byte) int { | ||||
| 	i := len(s) | ||||
| 	for i--; i >= 0; i-- { | ||||
| 		if s[i] == b { | ||||
| 			break | ||||
| 		} | ||||
| 	} | ||||
| 	return i | ||||
| } | ||||
							
								
								
									
										322
									
								
								vendor/golang.org/x/net/icmp/interface.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										322
									
								
								vendor/golang.org/x/net/icmp/interface.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,322 @@ | ||||
| // Copyright 2015 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
| 	"net" | ||||
| 	"strings" | ||||
|  | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	classInterfaceInfo = 2 | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	attrMTU = 1 << iota | ||||
| 	attrName | ||||
| 	attrIPAddr | ||||
| 	attrIfIndex | ||||
| ) | ||||
|  | ||||
| // An InterfaceInfo represents interface and next-hop identification. | ||||
| type InterfaceInfo struct { | ||||
| 	Class     int // extension object class number | ||||
| 	Type      int // extension object sub-type | ||||
| 	Interface *net.Interface | ||||
| 	Addr      *net.IPAddr | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) nameLen() int { | ||||
| 	if len(ifi.Interface.Name) > 63 { | ||||
| 		return 64 | ||||
| 	} | ||||
| 	l := 1 + len(ifi.Interface.Name) | ||||
| 	return (l + 3) &^ 3 | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) attrsAndLen(proto int) (attrs, l int) { | ||||
| 	l = 4 | ||||
| 	if ifi.Interface != nil && ifi.Interface.Index > 0 { | ||||
| 		attrs |= attrIfIndex | ||||
| 		l += 4 | ||||
| 		if len(ifi.Interface.Name) > 0 { | ||||
| 			attrs |= attrName | ||||
| 			l += ifi.nameLen() | ||||
| 		} | ||||
| 		if ifi.Interface.MTU > 0 { | ||||
| 			attrs |= attrMTU | ||||
| 			l += 4 | ||||
| 		} | ||||
| 	} | ||||
| 	if ifi.Addr != nil { | ||||
| 		switch proto { | ||||
| 		case iana.ProtocolICMP: | ||||
| 			if ifi.Addr.IP.To4() != nil { | ||||
| 				attrs |= attrIPAddr | ||||
| 				l += 4 + net.IPv4len | ||||
| 			} | ||||
| 		case iana.ProtocolIPv6ICMP: | ||||
| 			if ifi.Addr.IP.To16() != nil && ifi.Addr.IP.To4() == nil { | ||||
| 				attrs |= attrIPAddr | ||||
| 				l += 4 + net.IPv6len | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of Extension interface. | ||||
| func (ifi *InterfaceInfo) Len(proto int) int { | ||||
| 	_, l := ifi.attrsAndLen(proto) | ||||
| 	return l | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of Extension interface. | ||||
| func (ifi *InterfaceInfo) Marshal(proto int) ([]byte, error) { | ||||
| 	attrs, l := ifi.attrsAndLen(proto) | ||||
| 	b := make([]byte, l) | ||||
| 	if err := ifi.marshal(proto, b, attrs, l); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) marshal(proto int, b []byte, attrs, l int) error { | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(l)) | ||||
| 	b[2], b[3] = classInterfaceInfo, byte(ifi.Type) | ||||
| 	for b = b[4:]; len(b) > 0 && attrs != 0; { | ||||
| 		switch { | ||||
| 		case attrs&attrIfIndex != 0: | ||||
| 			b = ifi.marshalIfIndex(proto, b) | ||||
| 			attrs &^= attrIfIndex | ||||
| 		case attrs&attrIPAddr != 0: | ||||
| 			b = ifi.marshalIPAddr(proto, b) | ||||
| 			attrs &^= attrIPAddr | ||||
| 		case attrs&attrName != 0: | ||||
| 			b = ifi.marshalName(proto, b) | ||||
| 			attrs &^= attrName | ||||
| 		case attrs&attrMTU != 0: | ||||
| 			b = ifi.marshalMTU(proto, b) | ||||
| 			attrs &^= attrMTU | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) marshalIfIndex(proto int, b []byte) []byte { | ||||
| 	binary.BigEndian.PutUint32(b[:4], uint32(ifi.Interface.Index)) | ||||
| 	return b[4:] | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) parseIfIndex(b []byte) ([]byte, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	ifi.Interface.Index = int(binary.BigEndian.Uint32(b[:4])) | ||||
| 	return b[4:], nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) marshalIPAddr(proto int, b []byte) []byte { | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		binary.BigEndian.PutUint16(b[:2], uint16(iana.AddrFamilyIPv4)) | ||||
| 		copy(b[4:4+net.IPv4len], ifi.Addr.IP.To4()) | ||||
| 		b = b[4+net.IPv4len:] | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		binary.BigEndian.PutUint16(b[:2], uint16(iana.AddrFamilyIPv6)) | ||||
| 		copy(b[4:4+net.IPv6len], ifi.Addr.IP.To16()) | ||||
| 		b = b[4+net.IPv6len:] | ||||
| 	} | ||||
| 	return b | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) parseIPAddr(b []byte) ([]byte, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	afi := int(binary.BigEndian.Uint16(b[:2])) | ||||
| 	b = b[4:] | ||||
| 	switch afi { | ||||
| 	case iana.AddrFamilyIPv4: | ||||
| 		if len(b) < net.IPv4len { | ||||
| 			return nil, errMessageTooShort | ||||
| 		} | ||||
| 		ifi.Addr.IP = make(net.IP, net.IPv4len) | ||||
| 		copy(ifi.Addr.IP, b[:net.IPv4len]) | ||||
| 		b = b[net.IPv4len:] | ||||
| 	case iana.AddrFamilyIPv6: | ||||
| 		if len(b) < net.IPv6len { | ||||
| 			return nil, errMessageTooShort | ||||
| 		} | ||||
| 		ifi.Addr.IP = make(net.IP, net.IPv6len) | ||||
| 		copy(ifi.Addr.IP, b[:net.IPv6len]) | ||||
| 		b = b[net.IPv6len:] | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) marshalName(proto int, b []byte) []byte { | ||||
| 	l := byte(ifi.nameLen()) | ||||
| 	b[0] = l | ||||
| 	copy(b[1:], []byte(ifi.Interface.Name)) | ||||
| 	return b[l:] | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) parseName(b []byte) ([]byte, error) { | ||||
| 	if 4 > len(b) || len(b) < int(b[0]) { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	l := int(b[0]) | ||||
| 	if l%4 != 0 || 4 > l || l > 64 { | ||||
| 		return nil, errInvalidExtension | ||||
| 	} | ||||
| 	var name [63]byte | ||||
| 	copy(name[:], b[1:l]) | ||||
| 	ifi.Interface.Name = strings.Trim(string(name[:]), "\000") | ||||
| 	return b[l:], nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) marshalMTU(proto int, b []byte) []byte { | ||||
| 	binary.BigEndian.PutUint32(b[:4], uint32(ifi.Interface.MTU)) | ||||
| 	return b[4:] | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceInfo) parseMTU(b []byte) ([]byte, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	ifi.Interface.MTU = int(binary.BigEndian.Uint32(b[:4])) | ||||
| 	return b[4:], nil | ||||
| } | ||||
|  | ||||
| func parseInterfaceInfo(b []byte) (Extension, error) { | ||||
| 	ifi := &InterfaceInfo{ | ||||
| 		Class: int(b[2]), | ||||
| 		Type:  int(b[3]), | ||||
| 	} | ||||
| 	if ifi.Type&(attrIfIndex|attrName|attrMTU) != 0 { | ||||
| 		ifi.Interface = &net.Interface{} | ||||
| 	} | ||||
| 	if ifi.Type&attrIPAddr != 0 { | ||||
| 		ifi.Addr = &net.IPAddr{} | ||||
| 	} | ||||
| 	attrs := ifi.Type & (attrIfIndex | attrIPAddr | attrName | attrMTU) | ||||
| 	for b = b[4:]; len(b) > 0 && attrs != 0; { | ||||
| 		var err error | ||||
| 		switch { | ||||
| 		case attrs&attrIfIndex != 0: | ||||
| 			b, err = ifi.parseIfIndex(b) | ||||
| 			attrs &^= attrIfIndex | ||||
| 		case attrs&attrIPAddr != 0: | ||||
| 			b, err = ifi.parseIPAddr(b) | ||||
| 			attrs &^= attrIPAddr | ||||
| 		case attrs&attrName != 0: | ||||
| 			b, err = ifi.parseName(b) | ||||
| 			attrs &^= attrName | ||||
| 		case attrs&attrMTU != 0: | ||||
| 			b, err = ifi.parseMTU(b) | ||||
| 			attrs &^= attrMTU | ||||
| 		} | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	if ifi.Interface != nil && ifi.Interface.Name != "" && ifi.Addr != nil && ifi.Addr.IP.To16() != nil && ifi.Addr.IP.To4() == nil { | ||||
| 		ifi.Addr.Zone = ifi.Interface.Name | ||||
| 	} | ||||
| 	return ifi, nil | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	classInterfaceIdent    = 3 | ||||
| 	typeInterfaceByName    = 1 | ||||
| 	typeInterfaceByIndex   = 2 | ||||
| 	typeInterfaceByAddress = 3 | ||||
| ) | ||||
|  | ||||
| // An InterfaceIdent represents interface identification. | ||||
| type InterfaceIdent struct { | ||||
| 	Class int    // extension object class number | ||||
| 	Type  int    // extension object sub-type | ||||
| 	Name  string // interface name | ||||
| 	Index int    // interface index | ||||
| 	AFI   int    // address family identifier; see address family numbers in IANA registry | ||||
| 	Addr  []byte // address | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of Extension interface. | ||||
| func (ifi *InterfaceIdent) Len(_ int) int { | ||||
| 	switch ifi.Type { | ||||
| 	case typeInterfaceByName: | ||||
| 		l := len(ifi.Name) | ||||
| 		if l > 255 { | ||||
| 			l = 255 | ||||
| 		} | ||||
| 		return 4 + (l+3)&^3 | ||||
| 	case typeInterfaceByIndex: | ||||
| 		return 4 + 4 | ||||
| 	case typeInterfaceByAddress: | ||||
| 		return 4 + 4 + (len(ifi.Addr)+3)&^3 | ||||
| 	default: | ||||
| 		return 4 | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of Extension interface. | ||||
| func (ifi *InterfaceIdent) Marshal(proto int) ([]byte, error) { | ||||
| 	b := make([]byte, ifi.Len(proto)) | ||||
| 	if err := ifi.marshal(proto, b); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| func (ifi *InterfaceIdent) marshal(proto int, b []byte) error { | ||||
| 	l := ifi.Len(proto) | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(l)) | ||||
| 	b[2], b[3] = classInterfaceIdent, byte(ifi.Type) | ||||
| 	switch ifi.Type { | ||||
| 	case typeInterfaceByName: | ||||
| 		copy(b[4:], ifi.Name) | ||||
| 	case typeInterfaceByIndex: | ||||
| 		binary.BigEndian.PutUint32(b[4:4+4], uint32(ifi.Index)) | ||||
| 	case typeInterfaceByAddress: | ||||
| 		binary.BigEndian.PutUint16(b[4:4+2], uint16(ifi.AFI)) | ||||
| 		b[4+2] = byte(len(ifi.Addr)) | ||||
| 		copy(b[4+4:], ifi.Addr) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func parseInterfaceIdent(b []byte) (Extension, error) { | ||||
| 	ifi := &InterfaceIdent{ | ||||
| 		Class: int(b[2]), | ||||
| 		Type:  int(b[3]), | ||||
| 	} | ||||
| 	switch ifi.Type { | ||||
| 	case typeInterfaceByName: | ||||
| 		ifi.Name = strings.Trim(string(b[4:]), "\x00") | ||||
| 	case typeInterfaceByIndex: | ||||
| 		if len(b[4:]) < 4 { | ||||
| 			return nil, errInvalidExtension | ||||
| 		} | ||||
| 		ifi.Index = int(binary.BigEndian.Uint32(b[4 : 4+4])) | ||||
| 	case typeInterfaceByAddress: | ||||
| 		if len(b[4:]) < 4 { | ||||
| 			return nil, errInvalidExtension | ||||
| 		} | ||||
| 		ifi.AFI = int(binary.BigEndian.Uint16(b[4 : 4+2])) | ||||
| 		l := int(b[4+2]) | ||||
| 		if len(b[4+4:]) < l { | ||||
| 			return nil, errInvalidExtension | ||||
| 		} | ||||
| 		ifi.Addr = make([]byte, l) | ||||
| 		copy(ifi.Addr, b[4+4:]) | ||||
| 	} | ||||
| 	return ifi, nil | ||||
| } | ||||
							
								
								
									
										69
									
								
								vendor/golang.org/x/net/icmp/ipv4.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								vendor/golang.org/x/net/icmp/ipv4.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
| 	"net" | ||||
| 	"runtime" | ||||
|  | ||||
| 	"golang.org/x/net/internal/socket" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| ) | ||||
|  | ||||
| // freebsdVersion is set in sys_freebsd.go. | ||||
| // See http://www.freebsd.org/doc/en/books/porters-handbook/freebsd-versions.html. | ||||
| var freebsdVersion uint32 | ||||
|  | ||||
| // ParseIPv4Header returns the IPv4 header of the IPv4 packet that | ||||
| // triggered an ICMP error message. | ||||
| // This is found in the Data field of the ICMP error message body. | ||||
| // | ||||
| // The provided b must be in the format used by a raw ICMP socket on | ||||
| // the local system. | ||||
| // This may differ from the wire format, and the format used by a raw | ||||
| // IP socket, depending on the system. | ||||
| // | ||||
| // To parse an IPv6 header, use ipv6.ParseHeader. | ||||
| func ParseIPv4Header(b []byte) (*ipv4.Header, error) { | ||||
| 	if len(b) < ipv4.HeaderLen { | ||||
| 		return nil, errHeaderTooShort | ||||
| 	} | ||||
| 	hdrlen := int(b[0]&0x0f) << 2 | ||||
| 	if hdrlen > len(b) { | ||||
| 		return nil, errBufferTooShort | ||||
| 	} | ||||
| 	h := &ipv4.Header{ | ||||
| 		Version:  int(b[0] >> 4), | ||||
| 		Len:      hdrlen, | ||||
| 		TOS:      int(b[1]), | ||||
| 		ID:       int(binary.BigEndian.Uint16(b[4:6])), | ||||
| 		FragOff:  int(binary.BigEndian.Uint16(b[6:8])), | ||||
| 		TTL:      int(b[8]), | ||||
| 		Protocol: int(b[9]), | ||||
| 		Checksum: int(binary.BigEndian.Uint16(b[10:12])), | ||||
| 		Src:      net.IPv4(b[12], b[13], b[14], b[15]), | ||||
| 		Dst:      net.IPv4(b[16], b[17], b[18], b[19]), | ||||
| 	} | ||||
| 	switch runtime.GOOS { | ||||
| 	case "darwin", "ios": | ||||
| 		h.TotalLen = int(socket.NativeEndian.Uint16(b[2:4])) | ||||
| 	case "freebsd": | ||||
| 		if freebsdVersion >= 1000000 { | ||||
| 			h.TotalLen = int(binary.BigEndian.Uint16(b[2:4])) | ||||
| 		} else { | ||||
| 			h.TotalLen = int(socket.NativeEndian.Uint16(b[2:4])) | ||||
| 		} | ||||
| 	default: | ||||
| 		h.TotalLen = int(binary.BigEndian.Uint16(b[2:4])) | ||||
| 	} | ||||
| 	h.Flags = ipv4.HeaderFlags(h.FragOff&0xe000) >> 13 | ||||
| 	h.FragOff = h.FragOff & 0x1fff | ||||
| 	if hdrlen-ipv4.HeaderLen > 0 { | ||||
| 		h.Options = make([]byte, hdrlen-ipv4.HeaderLen) | ||||
| 		copy(h.Options, b[ipv4.HeaderLen:]) | ||||
| 	} | ||||
| 	return h, nil | ||||
| } | ||||
							
								
								
									
										23
									
								
								vendor/golang.org/x/net/icmp/ipv6.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/golang.org/x/net/icmp/ipv6.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| // Copyright 2013 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"net" | ||||
|  | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| ) | ||||
|  | ||||
| const ipv6PseudoHeaderLen = 2*net.IPv6len + 8 | ||||
|  | ||||
| // IPv6PseudoHeader returns an IPv6 pseudo header for checksum | ||||
| // calculation. | ||||
| func IPv6PseudoHeader(src, dst net.IP) []byte { | ||||
| 	b := make([]byte, ipv6PseudoHeaderLen) | ||||
| 	copy(b, src.To16()) | ||||
| 	copy(b[net.IPv6len:], dst.To16()) | ||||
| 	b[len(b)-1] = byte(iana.ProtocolIPv6ICMP) | ||||
| 	return b | ||||
| } | ||||
							
								
								
									
										103
									
								
								vendor/golang.org/x/net/icmp/listen_posix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								vendor/golang.org/x/net/icmp/listen_posix.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,103 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| // +build aix darwin dragonfly freebsd linux netbsd openbsd solaris windows | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import ( | ||||
| 	"net" | ||||
| 	"os" | ||||
| 	"runtime" | ||||
| 	"syscall" | ||||
|  | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| const sysIP_STRIPHDR = 0x17 // for now only darwin supports this option | ||||
|  | ||||
| // ListenPacket listens for incoming ICMP packets addressed to | ||||
| // address. See net.Dial for the syntax of address. | ||||
| // | ||||
| // For non-privileged datagram-oriented ICMP endpoints, network must | ||||
| // be "udp4" or "udp6". The endpoint allows to read, write a few | ||||
| // limited ICMP messages such as echo request and echo reply. | ||||
| // Currently only Darwin and Linux support this. | ||||
| // | ||||
| // Examples: | ||||
| //	ListenPacket("udp4", "192.168.0.1") | ||||
| //	ListenPacket("udp4", "0.0.0.0") | ||||
| //	ListenPacket("udp6", "fe80::1%en0") | ||||
| //	ListenPacket("udp6", "::") | ||||
| // | ||||
| // For privileged raw ICMP endpoints, network must be "ip4" or "ip6" | ||||
| // followed by a colon and an ICMP protocol number or name. | ||||
| // | ||||
| // Examples: | ||||
| //	ListenPacket("ip4:icmp", "192.168.0.1") | ||||
| //	ListenPacket("ip4:1", "0.0.0.0") | ||||
| //	ListenPacket("ip6:ipv6-icmp", "fe80::1%en0") | ||||
| //	ListenPacket("ip6:58", "::") | ||||
| func ListenPacket(network, address string) (*PacketConn, error) { | ||||
| 	var family, proto int | ||||
| 	switch network { | ||||
| 	case "udp4": | ||||
| 		family, proto = syscall.AF_INET, iana.ProtocolICMP | ||||
| 	case "udp6": | ||||
| 		family, proto = syscall.AF_INET6, iana.ProtocolIPv6ICMP | ||||
| 	default: | ||||
| 		i := last(network, ':') | ||||
| 		if i < 0 { | ||||
| 			i = len(network) | ||||
| 		} | ||||
| 		switch network[:i] { | ||||
| 		case "ip4": | ||||
| 			proto = iana.ProtocolICMP | ||||
| 		case "ip6": | ||||
| 			proto = iana.ProtocolIPv6ICMP | ||||
| 		} | ||||
| 	} | ||||
| 	var cerr error | ||||
| 	var c net.PacketConn | ||||
| 	switch family { | ||||
| 	case syscall.AF_INET, syscall.AF_INET6: | ||||
| 		s, err := syscall.Socket(family, syscall.SOCK_DGRAM, proto) | ||||
| 		if err != nil { | ||||
| 			return nil, os.NewSyscallError("socket", err) | ||||
| 		} | ||||
| 		if (runtime.GOOS == "darwin" || runtime.GOOS == "ios") && family == syscall.AF_INET { | ||||
| 			if err := syscall.SetsockoptInt(s, iana.ProtocolIP, sysIP_STRIPHDR, 1); err != nil { | ||||
| 				syscall.Close(s) | ||||
| 				return nil, os.NewSyscallError("setsockopt", err) | ||||
| 			} | ||||
| 		} | ||||
| 		sa, err := sockaddr(family, address) | ||||
| 		if err != nil { | ||||
| 			syscall.Close(s) | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		if err := syscall.Bind(s, sa); err != nil { | ||||
| 			syscall.Close(s) | ||||
| 			return nil, os.NewSyscallError("bind", err) | ||||
| 		} | ||||
| 		f := os.NewFile(uintptr(s), "datagram-oriented icmp") | ||||
| 		c, cerr = net.FilePacketConn(f) | ||||
| 		f.Close() | ||||
| 	default: | ||||
| 		c, cerr = net.ListenPacket(network, address) | ||||
| 	} | ||||
| 	if cerr != nil { | ||||
| 		return nil, cerr | ||||
| 	} | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		return &PacketConn{c: c, p4: ipv4.NewPacketConn(c)}, nil | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		return &PacketConn{c: c, p6: ipv6.NewPacketConn(c)}, nil | ||||
| 	default: | ||||
| 		return &PacketConn{c: c}, nil | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										33
									
								
								vendor/golang.org/x/net/icmp/listen_stub.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								vendor/golang.org/x/net/icmp/listen_stub.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| // +build !aix,!darwin,!dragonfly,!freebsd,!linux,!netbsd,!openbsd,!solaris,!windows | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| // ListenPacket listens for incoming ICMP packets addressed to | ||||
| // address. See net.Dial for the syntax of address. | ||||
| // | ||||
| // For non-privileged datagram-oriented ICMP endpoints, network must | ||||
| // be "udp4" or "udp6". The endpoint allows to read, write a few | ||||
| // limited ICMP messages such as echo request and echo reply. | ||||
| // Currently only Darwin and Linux support this. | ||||
| // | ||||
| // Examples: | ||||
| //	ListenPacket("udp4", "192.168.0.1") | ||||
| //	ListenPacket("udp4", "0.0.0.0") | ||||
| //	ListenPacket("udp6", "fe80::1%en0") | ||||
| //	ListenPacket("udp6", "::") | ||||
| // | ||||
| // For privileged raw ICMP endpoints, network must be "ip4" or "ip6" | ||||
| // followed by a colon and an ICMP protocol number or name. | ||||
| // | ||||
| // Examples: | ||||
| //	ListenPacket("ip4:icmp", "192.168.0.1") | ||||
| //	ListenPacket("ip4:1", "0.0.0.0") | ||||
| //	ListenPacket("ip6:ipv6-icmp", "fe80::1%en0") | ||||
| //	ListenPacket("ip6:58", "::") | ||||
| func ListenPacket(network, address string) (*PacketConn, error) { | ||||
| 	return nil, errNotImplemented | ||||
| } | ||||
							
								
								
									
										162
									
								
								vendor/golang.org/x/net/icmp/message.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										162
									
								
								vendor/golang.org/x/net/icmp/message.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,162 @@ | ||||
| // Copyright 2012 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| // Package icmp provides basic functions for the manipulation of | ||||
| // messages used in the Internet Control Message Protocols, | ||||
| // ICMPv4 and ICMPv6. | ||||
| // | ||||
| // ICMPv4 and ICMPv6 are defined in RFC 792 and RFC 4443. | ||||
| // Multi-part message support for ICMP is defined in RFC 4884. | ||||
| // ICMP extensions for MPLS are defined in RFC 4950. | ||||
| // ICMP extensions for interface and next-hop identification are | ||||
| // defined in RFC 5837. | ||||
| // PROBE: A utility for probing interfaces is defined in RFC 8335. | ||||
| package icmp // import "golang.org/x/net/icmp" | ||||
|  | ||||
| import ( | ||||
| 	"encoding/binary" | ||||
| 	"errors" | ||||
| 	"net" | ||||
| 	"runtime" | ||||
|  | ||||
| 	"golang.org/x/net/internal/iana" | ||||
| 	"golang.org/x/net/ipv4" | ||||
| 	"golang.org/x/net/ipv6" | ||||
| ) | ||||
|  | ||||
| // BUG(mikio): This package is not implemented on JS, NaCl and Plan 9. | ||||
|  | ||||
| var ( | ||||
| 	errInvalidConn      = errors.New("invalid connection") | ||||
| 	errInvalidProtocol  = errors.New("invalid protocol") | ||||
| 	errMessageTooShort  = errors.New("message too short") | ||||
| 	errHeaderTooShort   = errors.New("header too short") | ||||
| 	errBufferTooShort   = errors.New("buffer too short") | ||||
| 	errInvalidBody      = errors.New("invalid body") | ||||
| 	errNoExtension      = errors.New("no extension") | ||||
| 	errInvalidExtension = errors.New("invalid extension") | ||||
| 	errNotImplemented   = errors.New("not implemented on " + runtime.GOOS + "/" + runtime.GOARCH) | ||||
| ) | ||||
|  | ||||
| func checksum(b []byte) uint16 { | ||||
| 	csumcv := len(b) - 1 // checksum coverage | ||||
| 	s := uint32(0) | ||||
| 	for i := 0; i < csumcv; i += 2 { | ||||
| 		s += uint32(b[i+1])<<8 | uint32(b[i]) | ||||
| 	} | ||||
| 	if csumcv&1 == 0 { | ||||
| 		s += uint32(b[csumcv]) | ||||
| 	} | ||||
| 	s = s>>16 + s&0xffff | ||||
| 	s = s + s>>16 | ||||
| 	return ^uint16(s) | ||||
| } | ||||
|  | ||||
| // A Type represents an ICMP message type. | ||||
| type Type interface { | ||||
| 	Protocol() int | ||||
| } | ||||
|  | ||||
| // A Message represents an ICMP message. | ||||
| type Message struct { | ||||
| 	Type     Type        // type, either ipv4.ICMPType or ipv6.ICMPType | ||||
| 	Code     int         // code | ||||
| 	Checksum int         // checksum | ||||
| 	Body     MessageBody // body | ||||
| } | ||||
|  | ||||
| // Marshal returns the binary encoding of the ICMP message m. | ||||
| // | ||||
| // For an ICMPv4 message, the returned message always contains the | ||||
| // calculated checksum field. | ||||
| // | ||||
| // For an ICMPv6 message, the returned message contains the calculated | ||||
| // checksum field when psh is not nil, otherwise the kernel will | ||||
| // compute the checksum field during the message transmission. | ||||
| // When psh is not nil, it must be the pseudo header for IPv6. | ||||
| func (m *Message) Marshal(psh []byte) ([]byte, error) { | ||||
| 	var mtype byte | ||||
| 	switch typ := m.Type.(type) { | ||||
| 	case ipv4.ICMPType: | ||||
| 		mtype = byte(typ) | ||||
| 	case ipv6.ICMPType: | ||||
| 		mtype = byte(typ) | ||||
| 	default: | ||||
| 		return nil, errInvalidProtocol | ||||
| 	} | ||||
| 	b := []byte{mtype, byte(m.Code), 0, 0} | ||||
| 	proto := m.Type.Protocol() | ||||
| 	if proto == iana.ProtocolIPv6ICMP && psh != nil { | ||||
| 		b = append(psh, b...) | ||||
| 	} | ||||
| 	if m.Body != nil && m.Body.Len(proto) != 0 { | ||||
| 		mb, err := m.Body.Marshal(proto) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		b = append(b, mb...) | ||||
| 	} | ||||
| 	if proto == iana.ProtocolIPv6ICMP { | ||||
| 		if psh == nil { // cannot calculate checksum here | ||||
| 			return b, nil | ||||
| 		} | ||||
| 		off, l := 2*net.IPv6len, len(b)-len(psh) | ||||
| 		binary.BigEndian.PutUint32(b[off:off+4], uint32(l)) | ||||
| 	} | ||||
| 	s := checksum(b) | ||||
| 	// Place checksum back in header; using ^= avoids the | ||||
| 	// assumption the checksum bytes are zero. | ||||
| 	b[len(psh)+2] ^= byte(s) | ||||
| 	b[len(psh)+3] ^= byte(s >> 8) | ||||
| 	return b[len(psh):], nil | ||||
| } | ||||
|  | ||||
| var parseFns = map[Type]func(int, Type, []byte) (MessageBody, error){ | ||||
| 	ipv4.ICMPTypeDestinationUnreachable: parseDstUnreach, | ||||
| 	ipv4.ICMPTypeTimeExceeded:           parseTimeExceeded, | ||||
| 	ipv4.ICMPTypeParameterProblem:       parseParamProb, | ||||
|  | ||||
| 	ipv4.ICMPTypeEcho:                parseEcho, | ||||
| 	ipv4.ICMPTypeEchoReply:           parseEcho, | ||||
| 	ipv4.ICMPTypeExtendedEchoRequest: parseExtendedEchoRequest, | ||||
| 	ipv4.ICMPTypeExtendedEchoReply:   parseExtendedEchoReply, | ||||
|  | ||||
| 	ipv6.ICMPTypeDestinationUnreachable: parseDstUnreach, | ||||
| 	ipv6.ICMPTypePacketTooBig:           parsePacketTooBig, | ||||
| 	ipv6.ICMPTypeTimeExceeded:           parseTimeExceeded, | ||||
| 	ipv6.ICMPTypeParameterProblem:       parseParamProb, | ||||
|  | ||||
| 	ipv6.ICMPTypeEchoRequest:         parseEcho, | ||||
| 	ipv6.ICMPTypeEchoReply:           parseEcho, | ||||
| 	ipv6.ICMPTypeExtendedEchoRequest: parseExtendedEchoRequest, | ||||
| 	ipv6.ICMPTypeExtendedEchoReply:   parseExtendedEchoReply, | ||||
| } | ||||
|  | ||||
| // ParseMessage parses b as an ICMP message. | ||||
| // The provided proto must be either the ICMPv4 or ICMPv6 protocol | ||||
| // number. | ||||
| func ParseMessage(proto int, b []byte) (*Message, error) { | ||||
| 	if len(b) < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	var err error | ||||
| 	m := &Message{Code: int(b[1]), Checksum: int(binary.BigEndian.Uint16(b[2:4]))} | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		m.Type = ipv4.ICMPType(b[0]) | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		m.Type = ipv6.ICMPType(b[0]) | ||||
| 	default: | ||||
| 		return nil, errInvalidProtocol | ||||
| 	} | ||||
| 	if fn, ok := parseFns[m.Type]; !ok { | ||||
| 		m.Body, err = parseRawBody(proto, b[4:]) | ||||
| 	} else { | ||||
| 		m.Body, err = fn(proto, m.Type, b[4:]) | ||||
| 	} | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return m, nil | ||||
| } | ||||
							
								
								
									
										52
									
								
								vendor/golang.org/x/net/icmp/messagebody.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/golang.org/x/net/icmp/messagebody.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| // Copyright 2012 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| // A MessageBody represents an ICMP message body. | ||||
| type MessageBody interface { | ||||
| 	// Len returns the length of ICMP message body. | ||||
| 	// The provided proto must be either the ICMPv4 or ICMPv6 | ||||
| 	// protocol number. | ||||
| 	Len(proto int) int | ||||
|  | ||||
| 	// Marshal returns the binary encoding of ICMP message body. | ||||
| 	// The provided proto must be either the ICMPv4 or ICMPv6 | ||||
| 	// protocol number. | ||||
| 	Marshal(proto int) ([]byte, error) | ||||
| } | ||||
|  | ||||
| // A RawBody represents a raw message body. | ||||
| // | ||||
| // A raw message body is excluded from message processing and can be | ||||
| // used to construct applications such as protocol conformance | ||||
| // testing. | ||||
| type RawBody struct { | ||||
| 	Data []byte // data | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *RawBody) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return len(p.Data) | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *RawBody) Marshal(proto int) ([]byte, error) { | ||||
| 	return p.Data, nil | ||||
| } | ||||
|  | ||||
| // parseRawBody parses b as an ICMP message body. | ||||
| func parseRawBody(proto int, b []byte) (MessageBody, error) { | ||||
| 	p := &RawBody{Data: make([]byte, len(b))} | ||||
| 	copy(p.Data, b) | ||||
| 	return p, nil | ||||
| } | ||||
|  | ||||
| // A DefaultMessageBody represents the default message body. | ||||
| // | ||||
| // Deprecated: Use RawBody instead. | ||||
| type DefaultMessageBody = RawBody | ||||
							
								
								
									
										77
									
								
								vendor/golang.org/x/net/icmp/mpls.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								vendor/golang.org/x/net/icmp/mpls.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | ||||
| // Copyright 2015 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import "encoding/binary" | ||||
|  | ||||
| // MPLSLabel represents an MPLS label stack entry. | ||||
| type MPLSLabel struct { | ||||
| 	Label int  // label value | ||||
| 	TC    int  // traffic class; formerly experimental use | ||||
| 	S     bool // bottom of stack | ||||
| 	TTL   int  // time to live | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	classMPLSLabelStack        = 1 | ||||
| 	typeIncomingMPLSLabelStack = 1 | ||||
| ) | ||||
|  | ||||
| // MPLSLabelStack represents an MPLS label stack. | ||||
| type MPLSLabelStack struct { | ||||
| 	Class  int // extension object class number | ||||
| 	Type   int // extension object sub-type | ||||
| 	Labels []MPLSLabel | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of Extension interface. | ||||
| func (ls *MPLSLabelStack) Len(proto int) int { | ||||
| 	return 4 + (4 * len(ls.Labels)) | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of Extension interface. | ||||
| func (ls *MPLSLabelStack) Marshal(proto int) ([]byte, error) { | ||||
| 	b := make([]byte, ls.Len(proto)) | ||||
| 	if err := ls.marshal(proto, b); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| func (ls *MPLSLabelStack) marshal(proto int, b []byte) error { | ||||
| 	l := ls.Len(proto) | ||||
| 	binary.BigEndian.PutUint16(b[:2], uint16(l)) | ||||
| 	b[2], b[3] = classMPLSLabelStack, typeIncomingMPLSLabelStack | ||||
| 	off := 4 | ||||
| 	for _, ll := range ls.Labels { | ||||
| 		b[off], b[off+1], b[off+2] = byte(ll.Label>>12), byte(ll.Label>>4&0xff), byte(ll.Label<<4&0xf0) | ||||
| 		b[off+2] |= byte(ll.TC << 1 & 0x0e) | ||||
| 		if ll.S { | ||||
| 			b[off+2] |= 0x1 | ||||
| 		} | ||||
| 		b[off+3] = byte(ll.TTL) | ||||
| 		off += 4 | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func parseMPLSLabelStack(b []byte) (Extension, error) { | ||||
| 	ls := &MPLSLabelStack{ | ||||
| 		Class: int(b[2]), | ||||
| 		Type:  int(b[3]), | ||||
| 	} | ||||
| 	for b = b[4:]; len(b) >= 4; b = b[4:] { | ||||
| 		ll := MPLSLabel{ | ||||
| 			Label: int(b[0])<<12 | int(b[1])<<4 | int(b[2])>>4, | ||||
| 			TC:    int(b[2]&0x0e) >> 1, | ||||
| 			TTL:   int(b[3]), | ||||
| 		} | ||||
| 		if b[2]&0x1 != 0 { | ||||
| 			ll.S = true | ||||
| 		} | ||||
| 		ls.Labels = append(ls.Labels, ll) | ||||
| 	} | ||||
| 	return ls, nil | ||||
| } | ||||
							
								
								
									
										129
									
								
								vendor/golang.org/x/net/icmp/multipart.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								vendor/golang.org/x/net/icmp/multipart.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,129 @@ | ||||
| // Copyright 2015 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import "golang.org/x/net/internal/iana" | ||||
|  | ||||
| // multipartMessageBodyDataLen takes b as an original datagram and | ||||
| // exts as extensions, and returns a required length for message body | ||||
| // and a required length for a padded original datagram in wire | ||||
| // format. | ||||
| func multipartMessageBodyDataLen(proto int, withOrigDgram bool, b []byte, exts []Extension) (bodyLen, dataLen int) { | ||||
| 	bodyLen = 4 // length of leading octets | ||||
| 	var extLen int | ||||
| 	var rawExt bool // raw extension may contain an empty object | ||||
| 	for _, ext := range exts { | ||||
| 		extLen += ext.Len(proto) | ||||
| 		if _, ok := ext.(*RawExtension); ok { | ||||
| 			rawExt = true | ||||
| 		} | ||||
| 	} | ||||
| 	if extLen > 0 && withOrigDgram { | ||||
| 		dataLen = multipartMessageOrigDatagramLen(proto, b) | ||||
| 	} else { | ||||
| 		dataLen = len(b) | ||||
| 	} | ||||
| 	if extLen > 0 || rawExt { | ||||
| 		bodyLen += 4 // length of extension header | ||||
| 	} | ||||
| 	bodyLen += dataLen + extLen | ||||
| 	return bodyLen, dataLen | ||||
| } | ||||
|  | ||||
| // multipartMessageOrigDatagramLen takes b as an original datagram, | ||||
| // and returns a required length for a padded orignal datagram in wire | ||||
| // format. | ||||
| func multipartMessageOrigDatagramLen(proto int, b []byte) int { | ||||
| 	roundup := func(b []byte, align int) int { | ||||
| 		// According to RFC 4884, the padded original datagram | ||||
| 		// field must contain at least 128 octets. | ||||
| 		if len(b) < 128 { | ||||
| 			return 128 | ||||
| 		} | ||||
| 		r := len(b) | ||||
| 		return (r + align - 1) &^ (align - 1) | ||||
| 	} | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		return roundup(b, 4) | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		return roundup(b, 8) | ||||
| 	default: | ||||
| 		return len(b) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // marshalMultipartMessageBody takes data as an original datagram and | ||||
| // exts as extesnsions, and returns a binary encoding of message body. | ||||
| // It can be used for non-multipart message bodies when exts is nil. | ||||
| func marshalMultipartMessageBody(proto int, withOrigDgram bool, data []byte, exts []Extension) ([]byte, error) { | ||||
| 	bodyLen, dataLen := multipartMessageBodyDataLen(proto, withOrigDgram, data, exts) | ||||
| 	b := make([]byte, bodyLen) | ||||
| 	copy(b[4:], data) | ||||
| 	if len(exts) > 0 { | ||||
| 		b[4+dataLen] = byte(extensionVersion << 4) | ||||
| 		off := 4 + dataLen + 4 // leading octets, data, extension header | ||||
| 		for _, ext := range exts { | ||||
| 			switch ext := ext.(type) { | ||||
| 			case *MPLSLabelStack: | ||||
| 				if err := ext.marshal(proto, b[off:]); err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 				off += ext.Len(proto) | ||||
| 			case *InterfaceInfo: | ||||
| 				attrs, l := ext.attrsAndLen(proto) | ||||
| 				if err := ext.marshal(proto, b[off:], attrs, l); err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 				off += ext.Len(proto) | ||||
| 			case *InterfaceIdent: | ||||
| 				if err := ext.marshal(proto, b[off:]); err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 				off += ext.Len(proto) | ||||
| 			case *RawExtension: | ||||
| 				copy(b[off:], ext.Data) | ||||
| 				off += ext.Len(proto) | ||||
| 			} | ||||
| 		} | ||||
| 		s := checksum(b[4+dataLen:]) | ||||
| 		b[4+dataLen+2] ^= byte(s) | ||||
| 		b[4+dataLen+3] ^= byte(s >> 8) | ||||
| 		if withOrigDgram { | ||||
| 			switch proto { | ||||
| 			case iana.ProtocolICMP: | ||||
| 				b[1] = byte(dataLen / 4) | ||||
| 			case iana.ProtocolIPv6ICMP: | ||||
| 				b[0] = byte(dataLen / 8) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // parseMultipartMessageBody parses b as either a non-multipart | ||||
| // message body or a multipart message body. | ||||
| func parseMultipartMessageBody(proto int, typ Type, b []byte) ([]byte, []Extension, error) { | ||||
| 	var l int | ||||
| 	switch proto { | ||||
| 	case iana.ProtocolICMP: | ||||
| 		l = 4 * int(b[1]) | ||||
| 	case iana.ProtocolIPv6ICMP: | ||||
| 		l = 8 * int(b[0]) | ||||
| 	} | ||||
| 	if len(b) == 4 { | ||||
| 		return nil, nil, nil | ||||
| 	} | ||||
| 	exts, l, err := parseExtensions(typ, b[4:], l) | ||||
| 	if err != nil { | ||||
| 		l = len(b) - 4 | ||||
| 	} | ||||
| 	var data []byte | ||||
| 	if l > 0 { | ||||
| 		data = make([]byte, l) | ||||
| 		copy(data, b[4:]) | ||||
| 	} | ||||
| 	return data, exts, nil | ||||
| } | ||||
							
								
								
									
										43
									
								
								vendor/golang.org/x/net/icmp/packettoobig.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								vendor/golang.org/x/net/icmp/packettoobig.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,43 @@ | ||||
| // Copyright 2014 The Go Authors. All rights reserved. | ||||
| // Use of this source code is governed by a BSD-style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package icmp | ||||
|  | ||||
| import "encoding/binary" | ||||
|  | ||||
| // A PacketTooBig represents an ICMP packet too big message body. | ||||
| type PacketTooBig struct { | ||||
| 	MTU  int    // maximum transmission unit of the nexthop link | ||||
| 	Data []byte // data, known as original datagram field | ||||
| } | ||||
|  | ||||
| // Len implements the Len method of MessageBody interface. | ||||
| func (p *PacketTooBig) Len(proto int) int { | ||||
| 	if p == nil { | ||||
| 		return 0 | ||||
| 	} | ||||
| 	return 4 + len(p.Data) | ||||
| } | ||||
|  | ||||
| // Marshal implements the Marshal method of MessageBody interface. | ||||
| func (p *PacketTooBig) Marshal(proto int) ([]byte, error) { | ||||
| 	b := make([]byte, 4+len(p.Data)) | ||||
| 	binary.BigEndian.PutUint32(b[:4], uint32(p.MTU)) | ||||
| 	copy(b[4:], p.Data) | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // parsePacketTooBig parses b as an ICMP packet too big message body. | ||||
| func parsePacketTooBig(proto int, _ Type, b []byte) (MessageBody, error) { | ||||
| 	bodyLen := len(b) | ||||
| 	if bodyLen < 4 { | ||||
| 		return nil, errMessageTooShort | ||||
| 	} | ||||
| 	p := &PacketTooBig{MTU: int(binary.BigEndian.Uint32(b[:4]))} | ||||
| 	if bodyLen > 4 { | ||||
| 		p.Data = make([]byte, bodyLen-4) | ||||
| 		copy(p.Data, b[4:]) | ||||
| 	} | ||||
| 	return p, nil | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user