mirror of https://github.com/kubernetes/kops.git
				
				
				
			Update controller-runtime to v0.9.5
This commit is contained in:
		
							parent
							
								
									e6887bf163
								
							
						
					
					
						commit
						61e40c00c9
					
				
							
								
								
									
										6
									
								
								go.mod
								
								
								
								
							
							
						
						
									
										6
									
								
								go.mod
								
								
								
								
							|  | @ -78,7 +78,7 @@ require ( | |||
| 	golang.org/x/crypto v0.0.0-20210513164829-c07d793c2f9a | ||||
| 	golang.org/x/net v0.0.0-20210614182718-04defd469f4e | ||||
| 	golang.org/x/oauth2 v0.0.0-20210514164344-f6687ab2804c | ||||
| 	golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40 | ||||
| 	golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c | ||||
| 	google.golang.org/api v0.45.0 | ||||
| 	gopkg.in/gcfg.v1 v1.2.3 | ||||
| 	gopkg.in/inf.v0 v0.9.1 | ||||
|  | @ -95,8 +95,8 @@ require ( | |||
| 	k8s.io/kubectl v0.21.3 | ||||
| 	k8s.io/legacy-cloud-providers v0.21.3 | ||||
| 	k8s.io/mount-utils v0.21.3 | ||||
| 	k8s.io/utils v0.0.0-20210527160623-6fdb442a123b | ||||
| 	k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 | ||||
| 	rsc.io/letsencrypt v0.0.3 // indirect | ||||
| 	sigs.k8s.io/controller-runtime v0.9.0 | ||||
| 	sigs.k8s.io/controller-runtime v0.9.5 | ||||
| 	sigs.k8s.io/yaml v1.2.0 | ||||
| ) | ||||
|  |  | |||
							
								
								
									
										23
									
								
								go.sum
								
								
								
								
							
							
						
						
									
										23
									
								
								go.sum
								
								
								
								
							|  | @ -178,6 +178,7 @@ github.com/aws/aws-sdk-go v1.35.24/go.mod h1:tlPOdRjfxPBpNIwqDj61rmsnA85v9jc0Ps9 | |||
| github.com/aws/aws-sdk-go v1.40.0 h1:nTCSQAeahNt15SOYxuDwJ8XvMhOU3Uqe7eJUPv7+Vsk= | ||||
| github.com/aws/aws-sdk-go v1.40.0/go.mod h1:585smgzpB/KqRA+K3y/NL/oYRqQvpNJYvLm+LY1U59Q= | ||||
| github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= | ||||
| github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= | ||||
| github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= | ||||
| github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= | ||||
| github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= | ||||
|  | @ -900,7 +901,6 @@ github.com/onsi/ginkgo v1.10.3/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+ | |||
| github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.12.0/go.mod h1:oUhWkIvk5aDxtKvDDuw8gItl8pKl42LzjC9KZE0HfGg= | ||||
| github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= | ||||
| github.com/onsi/ginkgo v1.16.2/go.mod h1:CObGmKUOKaSC0RjmoAK7tKyn4Azo5P2IWuoMnvwxz1E= | ||||
| github.com/onsi/ginkgo v1.16.4 h1:29JGrr5oVBm5ulCWet69zQkzWipVXIol6ygQUe/EzNc= | ||||
| github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
|  | @ -912,8 +912,8 @@ github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7J | |||
| github.com/onsi/gomega v1.8.1/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA= | ||||
| github.com/onsi/gomega v1.9.0/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA= | ||||
| github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= | ||||
| github.com/onsi/gomega v1.13.0 h1:7lLHu94wT9Ij0o6EWWclhu0aOh32VxhkwEJvzuWPeak= | ||||
| github.com/onsi/gomega v1.13.0/go.mod h1:lRk9szgn8TxENtWd0Tp4c3wjlRfMTMH27I+3Je41yGY= | ||||
| github.com/onsi/gomega v1.14.0 h1:ep6kpPVwmr/nTbklSx2nrLNSIO62DoYAhnPNIMhK8gI= | ||||
| github.com/onsi/gomega v1.14.0/go.mod h1:cIuvLEne0aoVhAgh/O6ac0Op8WWw9H6eYCriF+tEHG0= | ||||
| github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk= | ||||
| github.com/opencontainers/go-digest v0.0.0-20170106003457-a6d0ee40d420/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
| github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
|  | @ -1203,8 +1203,9 @@ go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9i | |||
| go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA= | ||||
| go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= | ||||
| go.uber.org/zap v1.13.0/go.mod h1:zwrFLgMcdUuIBviXEYEH1YKNaOBnKXsx2IPda5bBwHM= | ||||
| go.uber.org/zap v1.17.0 h1:MTjgFu6ZLKvY6Pvaqk97GlxNBuMpV4Hy/3P6tRGlI2U= | ||||
| go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= | ||||
| go.uber.org/zap v1.18.1 h1:CSUJ2mjFszzEWt4CdKISEuChVIXGBn3lAPwkRGyVrc4= | ||||
| go.uber.org/zap v1.18.1/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= | ||||
| golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20181029021203-45a5f77698d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
|  | @ -1460,8 +1461,9 @@ golang.org/x/sys v0.0.0-20210412220455-f1c623a9e750/go.mod h1:h1NjWce9XRLGQEsW7w | |||
| golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210426230700-d19ff857e887/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40 h1:JWgyZ1qgdTaF3N3oxC+MdTV7qvEEgHo3otj+HB5CM7Q= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/term v0.0.0-20210220032956-6a3ed077a48d h1:SZxvLBoTP5yHO3Frd4z4vrF+DBX9vMVanchswa69toE= | ||||
|  | @ -1483,8 +1485,9 @@ golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxb | |||
| golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba h1:O8mE0/t419eoIwhTFpKVkHiTs/Igowgfkj25AcZrtiE= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac h1:7zkz7BUtwNFFqcowJ+RIgu2MaV/MapERkDIy+mwPyjs= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac/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-20180525024113-a5b4c53f6e8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
|  | @ -1833,8 +1836,8 @@ k8s.io/system-validators v1.4.0/go.mod h1:bPldcLgkIUK22ALflnsXk8pvkTEndYdNuaHH6g | |||
| k8s.io/utils v0.0.0-20200603063816-c1c6865ac451/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20200729134348-d5654de09c73/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20201110183641-67b214c5f920/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210527160623-6fdb442a123b h1:MSqsVQ3pZvPGTqCjptfimO2WjG7A9un2zcpiHkA6M/s= | ||||
| k8s.io/utils v0.0.0-20210527160623-6fdb442a123b/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 h1:DnzUXII7sVg1FJ/4JX6YDRJfLNAC7idRatPwe07suiI= | ||||
| k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| modernc.org/cc v1.0.0/go.mod h1:1Sk4//wdnYJiUIxnW8ddKpaOJCF37yAdqYnkxUpaYxw= | ||||
| modernc.org/golex v1.0.0/go.mod h1:b/QX9oBD/LhixY6NDh+IdGv17hgB+51fET1i2kPSmvk= | ||||
| modernc.org/mathutil v1.0.0/go.mod h1:wU0vUrJsVWBZ4P6e7xtFJEhFSNsfRLJ8H458uRjg03k= | ||||
|  | @ -1848,8 +1851,8 @@ 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/apiserver-network-proxy/konnectivity-client v0.0.19/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg= | ||||
| sigs.k8s.io/controller-runtime v0.6.2/go.mod h1:vhcq/rlnENJ09SIRp3EveTaZ0yqH526hjf9iJdbUJ/E= | ||||
| sigs.k8s.io/controller-runtime v0.9.0 h1:ZIZ/dtpboPSbZYY7uUz2OzrkaBTOThx2yekLtpGB+zY= | ||||
| sigs.k8s.io/controller-runtime v0.9.0/go.mod h1:TgkfvrhhEw3PlI0BRL/5xM+89y3/yc0ZDfdbTl84si8= | ||||
| sigs.k8s.io/controller-runtime v0.9.5 h1:WThcFE6cqctTn2jCZprLICO6BaKZfhsT37uAapTNfxc= | ||||
| sigs.k8s.io/controller-runtime v0.9.5/go.mod h1:q6PpkM5vqQubEKUKOM6qr06oXGzOBcCby1DA9FbyZeA= | ||||
| sigs.k8s.io/controller-tools v0.2.9-0.20200414181213-645d44dca7c0/go.mod h1:YKE/iHvcKITCljdnlqHYe+kAt7ZldvtAwUzQff0k1T0= | ||||
| sigs.k8s.io/kustomize/api v0.8.8 h1:G2z6JPSSjtWWgMeWSoHdXqyftJNmMmyxXpwENGoOtGE= | ||||
| sigs.k8s.io/kustomize/api v0.8.8/go.mod h1:He1zoK0nk43Pc6NlV085xDXDXTNprtcyKZVm3swsdNY= | ||||
|  |  | |||
|  | @ -248,6 +248,7 @@ github.com/aws/aws-sdk-go v1.40.0/go.mod h1:585smgzpB/KqRA+K3y/NL/oYRqQvpNJYvLm+ | |||
| github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= | ||||
| github.com/bazelbuild/buildtools v0.0.0-20190917191645-69366ca98f89/go.mod h1:5JP0TXzWDHXv8qvxRC4InIazwdyDseBDbzESUMKk1yU= | ||||
| github.com/bazelbuild/rules_go v0.22.1/go.mod h1:MC23Dc/wkXEyk3Wpq6lCqz0ZAYOZDw2DR5y3N1q2i7M= | ||||
| github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= | ||||
| github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= | ||||
| github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= | ||||
| github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= | ||||
|  | @ -1123,7 +1124,6 @@ github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+ | |||
| github.com/onsi/ginkgo v1.12.0/go.mod h1:oUhWkIvk5aDxtKvDDuw8gItl8pKl42LzjC9KZE0HfGg= | ||||
| github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= | ||||
| github.com/onsi/ginkgo v1.14.1/go.mod h1:iSB4RoI2tjJc9BBv4NKIKWKya62Rps+oPG/Lv9klQyY= | ||||
| github.com/onsi/ginkgo v1.16.2/go.mod h1:CObGmKUOKaSC0RjmoAK7tKyn4Azo5P2IWuoMnvwxz1E= | ||||
| github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v1.3.0/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
|  | @ -1137,7 +1137,7 @@ github.com/onsi/gomega v1.10.0/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGco | |||
| github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= | ||||
| github.com/onsi/gomega v1.10.2/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= | ||||
| github.com/onsi/gomega v1.10.3/go.mod h1:V9xEwhxec5O8UDM77eCW8vLymOMltsqPVYWrpDsH8xc= | ||||
| github.com/onsi/gomega v1.13.0/go.mod h1:lRk9szgn8TxENtWd0Tp4c3wjlRfMTMH27I+3Je41yGY= | ||||
| github.com/onsi/gomega v1.14.0/go.mod h1:cIuvLEne0aoVhAgh/O6ac0Op8WWw9H6eYCriF+tEHG0= | ||||
| github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk= | ||||
| github.com/opencontainers/go-digest v0.0.0-20170106003457-a6d0ee40d420/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
| github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
|  | @ -1503,6 +1503,7 @@ go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= | |||
| go.uber.org/zap v1.13.0/go.mod h1:zwrFLgMcdUuIBviXEYEH1YKNaOBnKXsx2IPda5bBwHM= | ||||
| go.uber.org/zap v1.14.1/go.mod h1:Mb2vm2krFEG5DV0W9qcHBYFtp/Wku1cvYaqPsS/WYfc= | ||||
| go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= | ||||
| go.uber.org/zap v1.18.1/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= | ||||
| gocloud.dev v0.19.0/go.mod h1:SmKwiR8YwIMMJvQBKLsC3fHNyMwXLw3PMDO+VVteJMI= | ||||
| golang.org/dl v0.0.0-20190829154251-82a15e2f2ead/go.mod h1:IUMfjQLJQd4UTqG1Z90tenwKoCX93Gn3MAQJMOSBsDQ= | ||||
| golang.org/x/crypto v0.0.0-20171113213409-9f005a07e0d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
|  | @ -1793,8 +1794,9 @@ golang.org/x/sys v0.0.0-20210403161142-5e06dd20ab57/go.mod h1:h1NjWce9XRLGQEsW7w | |||
| golang.org/x/sys v0.0.0-20210412220455-f1c623a9e750/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40 h1:JWgyZ1qgdTaF3N3oxC+MdTV7qvEEgHo3otj+HB5CM7Q= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/term v0.0.0-20210220032956-6a3ed077a48d h1:SZxvLBoTP5yHO3Frd4z4vrF+DBX9vMVanchswa69toE= | ||||
|  | @ -1817,8 +1819,9 @@ golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxb | |||
| golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba h1:O8mE0/t419eoIwhTFpKVkHiTs/Igowgfkj25AcZrtiE= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac h1:7zkz7BUtwNFFqcowJ+RIgu2MaV/MapERkDIy+mwPyjs= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac/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-20180525024113-a5b4c53f6e8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
|  | @ -2236,7 +2239,7 @@ k8s.io/utils v0.0.0-20200729134348-d5654de09c73/go.mod h1:jPW/WVKK9YHAvNhRxK0md/ | |||
| k8s.io/utils v0.0.0-20200912215256-4140de9c8800/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20201110183641-67b214c5f920/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210111153108-fddb29f9d009/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210527160623-6fdb442a123b/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| knative.dev/caching v0.0.0-20200116200605-67bca2c83dfa/go.mod h1:dHXFU6CGlLlbzaWc32g80cR92iuBSpsslDNBWI8C7eg= | ||||
| knative.dev/eventing-contrib v0.11.2/go.mod h1:SnXZgSGgMSMLNFTwTnpaOH7hXDzTFtw0J8OmHflNx3g= | ||||
| knative.dev/pkg v0.0.0-20200207155214-fef852970f43/go.mod h1:pgODObA1dTyhNoFxPZTTjNWfx6F0aKsKzn+vaT9XO/Q= | ||||
|  | @ -2263,7 +2266,7 @@ sigs.k8s.io/boskos v0.0.0-20200710214748-f5935686c7fc/go.mod h1:ZO5RV+VxJS9mb6Dv | |||
| sigs.k8s.io/controller-runtime v0.5.0/go.mod h1:REiJzC7Y00U+2YkMbT8wxgrsX5USpXKGhb2sCtAXiT8= | ||||
| sigs.k8s.io/controller-runtime v0.5.4/go.mod h1:JZUwSMVbxDupo0lTJSSFP5pimEyxGynROImSsqIOx1A= | ||||
| sigs.k8s.io/controller-runtime v0.6.2/go.mod h1:vhcq/rlnENJ09SIRp3EveTaZ0yqH526hjf9iJdbUJ/E= | ||||
| sigs.k8s.io/controller-runtime v0.9.0/go.mod h1:TgkfvrhhEw3PlI0BRL/5xM+89y3/yc0ZDfdbTl84si8= | ||||
| sigs.k8s.io/controller-runtime v0.9.5/go.mod h1:q6PpkM5vqQubEKUKOM6qr06oXGzOBcCby1DA9FbyZeA= | ||||
| sigs.k8s.io/controller-tools v0.2.9-0.20200414181213-645d44dca7c0/go.mod h1:YKE/iHvcKITCljdnlqHYe+kAt7ZldvtAwUzQff0k1T0= | ||||
| sigs.k8s.io/kubetest2 v0.0.0-20210423234514-1c731a5d2283 h1:8w3J6N9j8lUP3lb3B/2PGsJ5A6rtFF9wUpPPEk9/ctI= | ||||
| sigs.k8s.io/kubetest2 v0.0.0-20210423234514-1c731a5d2283/go.mod h1:miwZW11FA2Bvclxo4WqIVY+gHTR5B927inXdfxJYoAA= | ||||
|  |  | |||
							
								
								
									
										18
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/BUILD.bazel
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										18
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/BUILD.bazel
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,18 @@ | |||
| load("@io_bazel_rules_go//go:def.bzl", "go_library") | ||||
| 
 | ||||
| go_library( | ||||
|     name = "go_default_library", | ||||
|     srcs = [ | ||||
|         "collectors.go", | ||||
|         "dbstats_collector.go", | ||||
|         "dbstats_collector_go115.go", | ||||
|         "dbstats_collector_pre_go115.go", | ||||
|         "expvar_collector.go", | ||||
|         "go_collector.go", | ||||
|         "process_collector.go", | ||||
|     ], | ||||
|     importmap = "k8s.io/kops/vendor/github.com/prometheus/client_golang/prometheus/collectors", | ||||
|     importpath = "github.com/prometheus/client_golang/prometheus/collectors", | ||||
|     visibility = ["//visibility:public"], | ||||
|     deps = ["//vendor/github.com/prometheus/client_golang/prometheus:go_default_library"], | ||||
| ) | ||||
							
								
								
									
										16
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/collectors.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										16
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/collectors.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,16 @@ | |||
| // Copyright 2021 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.
 | ||||
| 
 | ||||
| // Package collectors provides implementations of prometheus.Collector to
 | ||||
| // conveniently collect process and Go-related metrics.
 | ||||
| package collectors | ||||
							
								
								
									
										119
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										119
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,119 @@ | |||
| // Copyright 2021 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.
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import ( | ||||
| 	"database/sql" | ||||
| 
 | ||||
| 	"github.com/prometheus/client_golang/prometheus" | ||||
| ) | ||||
| 
 | ||||
| type dbStatsCollector struct { | ||||
| 	db *sql.DB | ||||
| 
 | ||||
| 	maxOpenConnections *prometheus.Desc | ||||
| 
 | ||||
| 	openConnections  *prometheus.Desc | ||||
| 	inUseConnections *prometheus.Desc | ||||
| 	idleConnections  *prometheus.Desc | ||||
| 
 | ||||
| 	waitCount         *prometheus.Desc | ||||
| 	waitDuration      *prometheus.Desc | ||||
| 	maxIdleClosed     *prometheus.Desc | ||||
| 	maxIdleTimeClosed *prometheus.Desc | ||||
| 	maxLifetimeClosed *prometheus.Desc | ||||
| } | ||||
| 
 | ||||
| // NewDBStatsCollector returns a collector that exports metrics about the given *sql.DB.
 | ||||
| // See https://golang.org/pkg/database/sql/#DBStats for more information on stats.
 | ||||
| func NewDBStatsCollector(db *sql.DB, dbName string) prometheus.Collector { | ||||
| 	fqName := func(name string) string { | ||||
| 		return "go_sql_" + name | ||||
| 	} | ||||
| 	return &dbStatsCollector{ | ||||
| 		db: db, | ||||
| 		maxOpenConnections: prometheus.NewDesc( | ||||
| 			fqName("max_open_connections"), | ||||
| 			"Maximum number of open connections to the database.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		openConnections: prometheus.NewDesc( | ||||
| 			fqName("open_connections"), | ||||
| 			"The number of established connections both in use and idle.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		inUseConnections: prometheus.NewDesc( | ||||
| 			fqName("in_use_connections"), | ||||
| 			"The number of connections currently in use.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		idleConnections: prometheus.NewDesc( | ||||
| 			fqName("idle_connections"), | ||||
| 			"The number of idle connections.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		waitCount: prometheus.NewDesc( | ||||
| 			fqName("wait_count_total"), | ||||
| 			"The total number of connections waited for.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		waitDuration: prometheus.NewDesc( | ||||
| 			fqName("wait_duration_seconds_total"), | ||||
| 			"The total time blocked waiting for a new connection.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		maxIdleClosed: prometheus.NewDesc( | ||||
| 			fqName("max_idle_closed_total"), | ||||
| 			"The total number of connections closed due to SetMaxIdleConns.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		maxIdleTimeClosed: prometheus.NewDesc( | ||||
| 			fqName("max_idle_time_closed_total"), | ||||
| 			"The total number of connections closed due to SetConnMaxIdleTime.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 		maxLifetimeClosed: prometheus.NewDesc( | ||||
| 			fqName("max_lifetime_closed_total"), | ||||
| 			"The total number of connections closed due to SetConnMaxLifetime.", | ||||
| 			nil, prometheus.Labels{"db_name": dbName}, | ||||
| 		), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Describe implements Collector.
 | ||||
| func (c *dbStatsCollector) Describe(ch chan<- *prometheus.Desc) { | ||||
| 	ch <- c.maxOpenConnections | ||||
| 	ch <- c.openConnections | ||||
| 	ch <- c.inUseConnections | ||||
| 	ch <- c.idleConnections | ||||
| 	ch <- c.waitCount | ||||
| 	ch <- c.waitDuration | ||||
| 	ch <- c.maxIdleClosed | ||||
| 	ch <- c.maxLifetimeClosed | ||||
| 	c.describeNewInGo115(ch) | ||||
| } | ||||
| 
 | ||||
| // Collect implements Collector.
 | ||||
| func (c *dbStatsCollector) Collect(ch chan<- prometheus.Metric) { | ||||
| 	stats := c.db.Stats() | ||||
| 	ch <- prometheus.MustNewConstMetric(c.maxOpenConnections, prometheus.GaugeValue, float64(stats.MaxOpenConnections)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.openConnections, prometheus.GaugeValue, float64(stats.OpenConnections)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.inUseConnections, prometheus.GaugeValue, float64(stats.InUse)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.idleConnections, prometheus.GaugeValue, float64(stats.Idle)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.waitCount, prometheus.CounterValue, float64(stats.WaitCount)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.waitDuration, prometheus.CounterValue, stats.WaitDuration.Seconds()) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.maxIdleClosed, prometheus.CounterValue, float64(stats.MaxIdleClosed)) | ||||
| 	ch <- prometheus.MustNewConstMetric(c.maxLifetimeClosed, prometheus.CounterValue, float64(stats.MaxLifetimeClosed)) | ||||
| 	c.collectNewInGo115(ch, stats) | ||||
| } | ||||
							
								
								
									
										30
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector_go115.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										30
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector_go115.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,30 @@ | |||
| // Copyright 2021 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 go1.15
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import ( | ||||
| 	"database/sql" | ||||
| 
 | ||||
| 	"github.com/prometheus/client_golang/prometheus" | ||||
| ) | ||||
| 
 | ||||
| func (c *dbStatsCollector) describeNewInGo115(ch chan<- *prometheus.Desc) { | ||||
| 	ch <- c.maxIdleTimeClosed | ||||
| } | ||||
| 
 | ||||
| func (c *dbStatsCollector) collectNewInGo115(ch chan<- prometheus.Metric, stats sql.DBStats) { | ||||
| 	ch <- prometheus.MustNewConstMetric(c.maxIdleTimeClosed, prometheus.CounterValue, float64(stats.MaxIdleTimeClosed)) | ||||
| } | ||||
							
								
								
									
										26
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector_pre_go115.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										26
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/dbstats_collector_pre_go115.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,26 @@ | |||
| // Copyright 2021 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 !go1.15
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import ( | ||||
| 	"database/sql" | ||||
| 
 | ||||
| 	"github.com/prometheus/client_golang/prometheus" | ||||
| ) | ||||
| 
 | ||||
| func (c *dbStatsCollector) describeNewInGo115(ch chan<- *prometheus.Desc) {} | ||||
| 
 | ||||
| func (c *dbStatsCollector) collectNewInGo115(ch chan<- prometheus.Metric, stats sql.DBStats) {} | ||||
							
								
								
									
										57
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/expvar_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										57
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/expvar_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,57 @@ | |||
| // Copyright 2021 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.
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import "github.com/prometheus/client_golang/prometheus" | ||||
| 
 | ||||
| // NewExpvarCollector returns a newly allocated expvar Collector.
 | ||||
| //
 | ||||
| // An expvar Collector collects metrics from the expvar interface. It provides a
 | ||||
| // quick way to expose numeric values that are already exported via expvar as
 | ||||
| // Prometheus metrics. Note that the data models of expvar and Prometheus are
 | ||||
| // fundamentally different, and that the expvar Collector is inherently slower
 | ||||
| // than native Prometheus metrics. Thus, the expvar Collector is probably great
 | ||||
| // for experiments and prototying, but you should seriously consider a more
 | ||||
| // direct implementation of Prometheus metrics for monitoring production
 | ||||
| // systems.
 | ||||
| //
 | ||||
| // The exports map has the following meaning:
 | ||||
| //
 | ||||
| // The keys in the map correspond to expvar keys, i.e. for every expvar key you
 | ||||
| // want to export as Prometheus metric, you need an entry in the exports
 | ||||
| // map. The descriptor mapped to each key describes how to export the expvar
 | ||||
| // value. It defines the name and the help string of the Prometheus metric
 | ||||
| // proxying the expvar value. The type will always be Untyped.
 | ||||
| //
 | ||||
| // For descriptors without variable labels, the expvar value must be a number or
 | ||||
| // a bool. The number is then directly exported as the Prometheus sample
 | ||||
| // value. (For a bool, 'false' translates to 0 and 'true' to 1). Expvar values
 | ||||
| // that are not numbers or bools are silently ignored.
 | ||||
| //
 | ||||
| // If the descriptor has one variable label, the expvar value must be an expvar
 | ||||
| // map. The keys in the expvar map become the various values of the one
 | ||||
| // Prometheus label. The values in the expvar map must be numbers or bools again
 | ||||
| // as above.
 | ||||
| //
 | ||||
| // For descriptors with more than one variable label, the expvar must be a
 | ||||
| // nested expvar map, i.e. where the values of the topmost map are maps again
 | ||||
| // etc. until a depth is reached that corresponds to the number of labels. The
 | ||||
| // leaves of that structure must be numbers or bools as above to serve as the
 | ||||
| // sample values.
 | ||||
| //
 | ||||
| // Anything that does not fit into the scheme above is silently ignored.
 | ||||
| func NewExpvarCollector(exports map[string]*prometheus.Desc) prometheus.Collector { | ||||
| 	//nolint:staticcheck // Ignore SA1019 until v2.
 | ||||
| 	return prometheus.NewExpvarCollector(exports) | ||||
| } | ||||
							
								
								
									
										69
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/go_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										69
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/go_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,69 @@ | |||
| // Copyright 2021 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.
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import "github.com/prometheus/client_golang/prometheus" | ||||
| 
 | ||||
| // NewGoCollector returns a collector that exports metrics about the current Go
 | ||||
| // process. This includes memory stats. To collect those, runtime.ReadMemStats
 | ||||
| // is called. This requires to “stop the world”, which usually only happens for
 | ||||
| // garbage collection (GC). Take the following implications into account when
 | ||||
| // deciding whether to use the Go collector:
 | ||||
| //
 | ||||
| // 1. The performance impact of stopping the world is the more relevant the more
 | ||||
| // frequently metrics are collected. However, with Go1.9 or later the
 | ||||
| // stop-the-world time per metrics collection is very short (~25µs) so that the
 | ||||
| // performance impact will only matter in rare cases. However, with older Go
 | ||||
| // versions, the stop-the-world duration depends on the heap size and can be
 | ||||
| // quite significant (~1.7 ms/GiB as per
 | ||||
| // https://go-review.googlesource.com/c/go/+/34937).
 | ||||
| //
 | ||||
| // 2. During an ongoing GC, nothing else can stop the world. Therefore, if the
 | ||||
| // metrics collection happens to coincide with GC, it will only complete after
 | ||||
| // GC has finished. Usually, GC is fast enough to not cause problems. However,
 | ||||
| // with a very large heap, GC might take multiple seconds, which is enough to
 | ||||
| // cause scrape timeouts in common setups. To avoid this problem, the Go
 | ||||
| // 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.
 | ||||
| //
 | ||||
| // NOTE: The problem is solved in Go 1.15, see
 | ||||
| // https://github.com/golang/go/issues/19812 for the related Go issue.
 | ||||
| func NewGoCollector() prometheus.Collector { | ||||
| 	//nolint:staticcheck // Ignore SA1019 until v2.
 | ||||
| 	return prometheus.NewGoCollector() | ||||
| } | ||||
| 
 | ||||
| // NewBuildInfoCollector returns a collector collecting a single metric
 | ||||
| // "go_build_info" with the constant value 1 and three labels "path", "version",
 | ||||
| // and "checksum". Their label values contain the main module path, version, and
 | ||||
| // checksum, respectively. The labels will only have meaningful values if the
 | ||||
| // binary is built with Go module support and from source code retrieved from
 | ||||
| // the source repository (rather than the local file system). This is usually
 | ||||
| // accomplished by building from outside of GOPATH, specifying the full address
 | ||||
| // of the main package, e.g. "GO111MODULE=on go run
 | ||||
| // github.com/prometheus/client_golang/examples/random". If built without Go
 | ||||
| // module support, all label values will be "unknown". If built with Go module
 | ||||
| // support but using the source code from the local file system, the "path" will
 | ||||
| // be set appropriately, but "checksum" will be empty and "version" will be
 | ||||
| // "(devel)".
 | ||||
| //
 | ||||
| // This collector uses only the build information for the main module. See
 | ||||
| // https://github.com/povilasv/prommod for an example of a collector for the
 | ||||
| // module dependencies.
 | ||||
| func NewBuildInfoCollector() prometheus.Collector { | ||||
| 	//nolint:staticcheck // Ignore SA1019 until v2.
 | ||||
| 	return prometheus.NewBuildInfoCollector() | ||||
| } | ||||
							
								
								
									
										56
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/process_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										56
									
								
								vendor/github.com/prometheus/client_golang/prometheus/collectors/process_collector.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,56 @@ | |||
| // Copyright 2021 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.
 | ||||
| 
 | ||||
| package collectors | ||||
| 
 | ||||
| import "github.com/prometheus/client_golang/prometheus" | ||||
| 
 | ||||
| // ProcessCollectorOpts defines the behavior of a process metrics collector
 | ||||
| // created with NewProcessCollector.
 | ||||
| type ProcessCollectorOpts struct { | ||||
| 	// PidFn returns the PID of the process the collector collects metrics
 | ||||
| 	// for. It is called upon each collection. By default, the PID of the
 | ||||
| 	// current process is used, as determined on construction time by
 | ||||
| 	// calling os.Getpid().
 | ||||
| 	PidFn func() (int, error) | ||||
| 	// If non-empty, each of the collected metrics is prefixed by the
 | ||||
| 	// provided string and an underscore ("_").
 | ||||
| 	Namespace string | ||||
| 	// If true, any error encountered during collection is reported as an
 | ||||
| 	// invalid metric (see NewInvalidMetric). Otherwise, errors are ignored
 | ||||
| 	// and the collected metrics will be incomplete. (Possibly, no metrics
 | ||||
| 	// will be collected at all.) While that's usually not desired, it is
 | ||||
| 	// appropriate for the common "mix-in" of process metrics, where process
 | ||||
| 	// metrics are nice to have, but failing to collect them should not
 | ||||
| 	// disrupt the collection of the remaining metrics.
 | ||||
| 	ReportErrors bool | ||||
| } | ||||
| 
 | ||||
| // NewProcessCollector returns a collector which exports the current state of
 | ||||
| // process metrics including CPU, memory and file descriptor usage as well as
 | ||||
| // the process start time. The detailed behavior is defined by the provided
 | ||||
| // ProcessCollectorOpts. The zero value of ProcessCollectorOpts creates a
 | ||||
| // collector for the current process with an empty namespace string and no error
 | ||||
| // reporting.
 | ||||
| //
 | ||||
| // The collector only works on operating systems with a Linux-style proc
 | ||||
| // filesystem and on Microsoft Windows. On other operating systems, it will not
 | ||||
| // collect any metrics.
 | ||||
| func NewProcessCollector(opts ProcessCollectorOpts) prometheus.Collector { | ||||
| 	//nolint:staticcheck // Ignore SA1019 until v2.
 | ||||
| 	return prometheus.NewProcessCollector(prometheus.ProcessCollectorOpts{ | ||||
| 		PidFn:        opts.PidFn, | ||||
| 		Namespace:    opts.Namespace, | ||||
| 		ReportErrors: opts.ReportErrors, | ||||
| 	}) | ||||
| } | ||||
|  | @ -239,6 +239,7 @@ struct ltchars { | |||
| #include <linux/netfilter/nfnetlink.h> | ||||
| #include <linux/netlink.h> | ||||
| #include <linux/net_namespace.h> | ||||
| #include <linux/nfc.h> | ||||
| #include <linux/nsfs.h> | ||||
| #include <linux/perf_event.h> | ||||
| #include <linux/pps.h> | ||||
|  | @ -502,6 +503,9 @@ ccflags="$@" | |||
| 		$2 ~ /^LO_(KEY|NAME)_SIZE$/ || | ||||
| 		$2 ~ /^LOOP_(CLR|CTL|GET|SET)_/ || | ||||
| 		$2 ~ /^(AF|SOCK|SO|SOL|IPPROTO|IP|IPV6|TCP|MCAST|EVFILT|NOTE|SHUT|PROT|MAP|MFD|T?PACKET|MSG|SCM|MCL|DT|MADV|PR|LOCAL)_/ || | ||||
| 		$2 ~ /^NFC_(GENL|PROTO|COMM|RF|SE|DIRECTION|LLCP|SOCKPROTO)_/ || | ||||
| 		$2 ~ /^NFC_.*_(MAX)?SIZE$/ || | ||||
| 		$2 ~ /^RAW_PAYLOAD_/ || | ||||
| 		$2 ~ /^TP_STATUS_/ || | ||||
| 		$2 ~ /^FALLOC_/ || | ||||
| 		$2 ~ /^ICMPV?6?_(FILTER|SEC)/ || | ||||
|  | @ -559,6 +563,7 @@ ccflags="$@" | |||
| 		$2 ~ /^KEYCTL_/ || | ||||
| 		$2 ~ /^PERF_/ || | ||||
| 		$2 ~ /^SECCOMP_MODE_/ || | ||||
| 		$2 ~ /^SEEK_/ || | ||||
| 		$2 ~ /^SPLICE_/ || | ||||
| 		$2 ~ /^SYNC_FILE_RANGE_/ || | ||||
| 		$2 !~ /^AUDIT_RECORD_MAGIC/ && | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ | |||
| package unix | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"runtime" | ||||
| 	"syscall" | ||||
| 	"unsafe" | ||||
|  | @ -398,6 +399,38 @@ func GetsockoptXucred(fd, level, opt int) (*Xucred, error) { | |||
| 	return x, err | ||||
| } | ||||
| 
 | ||||
| func SysctlKinfoProcSlice(name string) ([]KinfoProc, error) { | ||||
| 	mib, err := sysctlmib(name) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	// Find size.
 | ||||
| 	n := uintptr(0) | ||||
| 	if err := sysctl(mib, nil, &n, nil, 0); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if n == 0 { | ||||
| 		return nil, nil | ||||
| 	} | ||||
| 	if n%SizeofKinfoProc != 0 { | ||||
| 		return nil, fmt.Errorf("sysctl() returned a size of %d, which is not a multiple of %d", n, SizeofKinfoProc) | ||||
| 	} | ||||
| 
 | ||||
| 	// Read into buffer of that size.
 | ||||
| 	buf := make([]KinfoProc, n/SizeofKinfoProc) | ||||
| 	if err := sysctl(mib, (*byte)(unsafe.Pointer(&buf[0])), &n, nil, 0); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if n%SizeofKinfoProc != 0 { | ||||
| 		return nil, fmt.Errorf("sysctl() returned a size of %d, which is not a multiple of %d", n, SizeofKinfoProc) | ||||
| 	} | ||||
| 
 | ||||
| 	// The actual call may return less than the original reported required
 | ||||
| 	// size so ensure we deal with that.
 | ||||
| 	return buf[:n/SizeofKinfoProc], nil | ||||
| } | ||||
| 
 | ||||
| //sys	sendfile(infd int, outfd int, offset int64, len *int64, hdtr unsafe.Pointer, flags int) (err error)
 | ||||
| 
 | ||||
| /* | ||||
|  |  | |||
|  | @ -904,6 +904,46 @@ func (sa *SockaddrIUCV) sockaddr() (unsafe.Pointer, _Socklen, error) { | |||
| 	return unsafe.Pointer(&sa.raw), SizeofSockaddrIUCV, nil | ||||
| } | ||||
| 
 | ||||
| type SockaddrNFC struct { | ||||
| 	DeviceIdx   uint32 | ||||
| 	TargetIdx   uint32 | ||||
| 	NFCProtocol uint32 | ||||
| 	raw         RawSockaddrNFC | ||||
| } | ||||
| 
 | ||||
| func (sa *SockaddrNFC) sockaddr() (unsafe.Pointer, _Socklen, error) { | ||||
| 	sa.raw.Sa_family = AF_NFC | ||||
| 	sa.raw.Dev_idx = sa.DeviceIdx | ||||
| 	sa.raw.Target_idx = sa.TargetIdx | ||||
| 	sa.raw.Nfc_protocol = sa.NFCProtocol | ||||
| 	return unsafe.Pointer(&sa.raw), SizeofSockaddrNFC, nil | ||||
| } | ||||
| 
 | ||||
| type SockaddrNFCLLCP struct { | ||||
| 	DeviceIdx      uint32 | ||||
| 	TargetIdx      uint32 | ||||
| 	NFCProtocol    uint32 | ||||
| 	DestinationSAP uint8 | ||||
| 	SourceSAP      uint8 | ||||
| 	ServiceName    string | ||||
| 	raw            RawSockaddrNFCLLCP | ||||
| } | ||||
| 
 | ||||
| func (sa *SockaddrNFCLLCP) sockaddr() (unsafe.Pointer, _Socklen, error) { | ||||
| 	sa.raw.Sa_family = AF_NFC | ||||
| 	sa.raw.Dev_idx = sa.DeviceIdx | ||||
| 	sa.raw.Target_idx = sa.TargetIdx | ||||
| 	sa.raw.Nfc_protocol = sa.NFCProtocol | ||||
| 	sa.raw.Dsap = sa.DestinationSAP | ||||
| 	sa.raw.Ssap = sa.SourceSAP | ||||
| 	if len(sa.ServiceName) > len(sa.raw.Service_name) { | ||||
| 		return nil, 0, EINVAL | ||||
| 	} | ||||
| 	copy(sa.raw.Service_name[:], sa.ServiceName) | ||||
| 	sa.raw.SetServiceNameLen(len(sa.ServiceName)) | ||||
| 	return unsafe.Pointer(&sa.raw), SizeofSockaddrNFCLLCP, nil | ||||
| } | ||||
| 
 | ||||
| var socketProtocol = func(fd int) (int, error) { | ||||
| 	return GetsockoptInt(fd, SOL_SOCKET, SO_PROTOCOL) | ||||
| } | ||||
|  | @ -1144,6 +1184,37 @@ func anyToSockaddr(fd int, rsa *RawSockaddrAny) (Sockaddr, error) { | |||
| 			} | ||||
| 			return sa, nil | ||||
| 		} | ||||
| 	case AF_NFC: | ||||
| 		proto, err := socketProtocol(fd) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		switch proto { | ||||
| 		case NFC_SOCKPROTO_RAW: | ||||
| 			pp := (*RawSockaddrNFC)(unsafe.Pointer(rsa)) | ||||
| 			sa := &SockaddrNFC{ | ||||
| 				DeviceIdx:   pp.Dev_idx, | ||||
| 				TargetIdx:   pp.Target_idx, | ||||
| 				NFCProtocol: pp.Nfc_protocol, | ||||
| 			} | ||||
| 			return sa, nil | ||||
| 		case NFC_SOCKPROTO_LLCP: | ||||
| 			pp := (*RawSockaddrNFCLLCP)(unsafe.Pointer(rsa)) | ||||
| 			if uint64(pp.Service_name_len) > uint64(len(pp.Service_name)) { | ||||
| 				return nil, EINVAL | ||||
| 			} | ||||
| 			sa := &SockaddrNFCLLCP{ | ||||
| 				DeviceIdx:      pp.Dev_idx, | ||||
| 				TargetIdx:      pp.Target_idx, | ||||
| 				NFCProtocol:    pp.Nfc_protocol, | ||||
| 				DestinationSAP: pp.Dsap, | ||||
| 				SourceSAP:      pp.Ssap, | ||||
| 				ServiceName:    string(pp.Service_name[:pp.Service_name_len]), | ||||
| 			} | ||||
| 			return sa, nil | ||||
| 		default: | ||||
| 			return nil, EINVAL | ||||
| 		} | ||||
| 	} | ||||
| 	return nil, EAFNOSUPPORT | ||||
| } | ||||
|  |  | |||
|  | @ -378,6 +378,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| //sys	poll(fds *PollFd, nfds int, timeout int) (n int, err error)
 | ||||
| 
 | ||||
| func Poll(fds []PollFd, timeout int) (n int, err error) { | ||||
|  |  | |||
|  | @ -172,6 +172,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| //sys	poll(fds *PollFd, nfds int, timeout int) (n int, err error)
 | ||||
| 
 | ||||
| func Poll(fds []PollFd, timeout int) (n int, err error) { | ||||
|  |  | |||
|  | @ -256,6 +256,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| //sys	poll(fds *PollFd, nfds int, timeout int) (n int, err error)
 | ||||
| 
 | ||||
| func Poll(fds []PollFd, timeout int) (n int, err error) { | ||||
|  |  | |||
|  | @ -207,6 +207,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func InotifyInit() (fd int, err error) { | ||||
| 	return InotifyInit1(0) | ||||
| } | ||||
|  |  | |||
|  | @ -217,6 +217,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func InotifyInit() (fd int, err error) { | ||||
| 	return InotifyInit1(0) | ||||
| } | ||||
|  |  | |||
|  | @ -229,6 +229,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| //sys	poll(fds *PollFd, nfds int, timeout int) (n int, err error)
 | ||||
| 
 | ||||
| func Poll(fds []PollFd, timeout int) (n int, err error) { | ||||
|  |  | |||
|  | @ -215,6 +215,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint32(length) | ||||
| } | ||||
| 
 | ||||
| //sysnb	pipe(p *[2]_C_int) (err error)
 | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  |  | |||
|  | @ -100,6 +100,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| //sysnb	pipe(p *[2]_C_int) (err error)
 | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  |  | |||
|  | @ -188,6 +188,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func InotifyInit() (fd int, err error) { | ||||
| 	return InotifyInit1(0) | ||||
| } | ||||
|  |  | |||
|  | @ -129,6 +129,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| // Linux on s390x uses the old mmap interface, which requires arguments to be passed in a struct.
 | ||||
| // mmap2 also requires arguments to be passed in a struct; it is currently not exposed in <asm/unistd.h>.
 | ||||
| func mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error) { | ||||
|  |  | |||
|  | @ -116,6 +116,10 @@ func (cmsg *Cmsghdr) SetLen(length int) { | |||
| 	cmsg.Len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| func (rsa *RawSockaddrNFCLLCP) SetServiceNameLen(length int) { | ||||
| 	rsa.Service_name_len = uint64(length) | ||||
| } | ||||
| 
 | ||||
| //sysnb	pipe(p *[2]_C_int) (err error)
 | ||||
| 
 | ||||
| func Pipe(p []int) (err error) { | ||||
|  |  | |||
|  | @ -1262,6 +1262,11 @@ const ( | |||
| 	SCM_RIGHTS                        = 0x1 | ||||
| 	SCM_TIMESTAMP                     = 0x2 | ||||
| 	SCM_TIMESTAMP_MONOTONIC           = 0x4 | ||||
| 	SEEK_CUR                          = 0x1 | ||||
| 	SEEK_DATA                         = 0x4 | ||||
| 	SEEK_END                          = 0x2 | ||||
| 	SEEK_HOLE                         = 0x3 | ||||
| 	SEEK_SET                          = 0x0 | ||||
| 	SHUT_RD                           = 0x0 | ||||
| 	SHUT_RDWR                         = 0x2 | ||||
| 	SHUT_WR                           = 0x1 | ||||
|  |  | |||
|  | @ -1262,6 +1262,11 @@ const ( | |||
| 	SCM_RIGHTS                        = 0x1 | ||||
| 	SCM_TIMESTAMP                     = 0x2 | ||||
| 	SCM_TIMESTAMP_MONOTONIC           = 0x4 | ||||
| 	SEEK_CUR                          = 0x1 | ||||
| 	SEEK_DATA                         = 0x4 | ||||
| 	SEEK_END                          = 0x2 | ||||
| 	SEEK_HOLE                         = 0x3 | ||||
| 	SEEK_SET                          = 0x0 | ||||
| 	SHUT_RD                           = 0x0 | ||||
| 	SHUT_RDWR                         = 0x2 | ||||
| 	SHUT_WR                           = 0x1 | ||||
|  |  | |||
|  | @ -1297,6 +1297,11 @@ const ( | |||
| 	SCM_RIGHTS                     = 0x1 | ||||
| 	SCM_TIMESTAMP                  = 0x2 | ||||
| 	SCM_TIME_INFO                  = 0x7 | ||||
| 	SEEK_CUR                       = 0x1 | ||||
| 	SEEK_DATA                      = 0x3 | ||||
| 	SEEK_END                       = 0x2 | ||||
| 	SEEK_HOLE                      = 0x4 | ||||
| 	SEEK_SET                       = 0x0 | ||||
| 	SHUT_RD                        = 0x0 | ||||
| 	SHUT_RDWR                      = 0x2 | ||||
| 	SHUT_WR                        = 0x1 | ||||
|  |  | |||
|  | @ -1298,6 +1298,11 @@ const ( | |||
| 	SCM_RIGHTS                     = 0x1 | ||||
| 	SCM_TIMESTAMP                  = 0x2 | ||||
| 	SCM_TIME_INFO                  = 0x7 | ||||
| 	SEEK_CUR                       = 0x1 | ||||
| 	SEEK_DATA                      = 0x3 | ||||
| 	SEEK_END                       = 0x2 | ||||
| 	SEEK_HOLE                      = 0x4 | ||||
| 	SEEK_SET                       = 0x0 | ||||
| 	SHUT_RD                        = 0x0 | ||||
| 	SHUT_RDWR                      = 0x2 | ||||
| 	SHUT_WR                        = 0x1 | ||||
|  |  | |||
|  | @ -1276,6 +1276,11 @@ const ( | |||
| 	SCM_CREDS                      = 0x3 | ||||
| 	SCM_RIGHTS                     = 0x1 | ||||
| 	SCM_TIMESTAMP                  = 0x2 | ||||
| 	SEEK_CUR                       = 0x1 | ||||
| 	SEEK_DATA                      = 0x3 | ||||
| 	SEEK_END                       = 0x2 | ||||
| 	SEEK_HOLE                      = 0x4 | ||||
| 	SEEK_SET                       = 0x0 | ||||
| 	SHUT_RD                        = 0x0 | ||||
| 	SHUT_RDWR                      = 0x2 | ||||
| 	SHUT_WR                        = 0x1 | ||||
|  |  | |||
|  | @ -1298,6 +1298,11 @@ const ( | |||
| 	SCM_RIGHTS                     = 0x1 | ||||
| 	SCM_TIMESTAMP                  = 0x2 | ||||
| 	SCM_TIME_INFO                  = 0x7 | ||||
| 	SEEK_CUR                       = 0x1 | ||||
| 	SEEK_DATA                      = 0x3 | ||||
| 	SEEK_END                       = 0x2 | ||||
| 	SEEK_HOLE                      = 0x4 | ||||
| 	SEEK_SET                       = 0x0 | ||||
| 	SHUT_RD                        = 0x0 | ||||
| 	SHUT_RDWR                      = 0x2 | ||||
| 	SHUT_WR                        = 0x1 | ||||
|  |  | |||
|  | @ -1566,6 +1566,59 @@ const ( | |||
| 	NETLINK_XFRM                                = 0x6 | ||||
| 	NETNSA_MAX                                  = 0x5 | ||||
| 	NETNSA_NSID_NOT_ASSIGNED                    = -0x1 | ||||
| 	NFC_ATR_REQ_GB_MAXSIZE                      = 0x30 | ||||
| 	NFC_ATR_REQ_MAXSIZE                         = 0x40 | ||||
| 	NFC_ATR_RES_GB_MAXSIZE                      = 0x2f | ||||
| 	NFC_ATR_RES_MAXSIZE                         = 0x40 | ||||
| 	NFC_COMM_ACTIVE                             = 0x0 | ||||
| 	NFC_COMM_PASSIVE                            = 0x1 | ||||
| 	NFC_DEVICE_NAME_MAXSIZE                     = 0x8 | ||||
| 	NFC_DIRECTION_RX                            = 0x0 | ||||
| 	NFC_DIRECTION_TX                            = 0x1 | ||||
| 	NFC_FIRMWARE_NAME_MAXSIZE                   = 0x20 | ||||
| 	NFC_GB_MAXSIZE                              = 0x30 | ||||
| 	NFC_GENL_MCAST_EVENT_NAME                   = "events" | ||||
| 	NFC_GENL_NAME                               = "nfc" | ||||
| 	NFC_GENL_VERSION                            = 0x1 | ||||
| 	NFC_HEADER_SIZE                             = 0x1 | ||||
| 	NFC_ISO15693_UID_MAXSIZE                    = 0x8 | ||||
| 	NFC_LLCP_MAX_SERVICE_NAME                   = 0x3f | ||||
| 	NFC_LLCP_MIUX                               = 0x1 | ||||
| 	NFC_LLCP_REMOTE_LTO                         = 0x3 | ||||
| 	NFC_LLCP_REMOTE_MIU                         = 0x2 | ||||
| 	NFC_LLCP_REMOTE_RW                          = 0x4 | ||||
| 	NFC_LLCP_RW                                 = 0x0 | ||||
| 	NFC_NFCID1_MAXSIZE                          = 0xa | ||||
| 	NFC_NFCID2_MAXSIZE                          = 0x8 | ||||
| 	NFC_NFCID3_MAXSIZE                          = 0xa | ||||
| 	NFC_PROTO_FELICA                            = 0x3 | ||||
| 	NFC_PROTO_FELICA_MASK                       = 0x8 | ||||
| 	NFC_PROTO_ISO14443                          = 0x4 | ||||
| 	NFC_PROTO_ISO14443_B                        = 0x6 | ||||
| 	NFC_PROTO_ISO14443_B_MASK                   = 0x40 | ||||
| 	NFC_PROTO_ISO14443_MASK                     = 0x10 | ||||
| 	NFC_PROTO_ISO15693                          = 0x7 | ||||
| 	NFC_PROTO_ISO15693_MASK                     = 0x80 | ||||
| 	NFC_PROTO_JEWEL                             = 0x1 | ||||
| 	NFC_PROTO_JEWEL_MASK                        = 0x2 | ||||
| 	NFC_PROTO_MAX                               = 0x8 | ||||
| 	NFC_PROTO_MIFARE                            = 0x2 | ||||
| 	NFC_PROTO_MIFARE_MASK                       = 0x4 | ||||
| 	NFC_PROTO_NFC_DEP                           = 0x5 | ||||
| 	NFC_PROTO_NFC_DEP_MASK                      = 0x20 | ||||
| 	NFC_RAW_HEADER_SIZE                         = 0x2 | ||||
| 	NFC_RF_INITIATOR                            = 0x0 | ||||
| 	NFC_RF_NONE                                 = 0x2 | ||||
| 	NFC_RF_TARGET                               = 0x1 | ||||
| 	NFC_SENSB_RES_MAXSIZE                       = 0xc | ||||
| 	NFC_SENSF_RES_MAXSIZE                       = 0x12 | ||||
| 	NFC_SE_DISABLED                             = 0x0 | ||||
| 	NFC_SE_EMBEDDED                             = 0x2 | ||||
| 	NFC_SE_ENABLED                              = 0x1 | ||||
| 	NFC_SE_UICC                                 = 0x1 | ||||
| 	NFC_SOCKPROTO_LLCP                          = 0x1 | ||||
| 	NFC_SOCKPROTO_MAX                           = 0x2 | ||||
| 	NFC_SOCKPROTO_RAW                           = 0x0 | ||||
| 	NFNETLINK_V0                                = 0x0 | ||||
| 	NFNLGRP_ACCT_QUOTA                          = 0x8 | ||||
| 	NFNLGRP_CONNTRACK_DESTROY                   = 0x3 | ||||
|  | @ -1991,6 +2044,11 @@ const ( | |||
| 	QNX4_SUPER_MAGIC                            = 0x2f | ||||
| 	QNX6_SUPER_MAGIC                            = 0x68191122 | ||||
| 	RAMFS_MAGIC                                 = 0x858458f6 | ||||
| 	RAW_PAYLOAD_DIGITAL                         = 0x3 | ||||
| 	RAW_PAYLOAD_HCI                             = 0x2 | ||||
| 	RAW_PAYLOAD_LLCP                            = 0x0 | ||||
| 	RAW_PAYLOAD_NCI                             = 0x1 | ||||
| 	RAW_PAYLOAD_PROPRIETARY                     = 0x4 | ||||
| 	RDTGROUP_SUPER_MAGIC                        = 0x7655821 | ||||
| 	REISERFS_SUPER_MAGIC                        = 0x52654973 | ||||
| 	RENAME_EXCHANGE                             = 0x2 | ||||
|  | @ -2226,6 +2284,12 @@ const ( | |||
| 	SECCOMP_MODE_FILTER                         = 0x2 | ||||
| 	SECCOMP_MODE_STRICT                         = 0x1 | ||||
| 	SECURITYFS_MAGIC                            = 0x73636673 | ||||
| 	SEEK_CUR                                    = 0x1 | ||||
| 	SEEK_DATA                                   = 0x3 | ||||
| 	SEEK_END                                    = 0x2 | ||||
| 	SEEK_HOLE                                   = 0x4 | ||||
| 	SEEK_MAX                                    = 0x4 | ||||
| 	SEEK_SET                                    = 0x0 | ||||
| 	SELINUX_MAGIC                               = 0xf97cff8c | ||||
| 	SHUT_RD                                     = 0x0 | ||||
| 	SHUT_RDWR                                   = 0x2 | ||||
|  |  | |||
|  | @ -535,3 +535,107 @@ type CtlInfo struct { | |||
| 	Id   uint32 | ||||
| 	Name [96]byte | ||||
| } | ||||
| 
 | ||||
| const SizeofKinfoProc = 0x288 | ||||
| 
 | ||||
| type Eproc struct { | ||||
| 	Paddr   uintptr | ||||
| 	Sess    uintptr | ||||
| 	Pcred   Pcred | ||||
| 	Ucred   Ucred | ||||
| 	Vm      Vmspace | ||||
| 	Ppid    int32 | ||||
| 	Pgid    int32 | ||||
| 	Jobc    int16 | ||||
| 	Tdev    int32 | ||||
| 	Tpgid   int32 | ||||
| 	Tsess   uintptr | ||||
| 	Wmesg   [8]int8 | ||||
| 	Xsize   int32 | ||||
| 	Xrssize int16 | ||||
| 	Xccount int16 | ||||
| 	Xswrss  int16 | ||||
| 	Flag    int32 | ||||
| 	Login   [12]int8 | ||||
| 	Spare   [4]int32 | ||||
| 	_       [4]byte | ||||
| } | ||||
| 
 | ||||
| type ExternProc struct { | ||||
| 	P_starttime Timeval | ||||
| 	P_vmspace   *Vmspace | ||||
| 	P_sigacts   uintptr | ||||
| 	P_flag      int32 | ||||
| 	P_stat      int8 | ||||
| 	P_pid       int32 | ||||
| 	P_oppid     int32 | ||||
| 	P_dupfd     int32 | ||||
| 	User_stack  *int8 | ||||
| 	Exit_thread *byte | ||||
| 	P_debugger  int32 | ||||
| 	Sigwait     int32 | ||||
| 	P_estcpu    uint32 | ||||
| 	P_cpticks   int32 | ||||
| 	P_pctcpu    uint32 | ||||
| 	P_wchan     *byte | ||||
| 	P_wmesg     *int8 | ||||
| 	P_swtime    uint32 | ||||
| 	P_slptime   uint32 | ||||
| 	P_realtimer Itimerval | ||||
| 	P_rtime     Timeval | ||||
| 	P_uticks    uint64 | ||||
| 	P_sticks    uint64 | ||||
| 	P_iticks    uint64 | ||||
| 	P_traceflag int32 | ||||
| 	P_tracep    uintptr | ||||
| 	P_siglist   int32 | ||||
| 	P_textvp    uintptr | ||||
| 	P_holdcnt   int32 | ||||
| 	P_sigmask   uint32 | ||||
| 	P_sigignore uint32 | ||||
| 	P_sigcatch  uint32 | ||||
| 	P_priority  uint8 | ||||
| 	P_usrpri    uint8 | ||||
| 	P_nice      int8 | ||||
| 	P_comm      [17]int8 | ||||
| 	P_pgrp      uintptr | ||||
| 	P_addr      uintptr | ||||
| 	P_xstat     uint16 | ||||
| 	P_acflag    uint16 | ||||
| 	P_ru        *Rusage | ||||
| } | ||||
| 
 | ||||
| type Itimerval struct { | ||||
| 	Interval Timeval | ||||
| 	Value    Timeval | ||||
| } | ||||
| 
 | ||||
| type KinfoProc struct { | ||||
| 	Proc  ExternProc | ||||
| 	Eproc Eproc | ||||
| } | ||||
| 
 | ||||
| type Vmspace struct { | ||||
| 	Dummy  int32 | ||||
| 	Dummy2 *int8 | ||||
| 	Dummy3 [5]int32 | ||||
| 	Dummy4 [3]*int8 | ||||
| } | ||||
| 
 | ||||
| type Pcred struct { | ||||
| 	Pc_lock  [72]int8 | ||||
| 	Pc_ucred uintptr | ||||
| 	P_ruid   uint32 | ||||
| 	P_svuid  uint32 | ||||
| 	P_rgid   uint32 | ||||
| 	P_svgid  uint32 | ||||
| 	P_refcnt int32 | ||||
| 	_        [4]byte | ||||
| } | ||||
| 
 | ||||
| type Ucred struct { | ||||
| 	Ref     int32 | ||||
| 	Uid     uint32 | ||||
| 	Ngroups int16 | ||||
| 	Groups  [16]uint32 | ||||
| } | ||||
|  |  | |||
|  | @ -535,3 +535,107 @@ type CtlInfo struct { | |||
| 	Id   uint32 | ||||
| 	Name [96]byte | ||||
| } | ||||
| 
 | ||||
| const SizeofKinfoProc = 0x288 | ||||
| 
 | ||||
| type Eproc struct { | ||||
| 	Paddr   uintptr | ||||
| 	Sess    uintptr | ||||
| 	Pcred   Pcred | ||||
| 	Ucred   Ucred | ||||
| 	Vm      Vmspace | ||||
| 	Ppid    int32 | ||||
| 	Pgid    int32 | ||||
| 	Jobc    int16 | ||||
| 	Tdev    int32 | ||||
| 	Tpgid   int32 | ||||
| 	Tsess   uintptr | ||||
| 	Wmesg   [8]int8 | ||||
| 	Xsize   int32 | ||||
| 	Xrssize int16 | ||||
| 	Xccount int16 | ||||
| 	Xswrss  int16 | ||||
| 	Flag    int32 | ||||
| 	Login   [12]int8 | ||||
| 	Spare   [4]int32 | ||||
| 	_       [4]byte | ||||
| } | ||||
| 
 | ||||
| type ExternProc struct { | ||||
| 	P_starttime Timeval | ||||
| 	P_vmspace   *Vmspace | ||||
| 	P_sigacts   uintptr | ||||
| 	P_flag      int32 | ||||
| 	P_stat      int8 | ||||
| 	P_pid       int32 | ||||
| 	P_oppid     int32 | ||||
| 	P_dupfd     int32 | ||||
| 	User_stack  *int8 | ||||
| 	Exit_thread *byte | ||||
| 	P_debugger  int32 | ||||
| 	Sigwait     int32 | ||||
| 	P_estcpu    uint32 | ||||
| 	P_cpticks   int32 | ||||
| 	P_pctcpu    uint32 | ||||
| 	P_wchan     *byte | ||||
| 	P_wmesg     *int8 | ||||
| 	P_swtime    uint32 | ||||
| 	P_slptime   uint32 | ||||
| 	P_realtimer Itimerval | ||||
| 	P_rtime     Timeval | ||||
| 	P_uticks    uint64 | ||||
| 	P_sticks    uint64 | ||||
| 	P_iticks    uint64 | ||||
| 	P_traceflag int32 | ||||
| 	P_tracep    uintptr | ||||
| 	P_siglist   int32 | ||||
| 	P_textvp    uintptr | ||||
| 	P_holdcnt   int32 | ||||
| 	P_sigmask   uint32 | ||||
| 	P_sigignore uint32 | ||||
| 	P_sigcatch  uint32 | ||||
| 	P_priority  uint8 | ||||
| 	P_usrpri    uint8 | ||||
| 	P_nice      int8 | ||||
| 	P_comm      [17]int8 | ||||
| 	P_pgrp      uintptr | ||||
| 	P_addr      uintptr | ||||
| 	P_xstat     uint16 | ||||
| 	P_acflag    uint16 | ||||
| 	P_ru        *Rusage | ||||
| } | ||||
| 
 | ||||
| type Itimerval struct { | ||||
| 	Interval Timeval | ||||
| 	Value    Timeval | ||||
| } | ||||
| 
 | ||||
| type KinfoProc struct { | ||||
| 	Proc  ExternProc | ||||
| 	Eproc Eproc | ||||
| } | ||||
| 
 | ||||
| type Vmspace struct { | ||||
| 	Dummy  int32 | ||||
| 	Dummy2 *int8 | ||||
| 	Dummy3 [5]int32 | ||||
| 	Dummy4 [3]*int8 | ||||
| } | ||||
| 
 | ||||
| type Pcred struct { | ||||
| 	Pc_lock  [72]int8 | ||||
| 	Pc_ucred uintptr | ||||
| 	P_ruid   uint32 | ||||
| 	P_svuid  uint32 | ||||
| 	P_rgid   uint32 | ||||
| 	P_svgid  uint32 | ||||
| 	P_refcnt int32 | ||||
| 	_        [4]byte | ||||
| } | ||||
| 
 | ||||
| type Ucred struct { | ||||
| 	Ref     int32 | ||||
| 	Uid     uint32 | ||||
| 	Ngroups int16 | ||||
| 	Groups  [16]uint32 | ||||
| } | ||||
|  |  | |||
|  | @ -431,6 +431,9 @@ type Winsize struct { | |||
| const ( | ||||
| 	AT_FDCWD            = 0xfffafdcd | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x1 | ||||
| 	AT_REMOVEDIR        = 0x2 | ||||
| 	AT_EACCESS          = 0x4 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -672,9 +672,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -675,9 +675,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -656,9 +656,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -653,9 +653,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -351,6 +351,13 @@ type RawSockaddrIUCV struct { | |||
| 	Name    [8]int8 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddrNFC struct { | ||||
| 	Sa_family    uint16 | ||||
| 	Dev_idx      uint32 | ||||
| 	Target_idx   uint32 | ||||
| 	Nfc_protocol uint32 | ||||
| } | ||||
| 
 | ||||
| type _Socklen uint32 | ||||
| 
 | ||||
| type Linger struct { | ||||
|  | @ -464,6 +471,7 @@ const ( | |||
| 	SizeofSockaddrL2TPIP    = 0x10 | ||||
| 	SizeofSockaddrL2TPIP6   = 0x20 | ||||
| 	SizeofSockaddrIUCV      = 0x20 | ||||
| 	SizeofSockaddrNFC       = 0x10 | ||||
| 	SizeofLinger            = 0x8 | ||||
| 	SizeofIPMreq            = 0x8 | ||||
| 	SizeofIPMreqn           = 0xc | ||||
|  | @ -1765,6 +1773,8 @@ const ( | |||
| 	NFPROTO_NUMPROTO = 0xd | ||||
| ) | ||||
| 
 | ||||
| const SO_ORIGINAL_DST = 0x50 | ||||
| 
 | ||||
| type Nfgenmsg struct { | ||||
| 	Nfgen_family uint8 | ||||
| 	Version      uint8 | ||||
|  | @ -3828,3 +3838,72 @@ const ( | |||
| 	MTD_FILE_MODE_OTP_USER    = 0x2 | ||||
| 	MTD_FILE_MODE_RAW         = 0x3 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	NFC_CMD_UNSPEC                    = 0x0 | ||||
| 	NFC_CMD_GET_DEVICE                = 0x1 | ||||
| 	NFC_CMD_DEV_UP                    = 0x2 | ||||
| 	NFC_CMD_DEV_DOWN                  = 0x3 | ||||
| 	NFC_CMD_DEP_LINK_UP               = 0x4 | ||||
| 	NFC_CMD_DEP_LINK_DOWN             = 0x5 | ||||
| 	NFC_CMD_START_POLL                = 0x6 | ||||
| 	NFC_CMD_STOP_POLL                 = 0x7 | ||||
| 	NFC_CMD_GET_TARGET                = 0x8 | ||||
| 	NFC_EVENT_TARGETS_FOUND           = 0x9 | ||||
| 	NFC_EVENT_DEVICE_ADDED            = 0xa | ||||
| 	NFC_EVENT_DEVICE_REMOVED          = 0xb | ||||
| 	NFC_EVENT_TARGET_LOST             = 0xc | ||||
| 	NFC_EVENT_TM_ACTIVATED            = 0xd | ||||
| 	NFC_EVENT_TM_DEACTIVATED          = 0xe | ||||
| 	NFC_CMD_LLC_GET_PARAMS            = 0xf | ||||
| 	NFC_CMD_LLC_SET_PARAMS            = 0x10 | ||||
| 	NFC_CMD_ENABLE_SE                 = 0x11 | ||||
| 	NFC_CMD_DISABLE_SE                = 0x12 | ||||
| 	NFC_CMD_LLC_SDREQ                 = 0x13 | ||||
| 	NFC_EVENT_LLC_SDRES               = 0x14 | ||||
| 	NFC_CMD_FW_DOWNLOAD               = 0x15 | ||||
| 	NFC_EVENT_SE_ADDED                = 0x16 | ||||
| 	NFC_EVENT_SE_REMOVED              = 0x17 | ||||
| 	NFC_EVENT_SE_CONNECTIVITY         = 0x18 | ||||
| 	NFC_EVENT_SE_TRANSACTION          = 0x19 | ||||
| 	NFC_CMD_GET_SE                    = 0x1a | ||||
| 	NFC_CMD_SE_IO                     = 0x1b | ||||
| 	NFC_CMD_ACTIVATE_TARGET           = 0x1c | ||||
| 	NFC_CMD_VENDOR                    = 0x1d | ||||
| 	NFC_CMD_DEACTIVATE_TARGET         = 0x1e | ||||
| 	NFC_ATTR_UNSPEC                   = 0x0 | ||||
| 	NFC_ATTR_DEVICE_INDEX             = 0x1 | ||||
| 	NFC_ATTR_DEVICE_NAME              = 0x2 | ||||
| 	NFC_ATTR_PROTOCOLS                = 0x3 | ||||
| 	NFC_ATTR_TARGET_INDEX             = 0x4 | ||||
| 	NFC_ATTR_TARGET_SENS_RES          = 0x5 | ||||
| 	NFC_ATTR_TARGET_SEL_RES           = 0x6 | ||||
| 	NFC_ATTR_TARGET_NFCID1            = 0x7 | ||||
| 	NFC_ATTR_TARGET_SENSB_RES         = 0x8 | ||||
| 	NFC_ATTR_TARGET_SENSF_RES         = 0x9 | ||||
| 	NFC_ATTR_COMM_MODE                = 0xa | ||||
| 	NFC_ATTR_RF_MODE                  = 0xb | ||||
| 	NFC_ATTR_DEVICE_POWERED           = 0xc | ||||
| 	NFC_ATTR_IM_PROTOCOLS             = 0xd | ||||
| 	NFC_ATTR_TM_PROTOCOLS             = 0xe | ||||
| 	NFC_ATTR_LLC_PARAM_LTO            = 0xf | ||||
| 	NFC_ATTR_LLC_PARAM_RW             = 0x10 | ||||
| 	NFC_ATTR_LLC_PARAM_MIUX           = 0x11 | ||||
| 	NFC_ATTR_SE                       = 0x12 | ||||
| 	NFC_ATTR_LLC_SDP                  = 0x13 | ||||
| 	NFC_ATTR_FIRMWARE_NAME            = 0x14 | ||||
| 	NFC_ATTR_SE_INDEX                 = 0x15 | ||||
| 	NFC_ATTR_SE_TYPE                  = 0x16 | ||||
| 	NFC_ATTR_SE_AID                   = 0x17 | ||||
| 	NFC_ATTR_FIRMWARE_DOWNLOAD_STATUS = 0x18 | ||||
| 	NFC_ATTR_SE_APDU                  = 0x19 | ||||
| 	NFC_ATTR_TARGET_ISO15693_DSFID    = 0x1a | ||||
| 	NFC_ATTR_TARGET_ISO15693_UID      = 0x1b | ||||
| 	NFC_ATTR_SE_PARAMS                = 0x1c | ||||
| 	NFC_ATTR_VENDOR_ID                = 0x1d | ||||
| 	NFC_ATTR_VENDOR_SUBCMD            = 0x1e | ||||
| 	NFC_ATTR_VENDOR_DATA              = 0x1f | ||||
| 	NFC_SDP_ATTR_UNSPEC               = 0x0 | ||||
| 	NFC_SDP_ATTR_URI                  = 0x1 | ||||
| 	NFC_SDP_ATTR_SAP                  = 0x2 | ||||
| ) | ||||
|  |  | |||
|  | @ -128,6 +128,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint32 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -160,9 +171,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x8 | ||||
| 	SizeofMsghdr  = 0x1c | ||||
| 	SizeofCmsghdr = 0xc | ||||
| 	SizeofSockaddrNFCLLCP = 0x58 | ||||
| 	SizeofIovec           = 0x8 | ||||
| 	SizeofMsghdr          = 0x1c | ||||
| 	SizeofCmsghdr         = 0xc | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -130,6 +130,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -163,9 +174,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -134,6 +134,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint32 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]uint8 | ||||
|  | @ -166,9 +177,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x8 | ||||
| 	SizeofMsghdr  = 0x1c | ||||
| 	SizeofCmsghdr = 0xc | ||||
| 	SizeofSockaddrNFCLLCP = 0x58 | ||||
| 	SizeofIovec           = 0x8 | ||||
| 	SizeofMsghdr          = 0x1c | ||||
| 	SizeofCmsghdr         = 0xc | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -131,6 +131,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -164,9 +175,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -133,6 +133,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint32 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -165,9 +176,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x8 | ||||
| 	SizeofMsghdr  = 0x1c | ||||
| 	SizeofCmsghdr = 0xc | ||||
| 	SizeofSockaddrNFCLLCP = 0x58 | ||||
| 	SizeofIovec           = 0x8 | ||||
| 	SizeofMsghdr          = 0x1c | ||||
| 	SizeofCmsghdr         = 0xc | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -131,6 +131,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -164,9 +175,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -131,6 +131,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -164,9 +175,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -133,6 +133,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint32 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -165,9 +176,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x8 | ||||
| 	SizeofMsghdr  = 0x1c | ||||
| 	SizeofCmsghdr = 0xc | ||||
| 	SizeofSockaddrNFCLLCP = 0x58 | ||||
| 	SizeofIovec           = 0x8 | ||||
| 	SizeofMsghdr          = 0x1c | ||||
| 	SizeofCmsghdr         = 0xc | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -134,6 +134,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint32 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]uint8 | ||||
|  | @ -166,9 +177,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x8 | ||||
| 	SizeofMsghdr  = 0x1c | ||||
| 	SizeofCmsghdr = 0xc | ||||
| 	SizeofSockaddrNFCLLCP = 0x58 | ||||
| 	SizeofIovec           = 0x8 | ||||
| 	SizeofMsghdr          = 0x1c | ||||
| 	SizeofCmsghdr         = 0xc | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -132,6 +132,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]uint8 | ||||
|  | @ -165,9 +176,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -132,6 +132,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]uint8 | ||||
|  | @ -165,9 +176,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -131,6 +131,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]uint8 | ||||
|  | @ -164,9 +175,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -130,6 +130,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x7 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -163,9 +174,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -134,6 +134,17 @@ const ( | |||
| 	FADV_NOREUSE  = 0x5 | ||||
| ) | ||||
| 
 | ||||
| type RawSockaddrNFCLLCP struct { | ||||
| 	Sa_family        uint16 | ||||
| 	Dev_idx          uint32 | ||||
| 	Target_idx       uint32 | ||||
| 	Nfc_protocol     uint32 | ||||
| 	Dsap             uint8 | ||||
| 	Ssap             uint8 | ||||
| 	Service_name     [63]uint8 | ||||
| 	Service_name_len uint64 | ||||
| } | ||||
| 
 | ||||
| type RawSockaddr struct { | ||||
| 	Family uint16 | ||||
| 	Data   [14]int8 | ||||
|  | @ -167,9 +178,10 @@ type Cmsghdr struct { | |||
| } | ||||
| 
 | ||||
| const ( | ||||
| 	SizeofIovec   = 0x10 | ||||
| 	SizeofMsghdr  = 0x38 | ||||
| 	SizeofCmsghdr = 0x10 | ||||
| 	SizeofSockaddrNFCLLCP = 0x60 | ||||
| 	SizeofIovec           = 0x10 | ||||
| 	SizeofMsghdr          = 0x38 | ||||
| 	SizeofCmsghdr         = 0x10 | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  |  | |||
|  | @ -445,8 +445,10 @@ type Ptmget struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -453,8 +453,10 @@ type Ptmget struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -450,8 +450,10 @@ type Ptmget struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -453,8 +453,10 @@ type Ptmget struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_EACCESS          = 0x100 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x200 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x400 | ||||
| 	AT_REMOVEDIR        = 0x800 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -438,8 +438,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_EACCESS          = 0x1 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x2 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_REMOVEDIR        = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -438,8 +438,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_EACCESS          = 0x1 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x2 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_REMOVEDIR        = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -439,8 +439,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_EACCESS          = 0x1 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x2 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_REMOVEDIR        = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -432,8 +432,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_EACCESS          = 0x1 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x2 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_REMOVEDIR        = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -432,8 +432,10 @@ type Winsize struct { | |||
| 
 | ||||
| const ( | ||||
| 	AT_FDCWD            = -0x64 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_EACCESS          = 0x1 | ||||
| 	AT_SYMLINK_NOFOLLOW = 0x2 | ||||
| 	AT_SYMLINK_FOLLOW   = 0x4 | ||||
| 	AT_REMOVEDIR        = 0x8 | ||||
| ) | ||||
| 
 | ||||
| type PollFd struct { | ||||
|  |  | |||
|  | @ -680,7 +680,7 @@ const ( | |||
| 	WTD_CHOICE_CERT    = 5 | ||||
| 
 | ||||
| 	WTD_STATEACTION_IGNORE           = 0x00000000 | ||||
| 	WTD_STATEACTION_VERIFY           = 0x00000010 | ||||
| 	WTD_STATEACTION_VERIFY           = 0x00000001 | ||||
| 	WTD_STATEACTION_CLOSE            = 0x00000002 | ||||
| 	WTD_STATEACTION_AUTO_CACHE       = 0x00000003 | ||||
| 	WTD_STATEACTION_AUTO_CACHE_FLUSH = 0x00000004 | ||||
|  |  | |||
|  | @ -145,7 +145,6 @@ func (r *Reservation) DelayFrom(now time.Time) time.Duration { | |||
| // Cancel is shorthand for CancelAt(time.Now()).
 | ||||
| func (r *Reservation) Cancel() { | ||||
| 	r.CancelAt(time.Now()) | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| // CancelAt indicates that the reservation holder will not perform the reserved action
 | ||||
|  | @ -186,8 +185,6 @@ func (r *Reservation) CancelAt(now time.Time) { | |||
| 			r.lim.lastEvent = prevEvent | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| // Reserve is shorthand for ReserveN(time.Now(), 1).
 | ||||
|  | @ -367,20 +364,13 @@ func (lim *Limiter) advance(now time.Time) (newNow time.Time, newLast time.Time, | |||
| 		last = now | ||||
| 	} | ||||
| 
 | ||||
| 	// Avoid making delta overflow below when last is very old.
 | ||||
| 	maxElapsed := lim.limit.durationFromTokens(float64(lim.burst) - lim.tokens) | ||||
| 	elapsed := now.Sub(last) | ||||
| 	if elapsed > maxElapsed { | ||||
| 		elapsed = maxElapsed | ||||
| 	} | ||||
| 
 | ||||
| 	// Calculate the new number of tokens, due to time that passed.
 | ||||
| 	elapsed := now.Sub(last) | ||||
| 	delta := lim.limit.tokensFromDuration(elapsed) | ||||
| 	tokens := lim.tokens + delta | ||||
| 	if burst := float64(lim.burst); tokens > burst { | ||||
| 		tokens = burst | ||||
| 	} | ||||
| 
 | ||||
| 	return now, last, tokens | ||||
| } | ||||
| 
 | ||||
|  | @ -388,15 +378,11 @@ func (lim *Limiter) advance(now time.Time) (newNow time.Time, newLast time.Time, | |||
| // of time it takes to accumulate them at a rate of limit tokens per second.
 | ||||
| func (limit Limit) durationFromTokens(tokens float64) time.Duration { | ||||
| 	seconds := tokens / float64(limit) | ||||
| 	return time.Nanosecond * time.Duration(1e9*seconds) | ||||
| 	return time.Duration(float64(time.Second) * seconds) | ||||
| } | ||||
| 
 | ||||
| // tokensFromDuration is a unit conversion function from a time duration to the number of tokens
 | ||||
| // which could be accumulated during that duration at a rate of limit tokens per second.
 | ||||
| func (limit Limit) tokensFromDuration(d time.Duration) float64 { | ||||
| 	// Split the integer and fractional parts ourself to minimize rounding errors.
 | ||||
| 	// See golang.org/issues/34861.
 | ||||
| 	sec := float64(d/time.Second) * float64(limit) | ||||
| 	nsec := float64(d%time.Second) * float64(limit) | ||||
| 	return sec + nsec/1e9 | ||||
| 	return d.Seconds() * float64(limit) | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,27 @@ | |||
| Copyright (c) 2012 The Go Authors. All rights reserved. | ||||
| 
 | ||||
| Redistribution and use in source and binary forms, with or without | ||||
| modification, are permitted provided that the following conditions are | ||||
| met: | ||||
| 
 | ||||
|    * Redistributions of source code must retain the above copyright | ||||
| notice, this list of conditions and the following disclaimer. | ||||
|    * Redistributions in binary form must reproduce the above | ||||
| copyright notice, this list of conditions and the following disclaimer | ||||
| in the documentation and/or other materials provided with the | ||||
| distribution. | ||||
|    * Neither the name of Google Inc. nor the names of its | ||||
| contributors may be used to endorse or promote products derived from | ||||
| this software without specific prior written permission. | ||||
| 
 | ||||
| THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
| "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
| LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
| A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
| OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
| SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
| LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
| DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
| THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
| (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
| OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  | @ -0,0 +1,22 @@ | |||
| Additional IP Rights Grant (Patents) | ||||
| 
 | ||||
| "This implementation" means the copyrightable works distributed by | ||||
| Google as part of the Go project. | ||||
| 
 | ||||
| Google 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, | ||||
| transfer and otherwise run, modify and propagate the contents of this | ||||
| implementation of Go, where such license applies only to those patent | ||||
| claims, both currently owned or controlled by Google and acquired in | ||||
| the future, licensable by Google that are necessarily infringed by this | ||||
| implementation of Go.  This grant does not include claims that would be | ||||
| infringed only as a consequence of further modification of this | ||||
| implementation.  If you or your agent or exclusive licensee institute or | ||||
| order or agree to the institution of patent litigation against any | ||||
| entity (including a cross-claim or counterclaim in a lawsuit) alleging | ||||
| that this implementation of Go or any code incorporated within this | ||||
| implementation of Go constitutes direct or contributory patent | ||||
| infringement, or inducement of patent infringement, then any patent | ||||
| rights granted to you under this License for this implementation of Go | ||||
| shall terminate as of the date such litigation is filed. | ||||
							
								
								
									
										12
									
								
								vendor/k8s.io/utils/internal/third_party/forked/golang/net/BUILD.bazel
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										12
									
								
								vendor/k8s.io/utils/internal/third_party/forked/golang/net/BUILD.bazel
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,12 @@ | |||
| load("@io_bazel_rules_go//go:def.bzl", "go_library") | ||||
| 
 | ||||
| go_library( | ||||
|     name = "go_default_library", | ||||
|     srcs = [ | ||||
|         "ip.go", | ||||
|         "parse.go", | ||||
|     ], | ||||
|     importmap = "k8s.io/kops/vendor/k8s.io/utils/internal/third_party/forked/golang/net", | ||||
|     importpath = "k8s.io/utils/internal/third_party/forked/golang/net", | ||||
|     visibility = ["//vendor/k8s.io/utils:__subpackages__"], | ||||
| ) | ||||
|  | @ -0,0 +1,236 @@ | |||
| // Copyright 2009 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.
 | ||||
| 
 | ||||
| // IP address manipulations
 | ||||
| //
 | ||||
| // IPv4 addresses are 4 bytes; IPv6 addresses are 16 bytes.
 | ||||
| // An IPv4 address can be converted to an IPv6 address by
 | ||||
| // adding a canonical prefix (10 zeros, 2 0xFFs).
 | ||||
| // This library accepts either size of byte slice but always
 | ||||
| // returns 16-byte addresses.
 | ||||
| 
 | ||||
| package net | ||||
| 
 | ||||
| ///////////////////////////////////////////////////////////////////////////////
 | ||||
| // NOTE: This file was forked because we need to maintain backwards-compatible
 | ||||
| // IP parsing logic, which was changed in a correct but incompatible way in
 | ||||
| // go-1.17.
 | ||||
| //
 | ||||
| // See https://issue.k8s.io/100895
 | ||||
| ///////////////////////////////////////////////////////////////////////////////
 | ||||
| 
 | ||||
| import ( | ||||
| 	stdnet "net" | ||||
| ) | ||||
| 
 | ||||
| //
 | ||||
| // Lean on the standard net lib as much as possible.
 | ||||
| //
 | ||||
| 
 | ||||
| type IP = stdnet.IP | ||||
| type IPNet = stdnet.IPNet | ||||
| type ParseError = stdnet.ParseError | ||||
| 
 | ||||
| const IPv4len = stdnet.IPv4len | ||||
| const IPv6len = stdnet.IPv6len | ||||
| 
 | ||||
| var CIDRMask = stdnet.CIDRMask | ||||
| var IPv4 = stdnet.IPv4 | ||||
| 
 | ||||
| // Parse IPv4 address (d.d.d.d).
 | ||||
| func parseIPv4(s string) IP { | ||||
| 	var p [IPv4len]byte | ||||
| 	for i := 0; i < IPv4len; i++ { | ||||
| 		if len(s) == 0 { | ||||
| 			// Missing octets.
 | ||||
| 			return nil | ||||
| 		} | ||||
| 		if i > 0 { | ||||
| 			if s[0] != '.' { | ||||
| 				return nil | ||||
| 			} | ||||
| 			s = s[1:] | ||||
| 		} | ||||
| 		n, c, ok := dtoi(s) | ||||
| 		if !ok || n > 0xFF { | ||||
| 			return nil | ||||
| 		} | ||||
| 		//
 | ||||
| 		// NOTE: This correct check was added for go-1.17, but is a
 | ||||
| 		// backwards-incompatible change for kubernetes users, who might have
 | ||||
| 		// stored data which uses these leading zeroes already.
 | ||||
| 		//
 | ||||
| 		// See https://issue.k8s.io/100895
 | ||||
| 		//
 | ||||
| 		//if c > 1 && s[0] == '0' {
 | ||||
| 		//	// Reject non-zero components with leading zeroes.
 | ||||
| 		//	return nil
 | ||||
| 		//}
 | ||||
| 		s = s[c:] | ||||
| 		p[i] = byte(n) | ||||
| 	} | ||||
| 	if len(s) != 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return IPv4(p[0], p[1], p[2], p[3]) | ||||
| } | ||||
| 
 | ||||
| // parseIPv6 parses s as a literal IPv6 address described in RFC 4291
 | ||||
| // and RFC 5952.
 | ||||
| func parseIPv6(s string) (ip IP) { | ||||
| 	ip = make(IP, IPv6len) | ||||
| 	ellipsis := -1 // position of ellipsis in ip
 | ||||
| 
 | ||||
| 	// Might have leading ellipsis
 | ||||
| 	if len(s) >= 2 && s[0] == ':' && s[1] == ':' { | ||||
| 		ellipsis = 0 | ||||
| 		s = s[2:] | ||||
| 		// Might be only ellipsis
 | ||||
| 		if len(s) == 0 { | ||||
| 			return ip | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Loop, parsing hex numbers followed by colon.
 | ||||
| 	i := 0 | ||||
| 	for i < IPv6len { | ||||
| 		// Hex number.
 | ||||
| 		n, c, ok := xtoi(s) | ||||
| 		if !ok || n > 0xFFFF { | ||||
| 			return nil | ||||
| 		} | ||||
| 
 | ||||
| 		// If followed by dot, might be in trailing IPv4.
 | ||||
| 		if c < len(s) && s[c] == '.' { | ||||
| 			if ellipsis < 0 && i != IPv6len-IPv4len { | ||||
| 				// Not the right place.
 | ||||
| 				return nil | ||||
| 			} | ||||
| 			if i+IPv4len > IPv6len { | ||||
| 				// Not enough room.
 | ||||
| 				return nil | ||||
| 			} | ||||
| 			ip4 := parseIPv4(s) | ||||
| 			if ip4 == nil { | ||||
| 				return nil | ||||
| 			} | ||||
| 			ip[i] = ip4[12] | ||||
| 			ip[i+1] = ip4[13] | ||||
| 			ip[i+2] = ip4[14] | ||||
| 			ip[i+3] = ip4[15] | ||||
| 			s = "" | ||||
| 			i += IPv4len | ||||
| 			break | ||||
| 		} | ||||
| 
 | ||||
| 		// Save this 16-bit chunk.
 | ||||
| 		ip[i] = byte(n >> 8) | ||||
| 		ip[i+1] = byte(n) | ||||
| 		i += 2 | ||||
| 
 | ||||
| 		// Stop at end of string.
 | ||||
| 		s = s[c:] | ||||
| 		if len(s) == 0 { | ||||
| 			break | ||||
| 		} | ||||
| 
 | ||||
| 		// Otherwise must be followed by colon and more.
 | ||||
| 		if s[0] != ':' || len(s) == 1 { | ||||
| 			return nil | ||||
| 		} | ||||
| 		s = s[1:] | ||||
| 
 | ||||
| 		// Look for ellipsis.
 | ||||
| 		if s[0] == ':' { | ||||
| 			if ellipsis >= 0 { // already have one
 | ||||
| 				return nil | ||||
| 			} | ||||
| 			ellipsis = i | ||||
| 			s = s[1:] | ||||
| 			if len(s) == 0 { // can be at end
 | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Must have used entire string.
 | ||||
| 	if len(s) != 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 
 | ||||
| 	// If didn't parse enough, expand ellipsis.
 | ||||
| 	if i < IPv6len { | ||||
| 		if ellipsis < 0 { | ||||
| 			return nil | ||||
| 		} | ||||
| 		n := IPv6len - i | ||||
| 		for j := i - 1; j >= ellipsis; j-- { | ||||
| 			ip[j+n] = ip[j] | ||||
| 		} | ||||
| 		for j := ellipsis + n - 1; j >= ellipsis; j-- { | ||||
| 			ip[j] = 0 | ||||
| 		} | ||||
| 	} else if ellipsis >= 0 { | ||||
| 		// Ellipsis must represent at least one 0 group.
 | ||||
| 		return nil | ||||
| 	} | ||||
| 	return ip | ||||
| } | ||||
| 
 | ||||
| // ParseIP parses s as an IP address, returning the result.
 | ||||
| // The string s can be in IPv4 dotted decimal ("192.0.2.1"), IPv6
 | ||||
| // ("2001:db8::68"), or IPv4-mapped IPv6 ("::ffff:192.0.2.1") form.
 | ||||
| // If s is not a valid textual representation of an IP address,
 | ||||
| // ParseIP returns nil.
 | ||||
| func ParseIP(s string) IP { | ||||
| 	for i := 0; i < len(s); i++ { | ||||
| 		switch s[i] { | ||||
| 		case '.': | ||||
| 			return parseIPv4(s) | ||||
| 		case ':': | ||||
| 			return parseIPv6(s) | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // ParseCIDR parses s as a CIDR notation IP address and prefix length,
 | ||||
| // like "192.0.2.0/24" or "2001:db8::/32", as defined in
 | ||||
| // RFC 4632 and RFC 4291.
 | ||||
| //
 | ||||
| // It returns the IP address and the network implied by the IP and
 | ||||
| // prefix length.
 | ||||
| // For example, ParseCIDR("192.0.2.1/24") returns the IP address
 | ||||
| // 192.0.2.1 and the network 192.0.2.0/24.
 | ||||
| func ParseCIDR(s string) (IP, *IPNet, error) { | ||||
| 	i := indexByteString(s, '/') | ||||
| 	if i < 0 { | ||||
| 		return nil, nil, &ParseError{Type: "CIDR address", Text: s} | ||||
| 	} | ||||
| 	addr, mask := s[:i], s[i+1:] | ||||
| 	iplen := IPv4len | ||||
| 	ip := parseIPv4(addr) | ||||
| 	if ip == nil { | ||||
| 		iplen = IPv6len | ||||
| 		ip = parseIPv6(addr) | ||||
| 	} | ||||
| 	n, i, ok := dtoi(mask) | ||||
| 	if ip == nil || !ok || i != len(mask) || n < 0 || n > 8*iplen { | ||||
| 		return nil, nil, &ParseError{Type: "CIDR address", Text: s} | ||||
| 	} | ||||
| 	m := CIDRMask(n, 8*iplen) | ||||
| 	return ip, &IPNet{IP: ip.Mask(m), Mask: m}, nil | ||||
| } | ||||
| 
 | ||||
| // This is copied from go/src/internal/bytealg, which includes versions
 | ||||
| // optimized for various platforms.  Those optimizations are elided here so we
 | ||||
| // don't have to maintain them.
 | ||||
| func indexByteString(s string, c byte) int { | ||||
| 	for i := 0; i < len(s); i++ { | ||||
| 		if s[i] == c { | ||||
| 			return i | ||||
| 		} | ||||
| 	} | ||||
| 	return -1 | ||||
| } | ||||
							
								
								
									
										59
									
								
								vendor/k8s.io/utils/internal/third_party/forked/golang/net/parse.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										59
									
								
								vendor/k8s.io/utils/internal/third_party/forked/golang/net/parse.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,59 @@ | |||
| // Copyright 2009 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.
 | ||||
| 
 | ||||
| // Simple file i/o and string manipulation, to avoid
 | ||||
| // depending on strconv and bufio and strings.
 | ||||
| 
 | ||||
| package net | ||||
| 
 | ||||
| ///////////////////////////////////////////////////////////////////////////////
 | ||||
| // NOTE: This file was forked because it is used by other code that needed to
 | ||||
| // be forked, not because it is used on its own.
 | ||||
| ///////////////////////////////////////////////////////////////////////////////
 | ||||
| 
 | ||||
| // Bigger than we need, not too big to worry about overflow
 | ||||
| const big = 0xFFFFFF | ||||
| 
 | ||||
| // Decimal to integer.
 | ||||
| // Returns number, characters consumed, success.
 | ||||
| func dtoi(s string) (n int, i int, ok bool) { | ||||
| 	n = 0 | ||||
| 	for i = 0; i < len(s) && '0' <= s[i] && s[i] <= '9'; i++ { | ||||
| 		n = n*10 + int(s[i]-'0') | ||||
| 		if n >= big { | ||||
| 			return big, i, false | ||||
| 		} | ||||
| 	} | ||||
| 	if i == 0 { | ||||
| 		return 0, 0, false | ||||
| 	} | ||||
| 	return n, i, true | ||||
| } | ||||
| 
 | ||||
| // Hexadecimal to integer.
 | ||||
| // Returns number, characters consumed, success.
 | ||||
| func xtoi(s string) (n int, i int, ok bool) { | ||||
| 	n = 0 | ||||
| 	for i = 0; i < len(s); i++ { | ||||
| 		if '0' <= s[i] && s[i] <= '9' { | ||||
| 			n *= 16 | ||||
| 			n += int(s[i] - '0') | ||||
| 		} else if 'a' <= s[i] && s[i] <= 'f' { | ||||
| 			n *= 16 | ||||
| 			n += int(s[i]-'a') + 10 | ||||
| 		} else if 'A' <= s[i] && s[i] <= 'F' { | ||||
| 			n *= 16 | ||||
| 			n += int(s[i]-'A') + 10 | ||||
| 		} else { | ||||
| 			break | ||||
| 		} | ||||
| 		if n >= big { | ||||
| 			return 0, i, false | ||||
| 		} | ||||
| 	} | ||||
| 	if i == 0 { | ||||
| 		return 0, i, false | ||||
| 	} | ||||
| 	return n, i, true | ||||
| } | ||||
|  | @ -5,9 +5,11 @@ go_library( | |||
|     srcs = [ | ||||
|         "ipnet.go", | ||||
|         "net.go", | ||||
|         "parse.go", | ||||
|         "port.go", | ||||
|     ], | ||||
|     importmap = "k8s.io/kops/vendor/k8s.io/utils/net", | ||||
|     importpath = "k8s.io/utils/net", | ||||
|     visibility = ["//visibility:public"], | ||||
|     deps = ["//vendor/k8s.io/utils/internal/third_party/forked/golang/net:go_default_library"], | ||||
| ) | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ func ParseIPNets(specs ...string) (IPNetSet, error) { | |||
| 	ipnetset := make(IPNetSet) | ||||
| 	for _, spec := range specs { | ||||
| 		spec = strings.TrimSpace(spec) | ||||
| 		_, ipnet, err := net.ParseCIDR(spec) | ||||
| 		_, ipnet, err := ParseCIDRSloppy(spec) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
|  | @ -128,7 +128,7 @@ type IPSet map[string]net.IP | |||
| func ParseIPSet(items ...string) (IPSet, error) { | ||||
| 	ipset := make(IPSet) | ||||
| 	for _, item := range items { | ||||
| 		ip := net.ParseIP(strings.TrimSpace(item)) | ||||
| 		ip := ParseIPSloppy(strings.TrimSpace(item)) | ||||
| 		if ip == nil { | ||||
| 			return nil, fmt.Errorf("error parsing IP %q", item) | ||||
| 		} | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ import ( | |||
| func ParseCIDRs(cidrsString []string) ([]*net.IPNet, error) { | ||||
| 	cidrs := make([]*net.IPNet, 0, len(cidrsString)) | ||||
| 	for _, cidrString := range cidrsString { | ||||
| 		_, cidr, err := net.ParseCIDR(cidrString) | ||||
| 		_, cidr, err := ParseCIDRSloppy(cidrString) | ||||
| 		if err != nil { | ||||
| 			return nil, fmt.Errorf("failed to parse cidr value:%q with error:%v", cidrString, err) | ||||
| 		} | ||||
|  | @ -71,7 +71,7 @@ func IsDualStackIPs(ips []net.IP) (bool, error) { | |||
| func IsDualStackIPStrings(ips []string) (bool, error) { | ||||
| 	parsedIPs := make([]net.IP, 0, len(ips)) | ||||
| 	for _, ip := range ips { | ||||
| 		parsedIP := net.ParseIP(ip) | ||||
| 		parsedIP := ParseIPSloppy(ip) | ||||
| 		parsedIPs = append(parsedIPs, parsedIP) | ||||
| 	} | ||||
| 	return IsDualStackIPs(parsedIPs) | ||||
|  | @ -120,14 +120,14 @@ func IsIPv6(netIP net.IP) bool { | |||
| 
 | ||||
| // IsIPv6String returns if ip is IPv6.
 | ||||
| func IsIPv6String(ip string) bool { | ||||
| 	netIP := net.ParseIP(ip) | ||||
| 	netIP := ParseIPSloppy(ip) | ||||
| 	return IsIPv6(netIP) | ||||
| } | ||||
| 
 | ||||
| // IsIPv6CIDRString returns if cidr is IPv6.
 | ||||
| // This assumes cidr is a valid CIDR.
 | ||||
| func IsIPv6CIDRString(cidr string) bool { | ||||
| 	ip, _, _ := net.ParseCIDR(cidr) | ||||
| 	ip, _, _ := ParseCIDRSloppy(cidr) | ||||
| 	return IsIPv6(ip) | ||||
| } | ||||
| 
 | ||||
|  | @ -144,7 +144,7 @@ func IsIPv4(netIP net.IP) bool { | |||
| 
 | ||||
| // IsIPv4String returns if ip is IPv4.
 | ||||
| func IsIPv4String(ip string) bool { | ||||
| 	netIP := net.ParseIP(ip) | ||||
| 	netIP := ParseIPSloppy(ip) | ||||
| 	return IsIPv4(netIP) | ||||
| } | ||||
| 
 | ||||
|  | @ -157,7 +157,7 @@ func IsIPv4CIDR(cidr *net.IPNet) bool { | |||
| // IsIPv4CIDRString returns if cidr is IPv4.
 | ||||
| // This assumes cidr is a valid CIDR.
 | ||||
| func IsIPv4CIDRString(cidr string) bool { | ||||
| 	ip, _, _ := net.ParseCIDR(cidr) | ||||
| 	ip, _, _ := ParseCIDRSloppy(cidr) | ||||
| 	return IsIPv4(ip) | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,33 @@ | |||
| /* | ||||
| Copyright 2021 The Kubernetes 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 net | ||||
| 
 | ||||
| import ( | ||||
| 	forkednet "k8s.io/utils/internal/third_party/forked/golang/net" | ||||
| ) | ||||
| 
 | ||||
| // ParseIPSloppy is identical to Go's standard net.ParseIP, except that it allows
 | ||||
| // leading '0' characters on numbers.  Go used to allow this and then changed
 | ||||
| // the behavior in 1.17.  We're choosing to keep it for compat with potential
 | ||||
| // stored values.
 | ||||
| var ParseIPSloppy = forkednet.ParseIP | ||||
| 
 | ||||
| // ParseCIDRSloppy is identical to Go's standard net.ParseCIDR, except that it allows
 | ||||
| // leading '0' characters on numbers.  Go used to allow this and then changed
 | ||||
| // the behavior in 1.17.  We're choosing to keep it for compat with potential
 | ||||
| // stored values.
 | ||||
| var ParseCIDRSloppy = forkednet.ParseCIDR | ||||
|  | @ -71,7 +71,7 @@ func NewLocalPort(desc, ip string, ipFamily IPFamily, port int, protocol Protoco | |||
| 		return nil, fmt.Errorf("Invalid IP family %s", ipFamily) | ||||
| 	} | ||||
| 	if ip != "" { | ||||
| 		parsedIP := net.ParseIP(ip) | ||||
| 		parsedIP := ParseIPSloppy(ip) | ||||
| 		if parsedIP == nil { | ||||
| 			return nil, fmt.Errorf("invalid ip address %s", ip) | ||||
| 		} | ||||
|  |  | |||
|  | @ -603,6 +603,7 @@ github.com/pmezard/go-difflib/difflib | |||
| # github.com/prometheus/client_golang v1.11.0 | ||||
| ## explicit | ||||
| github.com/prometheus/client_golang/prometheus | ||||
| github.com/prometheus/client_golang/prometheus/collectors | ||||
| github.com/prometheus/client_golang/prometheus/internal | ||||
| github.com/prometheus/client_golang/prometheus/promhttp | ||||
| # github.com/prometheus/client_model v0.2.0 | ||||
|  | @ -772,7 +773,7 @@ golang.org/x/oauth2/jwt | |||
| # golang.org/x/sync v0.0.0-20210220032951-036812b2e83c | ||||
| golang.org/x/sync/errgroup | ||||
| golang.org/x/sync/semaphore | ||||
| # golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40 | ||||
| # golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c | ||||
| ## explicit | ||||
| golang.org/x/sys/cpu | ||||
| golang.org/x/sys/execabs | ||||
|  | @ -795,7 +796,7 @@ golang.org/x/text/transform | |||
| golang.org/x/text/unicode/bidi | ||||
| golang.org/x/text/unicode/norm | ||||
| golang.org/x/text/width | ||||
| # golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba | ||||
| # golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac | ||||
| golang.org/x/time/rate | ||||
| # golang.org/x/tools v0.1.2 | ||||
| golang.org/x/tools/go/ast/astutil | ||||
|  | @ -1014,7 +1015,7 @@ k8s.io/api/scheduling/v1beta1 | |||
| k8s.io/api/storage/v1 | ||||
| k8s.io/api/storage/v1alpha1 | ||||
| k8s.io/api/storage/v1beta1 | ||||
| # k8s.io/apiextensions-apiserver v0.21.1 => k8s.io/apiextensions-apiserver v0.21.3 | ||||
| # k8s.io/apiextensions-apiserver v0.21.3 => k8s.io/apiextensions-apiserver v0.21.3 | ||||
| k8s.io/apiextensions-apiserver/pkg/apis/apiextensions | ||||
| k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1 | ||||
| k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1beta1 | ||||
|  | @ -1425,11 +1426,12 @@ k8s.io/legacy-cloud-providers/gce | |||
| # k8s.io/mount-utils v0.21.3 => k8s.io/mount-utils v0.21.3 | ||||
| ## explicit | ||||
| k8s.io/mount-utils | ||||
| # k8s.io/utils v0.0.0-20210527160623-6fdb442a123b | ||||
| # k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 | ||||
| ## explicit | ||||
| k8s.io/utils/buffer | ||||
| k8s.io/utils/exec | ||||
| k8s.io/utils/integer | ||||
| k8s.io/utils/internal/third_party/forked/golang/net | ||||
| k8s.io/utils/io | ||||
| k8s.io/utils/keymutex | ||||
| k8s.io/utils/net | ||||
|  | @ -1438,7 +1440,7 @@ k8s.io/utils/pointer | |||
| k8s.io/utils/trace | ||||
| # rsc.io/letsencrypt v0.0.3 | ||||
| ## explicit | ||||
| # sigs.k8s.io/controller-runtime v0.9.0 | ||||
| # sigs.k8s.io/controller-runtime v0.9.5 | ||||
| ## explicit | ||||
| sigs.k8s.io/controller-runtime | ||||
| sigs.k8s.io/controller-runtime/pkg/builder | ||||
|  |  | |||
|  | @ -1,36 +1,130 @@ | |||
| run: | ||||
|   deadline: 5m | ||||
| linters-settings: | ||||
|   lll: | ||||
|     line-length: 170 | ||||
|   dupl: | ||||
|     threshold: 400 | ||||
| issues: | ||||
|   # don't skip warning about doc comments | ||||
|   exclude-use-default: false | ||||
| 
 | ||||
|   # restore some of the defaults | ||||
|   # (fill in the rest as needed) | ||||
|   exclude-rules: | ||||
|   - linters: [errcheck] | ||||
|     text: "Error return value of .((os\\.)?std(out|err)\\..*|.*Close|.*Flush|os\\.Remove(All)?|.*printf?|os\\.(Un)?Setenv). is not checked" | ||||
| linters: | ||||
|   disable-all: true | ||||
|   enable: | ||||
|   - misspell | ||||
|   - structcheck | ||||
|   - golint | ||||
|   - govet | ||||
|   - asciicheck | ||||
|   - bodyclose | ||||
|   - deadcode | ||||
|   - depguard | ||||
|   - dogsled | ||||
|   - errcheck | ||||
|   - varcheck | ||||
|   - unparam | ||||
|   - ineffassign | ||||
|   - nakedret | ||||
|   - exportloopref | ||||
|   - goconst | ||||
|   - gocritic | ||||
|   - gocyclo | ||||
|   - dupl | ||||
|   - godot | ||||
|   - gofmt | ||||
|   - goimports | ||||
|   - golint | ||||
|   # disabled: | ||||
|   # - goconst is overly aggressive | ||||
|   # - lll generally just complains about flag help & error strings that are human-readable | ||||
|   - goprintffuncname | ||||
|   - gosec | ||||
|   - gosimple | ||||
|   - govet | ||||
|   - ifshort | ||||
|   - importas | ||||
|   - ineffassign | ||||
|   - misspell | ||||
|   - nakedret | ||||
|   - nilerr | ||||
|   - nolintlint | ||||
|   - prealloc | ||||
|   - revive | ||||
|   - rowserrcheck | ||||
|   - staticcheck | ||||
|   - structcheck | ||||
|   - stylecheck | ||||
|   - typecheck | ||||
|   - unconvert | ||||
|   - unparam | ||||
|   - varcheck | ||||
|   - whitespace | ||||
| 
 | ||||
| linters-settings: | ||||
|   ifshort: | ||||
|     # Maximum length of variable declaration measured in number of characters, after which linter won't suggest using short syntax. | ||||
|     max-decl-chars: 50 | ||||
|   importas: | ||||
|     no-unaliased: true | ||||
|     alias: | ||||
|       # Kubernetes | ||||
|       - pkg: k8s.io/api/core/v1 | ||||
|         alias: corev1 | ||||
|       - pkg: k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1 | ||||
|         alias: apiextensionsv1 | ||||
|       - pkg: k8s.io/apimachinery/pkg/apis/meta/v1 | ||||
|         alias: metav1 | ||||
|       - pkg: k8s.io/apimachinery/pkg/api/errors | ||||
|         alias: apierrors | ||||
|       - pkg: k8s.io/apimachinery/pkg/util/errors | ||||
|         alias: kerrors | ||||
|       # Controller Runtime | ||||
|       - pkg: sigs.k8s.io/controller-runtime | ||||
|         alias: ctrl | ||||
|   staticcheck: | ||||
|     go: "1.16" | ||||
|   stylecheck: | ||||
|     go: "1.16" | ||||
| 
 | ||||
| issues: | ||||
|   max-same-issues: 0 | ||||
|   max-issues-per-linter: 0 | ||||
|   # We are disabling default golangci exclusions because we want to help reviewers to focus on reviewing the most relevant | ||||
|   # changes in PRs and avoid nitpicking. | ||||
|   exclude-use-default: false | ||||
|   # List of regexps of issue texts to exclude, empty list by default. | ||||
|   exclude: | ||||
|   # The following are being worked on to remove their exclusion. This list should be reduced or go away all together over time. | ||||
|   # If it is decided they will not be addressed they should be moved above this comment. | ||||
|   - Subprocess launch(ed with variable|ing should be audited) | ||||
|   - (G204|G104|G307) | ||||
|   - "ST1000: at least one file in a package should have a package comment" | ||||
|   exclude-rules: | ||||
|   - linters: | ||||
|     - gosec | ||||
|     text: "G108: Profiling endpoint is automatically exposed on /debug/pprof" | ||||
|   - linters: | ||||
|     - revive | ||||
|     text: "exported: exported method .*\\.(Reconcile|SetupWithManager|SetupWebhookWithManager) should have comment or be unexported" | ||||
|   - linters: | ||||
|     - errcheck | ||||
|     text: Error return value of .((os\.)?std(out|err)\..*|.*Close|.*Flush|os\.Remove(All)?|.*print(f|ln)?|os\.(Un)?Setenv). is not checked | ||||
|   # With Go 1.16, the new embed directive can be used with an un-named import, | ||||
|   # revive (previously, golint) only allows these to be imported in a main.go, which wouldn't work for us. | ||||
|   # This directive allows the embed package to be imported with an underscore everywhere. | ||||
|   - linters: | ||||
|     - revive | ||||
|     source: _ "embed" | ||||
|   # Exclude some packages or code to require comments, for example test code, or fake clients. | ||||
|   - linters: | ||||
|     - revive | ||||
|     text: exported (method|function|type|const) (.+) should have comment or be unexported | ||||
|     source: (func|type).*Fake.* | ||||
|   - linters: | ||||
|     - revive | ||||
|     text: exported (method|function|type|const) (.+) should have comment or be unexported | ||||
|     path: fake_\.go | ||||
|   # Disable unparam "always receives" which might not be really | ||||
|   # useful when building libraries. | ||||
|   - linters: | ||||
|     - unparam | ||||
|     text: always receives | ||||
|   # Dot imports for gomega or ginkgo are allowed | ||||
|   # within test files. | ||||
|   - path: _test\.go | ||||
|     text: should not use dot imports | ||||
|   - path: _test\.go | ||||
|     text: cyclomatic complexity | ||||
|   - path: _test\.go | ||||
|     text: "G107: Potential HTTP request made with variable url" | ||||
|   # Append should be able to assign to a different var/slice. | ||||
|   - linters: | ||||
|     - gocritic | ||||
|     text: "appendAssign: append result not assigned to the same slice" | ||||
|   - linters: | ||||
|     - gocritic | ||||
|     text: "singleCaseSwitch: should rewrite switch statement to if statement" | ||||
| 
 | ||||
| run: | ||||
|   timeout: 10m | ||||
|   skip-files: | ||||
|   - "zz_generated.*\\.go$" | ||||
|   - ".*conversion.*\\.go$" | ||||
|   allow-parallel-runners: true | ||||
|  |  | |||
|  | @ -65,29 +65,29 @@ test-tools: ## tests the tools codebase (setup-envtest) | |||
| ## Binaries
 | ||||
| ## --------------------------------------
 | ||||
| 
 | ||||
| $(GOLANGCI_LINT): $(TOOLS_DIR)/go.mod # Build golangci-lint from tools folder.
 | ||||
| 	cd $(TOOLS_DIR) && go build -tags=tools -o bin/golangci-lint github.com/golangci/golangci-lint/cmd/golangci-lint | ||||
| 
 | ||||
| $(GO_APIDIFF): $(TOOLS_DIR)/go.mod # Build go-apidiff from tools folder.
 | ||||
| 	cd $(TOOLS_DIR) && go build -tags=tools -o bin/go-apidiff github.com/joelanford/go-apidiff | ||||
| 
 | ||||
| $(CONTROLLER_GEN): $(TOOLS_DIR)/go.mod # Build controller-gen from tools folder.
 | ||||
| 	cd $(TOOLS_DIR) && go build -tags=tools -o bin/controller-gen sigs.k8s.io/controller-tools/cmd/controller-gen | ||||
| 
 | ||||
| $(GOLANGCI_LINT): .github/workflows/golangci-lint.yml # Download golanci-lint using hack script into tools folder.
 | ||||
| 	hack/ensure-golangci-lint.sh \
 | ||||
| 		-b $(TOOLS_BIN_DIR) \
 | ||||
| 		$(shell cat .github/workflows/golangci-lint.yml | grep version | sed 's/.*version: //') | ||||
| 
 | ||||
| ## --------------------------------------
 | ||||
| ## Linting
 | ||||
| ## --------------------------------------
 | ||||
| 
 | ||||
| .PHONY: lint-libs | ||||
| lint-libs: $(GOLANGCI_LINT) ## Lint library codebase.
 | ||||
| 	$(GOLANGCI_LINT) run -v | ||||
| 
 | ||||
| .PHONY: lint-tools | ||||
| lint-tools: $(GOLANGCI_LINT) ## Lint tools codebase.
 | ||||
| 	cd tools/setup-envtest && $(GOLANGCI_LINT) run -v | ||||
| 
 | ||||
| .PHONY: lint | ||||
| lint: lint-libs lint-tools | ||||
| lint: $(GOLANGCI_LINT) ## Lint codebase
 | ||||
| 	$(GOLANGCI_LINT) run -v $(GOLANGCI_LINT_EXTRA_ARGS) | ||||
| 	cd tools/setup-envtest; $(GOLANGCI_LINT) run -v $(GOLANGCI_LINT_EXTRA_ARGS) | ||||
| 
 | ||||
| .PHONY: lint-fix | ||||
| lint-fix: $(GOLANGCI_LINT) ## Lint the codebase and run auto-fixers if supported by the linter.
 | ||||
| 	GOLANGCI_LINT_EXTRA_ARGS=--fix $(MAKE) lint | ||||
| 
 | ||||
| ## --------------------------------------
 | ||||
| ## Generate
 | ||||
|  |  | |||
|  | @ -4,7 +4,6 @@ aliases: | |||
|   # active folks who can be contacted to perform admin-related | ||||
|   # tasks on the repo, or otherwise approve any PRS. | ||||
|   controller-runtime-admins: | ||||
|   - directxman12 | ||||
|   - droot | ||||
|   - mengqiy | ||||
|   - pwittrock | ||||
|  | @ -36,4 +35,5 @@ aliases: | |||
| 
 | ||||
|   # folks who may have context on ancient history, | ||||
|   # but are no longer directly involved | ||||
|   # controller-runtime-emeritus-maintainers: | ||||
|   controller-runtime-emeritus-maintainers: | ||||
|   - directxman12 | ||||
|  |  | |||
|  | @ -10,6 +10,5 @@ | |||
| # DO NOT REPORT SECURITY VULNERABILITIES DIRECTLY TO THESE NAMES, FOLLOW THE | ||||
| # INSTRUCTIONS AT https://kubernetes.io/security/ | ||||
| 
 | ||||
| directxman12 | ||||
| pwittrock | ||||
| droot | ||||
|  |  | |||
|  | @ -45,7 +45,7 @@ type Result = reconcile.Result | |||
| // A Manager is required to create Controllers.
 | ||||
| type Manager = manager.Manager | ||||
| 
 | ||||
| // Options are the arguments for creating a new Manager
 | ||||
| // Options are the arguments for creating a new Manager.
 | ||||
| type Options = manager.Options | ||||
| 
 | ||||
| // SchemeBuilder builds a new Scheme for mapping go types to Kubernetes GroupVersionKinds.
 | ||||
|  | @ -55,7 +55,7 @@ type SchemeBuilder = scheme.Builder | |||
| type GroupVersion = schema.GroupVersion | ||||
| 
 | ||||
| // GroupResource specifies a Group and a Resource, but does not force a version.  This is useful for identifying
 | ||||
| // concepts during lookup stages without having partially valid types
 | ||||
| // concepts during lookup stages without having partially valid types.
 | ||||
| type GroupResource = schema.GroupResource | ||||
| 
 | ||||
| // TypeMeta describes an individual object in an API response or request
 | ||||
|  | @ -89,7 +89,7 @@ var ( | |||
| 	//
 | ||||
| 	// * In-cluster config if running in cluster
 | ||||
| 	//
 | ||||
| 	// * $HOME/.kube/config if exists
 | ||||
| 	// * $HOME/.kube/config if exists.
 | ||||
| 	GetConfig = config.GetConfig | ||||
| 
 | ||||
| 	// ConfigFile returns the cfg.File function for deferred config file loading,
 | ||||
|  | @ -97,10 +97,10 @@ var ( | |||
| 	// the manager.
 | ||||
| 	ConfigFile = cfg.File | ||||
| 
 | ||||
| 	// NewControllerManagedBy returns a new controller builder that will be started by the provided Manager
 | ||||
| 	// NewControllerManagedBy returns a new controller builder that will be started by the provided Manager.
 | ||||
| 	NewControllerManagedBy = builder.ControllerManagedBy | ||||
| 
 | ||||
| 	// NewWebhookManagedBy returns a new webhook builder that will be started by the provided Manager
 | ||||
| 	// NewWebhookManagedBy returns a new webhook builder that will be started by the provided Manager.
 | ||||
| 	NewWebhookManagedBy = builder.WebhookManagedBy | ||||
| 
 | ||||
| 	// NewManager returns a new Manager for creating Controllers.
 | ||||
|  |  | |||
|  | @ -28,7 +28,7 @@ limitations under the License. | |||
| // The main entrypoint for controller-runtime is this root package, which
 | ||||
| // contains all of the common types needed to get started building controllers:
 | ||||
| //  import (
 | ||||
| //      controllers "sigs.k8s.io/controller-runtime"
 | ||||
| //      ctrl "sigs.k8s.io/controller-runtime"
 | ||||
| //  )
 | ||||
| //
 | ||||
| // The examples in this package walk through a basic controller setup.  The
 | ||||
|  |  | |||
|  | @ -11,19 +11,20 @@ require ( | |||
| 	github.com/hashicorp/golang-lru v0.5.4 // indirect | ||||
| 	github.com/imdario/mergo v0.3.12 // indirect | ||||
| 	github.com/onsi/ginkgo v1.16.4 | ||||
| 	github.com/onsi/gomega v1.13.0 | ||||
| 	github.com/onsi/gomega v1.14.0 | ||||
| 	github.com/prometheus/client_golang v1.11.0 | ||||
| 	github.com/prometheus/client_model v0.2.0 | ||||
| 	go.uber.org/goleak v1.1.10 | ||||
| 	go.uber.org/zap v1.17.0 | ||||
| 	golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba | ||||
| 	go.uber.org/zap v1.18.1 | ||||
| 	golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c | ||||
| 	golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac | ||||
| 	gomodules.xyz/jsonpatch/v2 v2.2.0 | ||||
| 	google.golang.org/appengine v1.6.7 // indirect | ||||
| 	k8s.io/api v0.21.1 | ||||
| 	k8s.io/apiextensions-apiserver v0.21.1 | ||||
| 	k8s.io/apimachinery v0.21.1 | ||||
| 	k8s.io/client-go v0.21.1 | ||||
| 	k8s.io/component-base v0.21.1 | ||||
| 	k8s.io/utils v0.0.0-20210527160623-6fdb442a123b | ||||
| 	k8s.io/api v0.21.3 | ||||
| 	k8s.io/apiextensions-apiserver v0.21.3 | ||||
| 	k8s.io/apimachinery v0.21.3 | ||||
| 	k8s.io/client-go v0.21.3 | ||||
| 	k8s.io/component-base v0.21.3 | ||||
| 	k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 | ||||
| 	sigs.k8s.io/yaml v1.2.0 | ||||
| ) | ||||
|  |  | |||
|  | @ -47,6 +47,8 @@ github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e/go.mod h1:3U/XgcO3hC | |||
| github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da/go.mod h1:Q73ZrmVTwzkszR9V5SSuryQ31EELlFMUz1kKyl939pY= | ||||
| github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8= | ||||
| github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= | ||||
| github.com/benbjohnson/clock v1.1.0 h1:Q92kusRqC1XV2MjkWETPvjJVqKetz1OzxZB7mHJLju8= | ||||
| github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= | ||||
| github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= | ||||
| github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= | ||||
| github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= | ||||
|  | @ -164,7 +166,6 @@ github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMyw | |||
| 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.5.0/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/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU= | ||||
| github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
|  | @ -294,15 +295,14 @@ github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c/go.mod h1:lLunBs/Ym6LB | |||
| github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= | ||||
| github.com/onsi/ginkgo v1.16.2/go.mod h1:CObGmKUOKaSC0RjmoAK7tKyn4Azo5P2IWuoMnvwxz1E= | ||||
| github.com/onsi/ginkgo v1.16.4 h1:29JGrr5oVBm5ulCWet69zQkzWipVXIol6ygQUe/EzNc= | ||||
| github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
| github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= | ||||
| github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= | ||||
| github.com/onsi/gomega v1.13.0 h1:7lLHu94wT9Ij0o6EWWclhu0aOh32VxhkwEJvzuWPeak= | ||||
| github.com/onsi/gomega v1.13.0/go.mod h1:lRk9szgn8TxENtWd0Tp4c3wjlRfMTMH27I+3Je41yGY= | ||||
| github.com/onsi/gomega v1.14.0 h1:ep6kpPVwmr/nTbklSx2nrLNSIO62DoYAhnPNIMhK8gI= | ||||
| github.com/onsi/gomega v1.14.0/go.mod h1:cIuvLEne0aoVhAgh/O6ac0Op8WWw9H6eYCriF+tEHG0= | ||||
| github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= | ||||
| github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= | ||||
| github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU= | ||||
|  | @ -401,8 +401,8 @@ go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/ | |||
| go.uber.org/multierr v1.6.0 h1:y6IPFStTAIT5Ytl7/XYmHvzXQ7S3g/IeZW9hyZ5thw4= | ||||
| go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= | ||||
| go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= | ||||
| go.uber.org/zap v1.17.0 h1:MTjgFu6ZLKvY6Pvaqk97GlxNBuMpV4Hy/3P6tRGlI2U= | ||||
| go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= | ||||
| go.uber.org/zap v1.18.1 h1:CSUJ2mjFszzEWt4CdKISEuChVIXGBn3lAPwkRGyVrc4= | ||||
| go.uber.org/zap v1.18.1/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= | ||||
| golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| 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= | ||||
|  | @ -532,10 +532,11 @@ golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7w | |||
| golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40 h1:JWgyZ1qgdTaF3N3oxC+MdTV7qvEEgHo3otj+HB5CM7Q= | ||||
| golang.org/x/sys v0.0.0-20210426230700-d19ff857e887/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= | ||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||
| golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= | ||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||
| golang.org/x/term v0.0.0-20210220032956-6a3ed077a48d h1:SZxvLBoTP5yHO3Frd4z4vrF+DBX9vMVanchswa69toE= | ||||
|  | @ -552,8 +553,9 @@ golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxb | |||
| 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/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba h1:O8mE0/t419eoIwhTFpKVkHiTs/Igowgfkj25AcZrtiE= | ||||
| golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac h1:7zkz7BUtwNFFqcowJ+RIgu2MaV/MapERkDIy+mwPyjs= | ||||
| golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac/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-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
|  | @ -699,18 +701,18 @@ honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWh | |||
| 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= | ||||
| honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= | ||||
| k8s.io/api v0.21.1 h1:94bbZ5NTjdINJEdzOkpS4vdPhkb1VFpTYC9zh43f75c= | ||||
| k8s.io/api v0.21.1/go.mod h1:FstGROTmsSHBarKc8bylzXih8BLNYTiS3TZcsoEDg2s= | ||||
| k8s.io/apiextensions-apiserver v0.21.1 h1:AA+cnsb6w7SZ1vD32Z+zdgfXdXY8X9uGX5bN6EoPEIo= | ||||
| k8s.io/apiextensions-apiserver v0.21.1/go.mod h1:KESQFCGjqVcVsZ9g0xX5bacMjyX5emuWcS2arzdEouA= | ||||
| k8s.io/apimachinery v0.21.1 h1:Q6XuHGlj2xc+hlMCvqyYfbv3H7SRGn2c8NycxJquDVs= | ||||
| k8s.io/apimachinery v0.21.1/go.mod h1:jbreFvJo3ov9rj7eWT7+sYiRx+qZuCYXwWT1bcDswPY= | ||||
| k8s.io/apiserver v0.21.1/go.mod h1:nLLYZvMWn35glJ4/FZRhzLG/3MPxAaZTgV4FJZdr+tY= | ||||
| k8s.io/client-go v0.21.1 h1:bhblWYLZKUu+pm50plvQF8WpY6TXdRRtcS/K9WauOj4= | ||||
| k8s.io/client-go v0.21.1/go.mod h1:/kEw4RgW+3xnBGzvp9IWxKSNA+lXn3A7AuH3gdOAzLs= | ||||
| k8s.io/code-generator v0.21.1/go.mod h1:hUlps5+9QaTrKx+jiM4rmq7YmH8wPOIko64uZCHDh6Q= | ||||
| k8s.io/component-base v0.21.1 h1:iLpj2btXbR326s/xNQWmPNGu0gaYSjzn7IN/5i28nQw= | ||||
| k8s.io/component-base v0.21.1/go.mod h1:NgzFZ2qu4m1juby4TnrmpR8adRk6ka62YdH5DkIIyKA= | ||||
| k8s.io/api v0.21.3 h1:cblWILbLO8ar+Fj6xdDGr603HRsf8Wu9E9rngJeprZQ= | ||||
| k8s.io/api v0.21.3/go.mod h1:hUgeYHUbBp23Ue4qdX9tR8/ANi/g3ehylAqDn9NWVOg= | ||||
| k8s.io/apiextensions-apiserver v0.21.3 h1:+B6biyUWpqt41kz5x6peIsljlsuwvNAp/oFax/j2/aY= | ||||
| k8s.io/apiextensions-apiserver v0.21.3/go.mod h1:kl6dap3Gd45+21Jnh6utCx8Z2xxLm8LGDkprcd+KbsE= | ||||
| k8s.io/apimachinery v0.21.3 h1:3Ju4nvjCngxxMYby0BimUk+pQHPOQp3eCGChk5kfVII= | ||||
| k8s.io/apimachinery v0.21.3/go.mod h1:H/IM+5vH9kZRNJ4l3x/fXP/5bOPJaVP/guptnZPeCFI= | ||||
| k8s.io/apiserver v0.21.3/go.mod h1:eDPWlZG6/cCCMj/JBcEpDoK+I+6i3r9GsChYBHSbAzU= | ||||
| k8s.io/client-go v0.21.3 h1:J9nxZTOmvkInRDCzcSNQmPJbDYN/PjlxXT9Mos3HcLg= | ||||
| k8s.io/client-go v0.21.3/go.mod h1:+VPhCgTsaFmGILxR/7E1N0S+ryO010QBeNCv5JwRGYU= | ||||
| k8s.io/code-generator v0.21.3/go.mod h1:K3y0Bv9Cz2cOW2vXUrNZlFbflhuPvuadW6JdnN6gGKo= | ||||
| k8s.io/component-base v0.21.3 h1:4WuuXY3Npa+iFfi2aDRiOz+anhNvRfye0859ZgfC5Og= | ||||
| k8s.io/component-base v0.21.3/go.mod h1:kkuhtfEHeZM6LkX0saqSK8PbdO7A0HigUngmhhrwfGQ= | ||||
| k8s.io/gengo v0.0.0-20200413195148-3a45101e95ac/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/gengo v0.0.0-20201214224949-b6c5ce23f027/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= | ||||
| k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE= | ||||
|  | @ -720,15 +722,15 @@ k8s.io/klog/v2 v2.8.0/go.mod h1:hy9LJ/NvuK+iVyP4Ehqva4HxZG/oXyIS3n3Jmire4Ec= | |||
| k8s.io/kube-openapi v0.0.0-20210305001622-591a79e4bda7 h1:vEx13qjvaZ4yfObSSXW7BrMc/KQBBT/Jyee8XtLf4x0= | ||||
| k8s.io/kube-openapi v0.0.0-20210305001622-591a79e4bda7/go.mod h1:wXW5VT87nVfh/iLV8FpR2uDvrFyomxbtb1KivDbvPTE= | ||||
| k8s.io/utils v0.0.0-20201110183641-67b214c5f920/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210527160623-6fdb442a123b h1:MSqsVQ3pZvPGTqCjptfimO2WjG7A9un2zcpiHkA6M/s= | ||||
| k8s.io/utils v0.0.0-20210527160623-6fdb442a123b/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= | ||||
| k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 h1:DnzUXII7sVg1FJ/4JX6YDRJfLNAC7idRatPwe07suiI= | ||||
| k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471/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/apiserver-network-proxy/konnectivity-client v0.0.15/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg= | ||||
| sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.19/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.0.2/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.1.0 h1:C4r9BgJ98vrKnnVCjwCSXcWjWe0NKcUQkmzDXZXGwH8= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.1.0/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.1.2 h1:Hr/htKFmJEbtMgS/UD0N+gtgctAqz81t3nu+sPzynno= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.1.2/go.mod h1:j/nl6xW8vLS49O8YvXW1ocPhZawJtm+Yrr7PPRQ0Vg4= | ||||
| 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= | ||||
|  |  | |||
|  | @ -34,18 +34,18 @@ import ( | |||
| 	"sigs.k8s.io/controller-runtime/pkg/source" | ||||
| ) | ||||
| 
 | ||||
| // Supporting mocking out functions for testing
 | ||||
| // Supporting mocking out functions for testing.
 | ||||
| var newController = controller.New | ||||
| var getGvk = apiutil.GVKForObject | ||||
| 
 | ||||
| // project represents other forms that the we can use to
 | ||||
| // send/receive a given resource (metadata-only, unstructured, etc)
 | ||||
| // send/receive a given resource (metadata-only, unstructured, etc).
 | ||||
| type objectProjection int | ||||
| 
 | ||||
| const ( | ||||
| 	// projectAsNormal doesn't change the object from the form given
 | ||||
| 	// projectAsNormal doesn't change the object from the form given.
 | ||||
| 	projectAsNormal objectProjection = iota | ||||
| 	// projectAsMetadata turns this into an metadata-only watch
 | ||||
| 	// projectAsMetadata turns this into an metadata-only watch.
 | ||||
| 	projectAsMetadata | ||||
| ) | ||||
| 
 | ||||
|  | @ -61,7 +61,7 @@ type Builder struct { | |||
| 	name             string | ||||
| } | ||||
| 
 | ||||
| // ControllerManagedBy returns a new controller builder that will be started by the provided Manager
 | ||||
| // ControllerManagedBy returns a new controller builder that will be started by the provided Manager.
 | ||||
| func ControllerManagedBy(m manager.Manager) *Builder { | ||||
| 	return &Builder{mgr: m} | ||||
| } | ||||
|  | @ -77,7 +77,7 @@ type ForInput struct { | |||
| // For defines the type of Object being *reconciled*, and configures the ControllerManagedBy to respond to create / delete /
 | ||||
| // update events by *reconciling the object*.
 | ||||
| // This is the equivalent of calling
 | ||||
| // Watches(&source.Kind{Type: apiType}, &handler.EnqueueRequestForObject{})
 | ||||
| // Watches(&source.Kind{Type: apiType}, &handler.EnqueueRequestForObject{}).
 | ||||
| func (blder *Builder) For(object client.Object, opts ...ForOption) *Builder { | ||||
| 	if blder.forInput.object != nil { | ||||
| 		blder.forInput.err = fmt.Errorf("For(...) should only be called once, could not assign multiple objects for reconciliation") | ||||
|  | @ -101,7 +101,7 @@ type OwnsInput struct { | |||
| 
 | ||||
| // Owns defines types of Objects being *generated* by the ControllerManagedBy, and configures the ControllerManagedBy to respond to
 | ||||
| // create / delete / update events by *reconciling the owner object*.  This is the equivalent of calling
 | ||||
| // Watches(&source.Kind{Type: <ForType-forInput>}, &handler.EnqueueRequestForOwner{OwnerType: apiType, IsController: true})
 | ||||
| // Watches(&source.Kind{Type: <ForType-forInput>}, &handler.EnqueueRequestForOwner{OwnerType: apiType, IsController: true}).
 | ||||
| func (blder *Builder) Owns(object client.Object, opts ...OwnsOption) *Builder { | ||||
| 	input := OwnsInput{object: object} | ||||
| 	for _, opt := range opts { | ||||
|  |  | |||
|  | @ -38,7 +38,7 @@ type WebhookBuilder struct { | |||
| 	config  *rest.Config | ||||
| } | ||||
| 
 | ||||
| // WebhookManagedBy allows inform its manager.Manager
 | ||||
| // WebhookManagedBy allows inform its manager.Manager.
 | ||||
| func WebhookManagedBy(m manager.Manager) *WebhookBuilder { | ||||
| 	return &WebhookBuilder{mgr: m} | ||||
| } | ||||
|  | @ -86,7 +86,7 @@ func (blder *WebhookBuilder) registerWebhooks() error { | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // registerDefaultingWebhook registers a defaulting webhook if th
 | ||||
| // registerDefaultingWebhook registers a defaulting webhook if th.
 | ||||
| func (blder *WebhookBuilder) registerDefaultingWebhook() { | ||||
| 	defaulter, isDefaulter := blder.apiType.(admission.Defaulter) | ||||
| 	if !isDefaulter { | ||||
|  | @ -157,11 +157,11 @@ func (blder *WebhookBuilder) isAlreadyHandled(path string) bool { | |||
| } | ||||
| 
 | ||||
| func generateMutatePath(gvk schema.GroupVersionKind) string { | ||||
| 	return "/mutate-" + strings.Replace(gvk.Group, ".", "-", -1) + "-" + | ||||
| 	return "/mutate-" + strings.ReplaceAll(gvk.Group, ".", "-") + "-" + | ||||
| 		gvk.Version + "-" + strings.ToLower(gvk.Kind) | ||||
| } | ||||
| 
 | ||||
| func generateValidatePath(gvk schema.GroupVersionKind) string { | ||||
| 	return "/validate-" + strings.Replace(gvk.Group, ".", "-", -1) + "-" + | ||||
| 	return "/validate-" + strings.ReplaceAll(gvk.Group, ".", "-") + "-" + | ||||
| 		gvk.Version + "-" + strings.ToLower(gvk.Kind) | ||||
| } | ||||
|  |  | |||
|  | @ -69,7 +69,7 @@ type Informers interface { | |||
| 	client.FieldIndexer | ||||
| } | ||||
| 
 | ||||
| // Informer - informer allows you interact with the underlying informer
 | ||||
| // Informer - informer allows you interact with the underlying informer.
 | ||||
| type Informer interface { | ||||
| 	// AddEventHandler adds an event handler to the shared informer using the shared informer's resync
 | ||||
| 	// period.  Events to a single handler are delivered sequentially, but there is no coordination
 | ||||
|  | @ -82,14 +82,14 @@ type Informer interface { | |||
| 	// AddIndexers adds more indexers to this store.  If you call this after you already have data
 | ||||
| 	// in the store, the results are undefined.
 | ||||
| 	AddIndexers(indexers toolscache.Indexers) error | ||||
| 	//HasSynced return true if the informers underlying store has synced
 | ||||
| 	// HasSynced return true if the informers underlying store has synced.
 | ||||
| 	HasSynced() bool | ||||
| } | ||||
| 
 | ||||
| // SelectorsByObject associate a client.Object's GVK to a field/label selector
 | ||||
| // SelectorsByObject associate a client.Object's GVK to a field/label selector.
 | ||||
| type SelectorsByObject map[client.Object]internal.Selector | ||||
| 
 | ||||
| // Options are the optional arguments for creating a new InformersMap object
 | ||||
| // Options are the optional arguments for creating a new InformersMap object.
 | ||||
| type Options struct { | ||||
| 	// Scheme is the scheme to use for mapping objects to GroupVersionKinds
 | ||||
| 	Scheme *runtime.Scheme | ||||
|  |  | |||
|  | @ -50,7 +50,7 @@ type informerCache struct { | |||
| 	*internal.InformersMap | ||||
| } | ||||
| 
 | ||||
| // Get implements Reader
 | ||||
| // Get implements Reader.
 | ||||
| func (ip *informerCache) Get(ctx context.Context, key client.ObjectKey, out client.Object) error { | ||||
| 	gvk, err := apiutil.GVKForObject(out, ip.Scheme) | ||||
| 	if err != nil { | ||||
|  | @ -68,9 +68,8 @@ func (ip *informerCache) Get(ctx context.Context, key client.ObjectKey, out clie | |||
| 	return cache.Reader.Get(ctx, key, out) | ||||
| } | ||||
| 
 | ||||
| // List implements Reader
 | ||||
| // List implements Reader.
 | ||||
| func (ip *informerCache) List(ctx context.Context, out client.ObjectList, opts ...client.ListOption) error { | ||||
| 
 | ||||
| 	gvk, cacheTypeObj, err := ip.objectTypeForListObject(out) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|  | @ -130,7 +129,7 @@ func (ip *informerCache) objectTypeForListObject(list client.ObjectList) (*schem | |||
| 	return &gvk, cacheTypeObj, nil | ||||
| } | ||||
| 
 | ||||
| // GetInformerForKind returns the informer for the GroupVersionKind
 | ||||
| // GetInformerForKind returns the informer for the GroupVersionKind.
 | ||||
| func (ip *informerCache) GetInformerForKind(ctx context.Context, gvk schema.GroupVersionKind) (Informer, error) { | ||||
| 	// Map the gvk to an object
 | ||||
| 	obj, err := ip.Scheme.New(gvk) | ||||
|  | @ -145,7 +144,7 @@ func (ip *informerCache) GetInformerForKind(ctx context.Context, gvk schema.Grou | |||
| 	return i.Informer, err | ||||
| } | ||||
| 
 | ||||
| // GetInformer returns the informer for the obj
 | ||||
| // GetInformer returns the informer for the obj.
 | ||||
| func (ip *informerCache) GetInformer(ctx context.Context, obj client.Object) (Informer, error) { | ||||
| 	gvk, err := apiutil.GVKForObject(obj, ip.Scheme) | ||||
| 	if err != nil { | ||||
|  | @ -160,7 +159,7 @@ func (ip *informerCache) GetInformer(ctx context.Context, obj client.Object) (In | |||
| } | ||||
| 
 | ||||
| // NeedLeaderElection implements the LeaderElectionRunnable interface
 | ||||
| // to indicate that this can be started without requiring the leader lock
 | ||||
| // to indicate that this can be started without requiring the leader lock.
 | ||||
| func (ip *informerCache) NeedLeaderElection() bool { | ||||
| 	return false | ||||
| } | ||||
|  |  | |||
|  | @ -21,7 +21,7 @@ import ( | |||
| 	"fmt" | ||||
| 	"reflect" | ||||
| 
 | ||||
| 	"k8s.io/apimachinery/pkg/api/errors" | ||||
| 	apierrors "k8s.io/apimachinery/pkg/api/errors" | ||||
| 	apimeta "k8s.io/apimachinery/pkg/api/meta" | ||||
| 	"k8s.io/apimachinery/pkg/fields" | ||||
| 	"k8s.io/apimachinery/pkg/labels" | ||||
|  | @ -33,10 +33,10 @@ import ( | |||
| 	"sigs.k8s.io/controller-runtime/pkg/client" | ||||
| ) | ||||
| 
 | ||||
| // CacheReader is a client.Reader
 | ||||
| // CacheReader is a client.Reader.
 | ||||
| var _ client.Reader = &CacheReader{} | ||||
| 
 | ||||
| // CacheReader wraps a cache.Index to implement the client.CacheReader interface for a single type
 | ||||
| // CacheReader wraps a cache.Index to implement the client.CacheReader interface for a single type.
 | ||||
| type CacheReader struct { | ||||
| 	// indexer is the underlying indexer wrapped by this cache.
 | ||||
| 	indexer cache.Indexer | ||||
|  | @ -48,7 +48,7 @@ type CacheReader struct { | |||
| 	scopeName apimeta.RESTScopeName | ||||
| } | ||||
| 
 | ||||
| // Get checks the indexer for the object and writes a copy of it if found
 | ||||
| // Get checks the indexer for the object and writes a copy of it if found.
 | ||||
| func (c *CacheReader) Get(_ context.Context, key client.ObjectKey, out client.Object) error { | ||||
| 	if c.scopeName == apimeta.RESTScopeNameRoot { | ||||
| 		key.Namespace = "" | ||||
|  | @ -64,7 +64,7 @@ func (c *CacheReader) Get(_ context.Context, key client.ObjectKey, out client.Ob | |||
| 	// Not found, return an error
 | ||||
| 	if !exists { | ||||
| 		// Resource gets transformed into Kind in the error anyway, so this is fine
 | ||||
| 		return errors.NewNotFound(schema.GroupResource{ | ||||
| 		return apierrors.NewNotFound(schema.GroupResource{ | ||||
| 			Group:    c.groupVersionKind.Group, | ||||
| 			Resource: c.groupVersionKind.Kind, | ||||
| 		}, key.Name) | ||||
|  | @ -93,7 +93,7 @@ func (c *CacheReader) Get(_ context.Context, key client.ObjectKey, out client.Ob | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // List lists items out of the indexer and writes them to out
 | ||||
| // List lists items out of the indexer and writes them to out.
 | ||||
| func (c *CacheReader) List(_ context.Context, out client.ObjectList, opts ...client.ListOption) error { | ||||
| 	var objs []interface{} | ||||
| 	var err error | ||||
|  | @ -101,7 +101,8 @@ func (c *CacheReader) List(_ context.Context, out client.ObjectList, opts ...cli | |||
| 	listOpts := client.ListOptions{} | ||||
| 	listOpts.ApplyOptions(opts) | ||||
| 
 | ||||
| 	if listOpts.FieldSelector != nil { | ||||
| 	switch { | ||||
| 	case listOpts.FieldSelector != nil: | ||||
| 		// TODO(directxman12): support more complicated field selectors by
 | ||||
| 		// combining multiple indices, GetIndexers, etc
 | ||||
| 		field, val, requiresExact := requiresExactMatch(listOpts.FieldSelector) | ||||
|  | @ -112,9 +113,9 @@ func (c *CacheReader) List(_ context.Context, out client.ObjectList, opts ...cli | |||
| 		// namespaced index key.  Otherwise, ask for the non-namespaced variant by using the fake "all namespaces"
 | ||||
| 		// namespace.
 | ||||
| 		objs, err = c.indexer.ByIndex(FieldIndexName(field), KeyToNamespacedKey(listOpts.Namespace, val)) | ||||
| 	} else if listOpts.Namespace != "" { | ||||
| 	case listOpts.Namespace != "": | ||||
| 		objs, err = c.indexer.ByIndex(cache.NamespaceIndex, listOpts.Namespace) | ||||
| 	} else { | ||||
| 	default: | ||||
| 		objs = c.indexer.List() | ||||
| 	} | ||||
| 	if err != nil { | ||||
|  | @ -186,7 +187,7 @@ func FieldIndexName(field string) string { | |||
| 	return "field:" + field | ||||
| } | ||||
| 
 | ||||
| // noNamespaceNamespace is used as the "namespace" when we want to list across all namespaces
 | ||||
| // noNamespaceNamespace is used as the "namespace" when we want to list across all namespaces.
 | ||||
| const allNamespacesNamespace = "__all_namespaces" | ||||
| 
 | ||||
| // KeyToNamespacedKey prefixes the given index key with a namespace
 | ||||
|  |  | |||
|  | @ -52,7 +52,6 @@ func NewInformersMap(config *rest.Config, | |||
| 	namespace string, | ||||
| 	selectors SelectorsByGVK, | ||||
| ) *InformersMap { | ||||
| 
 | ||||
| 	return &InformersMap{ | ||||
| 		structured:   newStructuredInformersMap(config, scheme, mapper, resync, namespace, selectors), | ||||
| 		unstructured: newUnstructuredInformersMap(config, scheme, mapper, resync, namespace, selectors), | ||||
|  |  | |||
|  | @ -37,7 +37,11 @@ import ( | |||
| 	"sigs.k8s.io/controller-runtime/pkg/client/apiutil" | ||||
| ) | ||||
| 
 | ||||
| // clientListWatcherFunc knows how to create a ListWatcher
 | ||||
| func init() { | ||||
| 	rand.Seed(time.Now().UnixNano()) | ||||
| } | ||||
| 
 | ||||
| // clientListWatcherFunc knows how to create a ListWatcher.
 | ||||
| type createListWatcherFunc func(gvk schema.GroupVersionKind, ip *specificInformersMap) (*cache.ListWatch, error) | ||||
| 
 | ||||
| // newSpecificInformersMap returns a new specificInformersMap (like
 | ||||
|  | @ -65,7 +69,7 @@ func newSpecificInformersMap(config *rest.Config, | |||
| 	return ip | ||||
| } | ||||
| 
 | ||||
| // MapEntry contains the cached data for an Informer
 | ||||
| // MapEntry contains the cached data for an Informer.
 | ||||
| type MapEntry struct { | ||||
| 	// Informer is the cached informer
 | ||||
| 	Informer cache.SharedIndexInformer | ||||
|  | @ -270,8 +274,9 @@ func createStructuredListWatch(gvk schema.GroupVersionKind, ip *specificInformer | |||
| 		ListFunc: func(opts metav1.ListOptions) (runtime.Object, error) { | ||||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			res := listObj.DeepCopyObject() | ||||
| 			isNamespaceScoped := ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot | ||||
| 			err := client.Get().NamespaceIfScoped(ip.namespace, isNamespaceScoped).Resource(mapping.Resource.Resource).VersionedParams(&opts, ip.paramCodec).Do(ctx).Into(res) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			isNamespaceScoped := namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot | ||||
| 			err := client.Get().NamespaceIfScoped(namespace, isNamespaceScoped).Resource(mapping.Resource.Resource).VersionedParams(&opts, ip.paramCodec).Do(ctx).Into(res) | ||||
| 			return res, err | ||||
| 		}, | ||||
| 		// Setup the watch function
 | ||||
|  | @ -279,8 +284,9 @@ func createStructuredListWatch(gvk schema.GroupVersionKind, ip *specificInformer | |||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			// Watch needs to be set to true separately
 | ||||
| 			opts.Watch = true | ||||
| 			isNamespaceScoped := ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot | ||||
| 			return client.Get().NamespaceIfScoped(ip.namespace, isNamespaceScoped).Resource(mapping.Resource.Resource).VersionedParams(&opts, ip.paramCodec).Watch(ctx) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			isNamespaceScoped := namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot | ||||
| 			return client.Get().NamespaceIfScoped(namespace, isNamespaceScoped).Resource(mapping.Resource.Resource).VersionedParams(&opts, ip.paramCodec).Watch(ctx) | ||||
| 		}, | ||||
| 	}, nil | ||||
| } | ||||
|  | @ -309,8 +315,9 @@ func createUnstructuredListWatch(gvk schema.GroupVersionKind, ip *specificInform | |||
| 	return &cache.ListWatch{ | ||||
| 		ListFunc: func(opts metav1.ListOptions) (runtime.Object, error) { | ||||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			if ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return dynamicClient.Resource(mapping.Resource).Namespace(ip.namespace).List(ctx, opts) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			if namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return dynamicClient.Resource(mapping.Resource).Namespace(namespace).List(ctx, opts) | ||||
| 			} | ||||
| 			return dynamicClient.Resource(mapping.Resource).List(ctx, opts) | ||||
| 		}, | ||||
|  | @ -319,8 +326,9 @@ func createUnstructuredListWatch(gvk schema.GroupVersionKind, ip *specificInform | |||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			// Watch needs to be set to true separately
 | ||||
| 			opts.Watch = true | ||||
| 			if ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return dynamicClient.Resource(mapping.Resource).Namespace(ip.namespace).Watch(ctx, opts) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			if namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return dynamicClient.Resource(mapping.Resource).Namespace(namespace).Watch(ctx, opts) | ||||
| 			} | ||||
| 			return dynamicClient.Resource(mapping.Resource).Watch(ctx, opts) | ||||
| 		}, | ||||
|  | @ -354,8 +362,9 @@ func createMetadataListWatch(gvk schema.GroupVersionKind, ip *specificInformersM | |||
| 	return &cache.ListWatch{ | ||||
| 		ListFunc: func(opts metav1.ListOptions) (runtime.Object, error) { | ||||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			if ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return client.Resource(mapping.Resource).Namespace(ip.namespace).List(ctx, opts) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			if namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return client.Resource(mapping.Resource).Namespace(namespace).List(ctx, opts) | ||||
| 			} | ||||
| 			return client.Resource(mapping.Resource).List(ctx, opts) | ||||
| 		}, | ||||
|  | @ -364,8 +373,9 @@ func createMetadataListWatch(gvk schema.GroupVersionKind, ip *specificInformersM | |||
| 			ip.selectors[gvk].ApplyToList(&opts) | ||||
| 			// Watch needs to be set to true separately
 | ||||
| 			opts.Watch = true | ||||
| 			if ip.namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return client.Resource(mapping.Resource).Namespace(ip.namespace).Watch(ctx, opts) | ||||
| 			namespace := restrictNamespaceBySelector(ip.namespace, ip.selectors[gvk]) | ||||
| 			if namespace != "" && mapping.Scope.Name() != meta.RESTScopeNameRoot { | ||||
| 				return client.Resource(mapping.Resource).Namespace(namespace).Watch(ctx, opts) | ||||
| 			} | ||||
| 			return client.Resource(mapping.Resource).Watch(ctx, opts) | ||||
| 		}, | ||||
|  | @ -378,7 +388,27 @@ func createMetadataListWatch(gvk schema.GroupVersionKind, ip *specificInformersM | |||
| func resyncPeriod(resync time.Duration) func() time.Duration { | ||||
| 	return func() time.Duration { | ||||
| 		// the factor will fall into [0.9, 1.1)
 | ||||
| 		factor := rand.Float64()/5.0 + 0.9 | ||||
| 		factor := rand.Float64()/5.0 + 0.9 //nolint:gosec
 | ||||
| 		return time.Duration(float64(resync.Nanoseconds()) * factor) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // restrictNamespaceBySelector returns either a global restriction for all ListWatches
 | ||||
| // if not default/empty, or the namespace that a ListWatch for the specific resource
 | ||||
| // is restricted to, based on a specified field selector for metadata.namespace field.
 | ||||
| func restrictNamespaceBySelector(namespaceOpt string, s Selector) string { | ||||
| 	if namespaceOpt != "" { | ||||
| 		// namespace is already restricted
 | ||||
| 		return namespaceOpt | ||||
| 	} | ||||
| 	fieldSelector := s.Field | ||||
| 	if fieldSelector == nil || fieldSelector.Empty() { | ||||
| 		return "" | ||||
| 	} | ||||
| 	// check whether a selector includes the namespace field
 | ||||
| 	value, found := fieldSelector.RequiresExactMatch("metadata.namespace") | ||||
| 	if found { | ||||
| 		return value | ||||
| 	} | ||||
| 	return "" | ||||
| } | ||||
|  |  | |||
|  | @ -23,16 +23,16 @@ import ( | |||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
| 
 | ||||
| // SelectorsByGVK associate a GroupVersionKind to a field/label selector
 | ||||
| // SelectorsByGVK associate a GroupVersionKind to a field/label selector.
 | ||||
| type SelectorsByGVK map[schema.GroupVersionKind]Selector | ||||
| 
 | ||||
| // Selector specify the label/field selector to fill in ListOptions
 | ||||
| // Selector specify the label/field selector to fill in ListOptions.
 | ||||
| type Selector struct { | ||||
| 	Label labels.Selector | ||||
| 	Field fields.Selector | ||||
| } | ||||
| 
 | ||||
| // ApplyToList fill in ListOptions LabelSelector and FieldSelector if needed
 | ||||
| // ApplyToList fill in ListOptions LabelSelector and FieldSelector if needed.
 | ||||
| func (s Selector) ApplyToList(listOpts *metav1.ListOptions) { | ||||
| 	if s.Label != nil { | ||||
| 		listOpts.LabelSelector = s.Label.String() | ||||
|  |  | |||
|  | @ -22,7 +22,6 @@ import ( | |||
| 	"time" | ||||
| 
 | ||||
| 	corev1 "k8s.io/api/core/v1" | ||||
| 	"k8s.io/apimachinery/pkg/api/meta" | ||||
| 	apimeta "k8s.io/apimachinery/pkg/api/meta" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
|  | @ -32,10 +31,10 @@ import ( | |||
| 	"sigs.k8s.io/controller-runtime/pkg/internal/objectutil" | ||||
| ) | ||||
| 
 | ||||
| // NewCacheFunc - Function for creating a new cache from the options and a rest config
 | ||||
| // NewCacheFunc - Function for creating a new cache from the options and a rest config.
 | ||||
| type NewCacheFunc func(config *rest.Config, opts Options) (Cache, error) | ||||
| 
 | ||||
| // a new global namespaced cache to handle cluster scoped resources
 | ||||
| // a new global namespaced cache to handle cluster scoped resources.
 | ||||
| const globalCache = "_cluster-scope" | ||||
| 
 | ||||
| // MultiNamespacedCacheBuilder - Builder function to create a new multi-namespaced cache.
 | ||||
|  | @ -78,13 +77,13 @@ func MultiNamespacedCacheBuilder(namespaces []string) NewCacheFunc { | |||
| type multiNamespaceCache struct { | ||||
| 	namespaceToCache map[string]Cache | ||||
| 	Scheme           *runtime.Scheme | ||||
| 	RESTMapper       meta.RESTMapper | ||||
| 	RESTMapper       apimeta.RESTMapper | ||||
| 	clusterCache     Cache | ||||
| } | ||||
| 
 | ||||
| var _ Cache = &multiNamespaceCache{} | ||||
| 
 | ||||
| // Methods for multiNamespaceCache to conform to the Informers interface
 | ||||
| // Methods for multiNamespaceCache to conform to the Informers interface.
 | ||||
| func (c *multiNamespaceCache) GetInformer(ctx context.Context, obj client.Object) (Informer, error) { | ||||
| 	informers := map[string]Informer{} | ||||
| 
 | ||||
|  | @ -186,7 +185,7 @@ func (c *multiNamespaceCache) WaitForCacheSync(ctx context.Context) bool { | |||
| func (c *multiNamespaceCache) IndexField(ctx context.Context, obj client.Object, field string, extractValue client.IndexerFunc) error { | ||||
| 	isNamespaced, err := objectutil.IsAPINamespaced(obj, c.Scheme, c.RESTMapper) | ||||
| 	if err != nil { | ||||
| 		return nil | ||||
| 		return nil //nolint:nilerr
 | ||||
| 	} | ||||
| 
 | ||||
| 	if !isNamespaced { | ||||
|  | @ -242,7 +241,7 @@ func (c *multiNamespaceCache) List(ctx context.Context, list client.ObjectList, | |||
| 		return cache.List(ctx, list, opts...) | ||||
| 	} | ||||
| 
 | ||||
| 	listAccessor, err := meta.ListAccessor(list) | ||||
| 	listAccessor, err := apimeta.ListAccessor(list) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | @ -265,7 +264,7 @@ func (c *multiNamespaceCache) List(ctx context.Context, list client.ObjectList, | |||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		accessor, err := meta.ListAccessor(listObj) | ||||
| 		accessor, err := apimeta.ListAccessor(listObj) | ||||
| 		if err != nil { | ||||
| 			return fmt.Errorf("object: %T must be a list type", list) | ||||
| 		} | ||||
|  | @ -289,28 +288,28 @@ func (c *multiNamespaceCache) List(ctx context.Context, list client.ObjectList, | |||
| 	return apimeta.SetList(list, allItems) | ||||
| } | ||||
| 
 | ||||
| // multiNamespaceInformer knows how to handle interacting with the underlying informer across multiple namespaces
 | ||||
| // multiNamespaceInformer knows how to handle interacting with the underlying informer across multiple namespaces.
 | ||||
| type multiNamespaceInformer struct { | ||||
| 	namespaceToInformer map[string]Informer | ||||
| } | ||||
| 
 | ||||
| var _ Informer = &multiNamespaceInformer{} | ||||
| 
 | ||||
| // AddEventHandler adds the handler to each namespaced informer
 | ||||
| // AddEventHandler adds the handler to each namespaced informer.
 | ||||
| func (i *multiNamespaceInformer) AddEventHandler(handler toolscache.ResourceEventHandler) { | ||||
| 	for _, informer := range i.namespaceToInformer { | ||||
| 		informer.AddEventHandler(handler) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // AddEventHandlerWithResyncPeriod adds the handler with a resync period to each namespaced informer
 | ||||
| // AddEventHandlerWithResyncPeriod adds the handler with a resync period to each namespaced informer.
 | ||||
| func (i *multiNamespaceInformer) AddEventHandlerWithResyncPeriod(handler toolscache.ResourceEventHandler, resyncPeriod time.Duration) { | ||||
| 	for _, informer := range i.namespaceToInformer { | ||||
| 		informer.AddEventHandlerWithResyncPeriod(handler, resyncPeriod) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // AddIndexers adds the indexer for each namespaced informer
 | ||||
| // AddIndexers adds the indexer for each namespaced informer.
 | ||||
| func (i *multiNamespaceInformer) AddIndexers(indexers toolscache.Indexers) error { | ||||
| 	for _, informer := range i.namespaceToInformer { | ||||
| 		err := informer.AddIndexers(indexers) | ||||
|  | @ -321,7 +320,7 @@ func (i *multiNamespaceInformer) AddIndexers(indexers toolscache.Indexers) error | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // HasSynced checks if each namespaced informer has synced
 | ||||
| // HasSynced checks if each namespaced informer has synced.
 | ||||
| func (i *multiNamespaceInformer) HasSynced() bool { | ||||
| 	for _, informer := range i.namespaceToInformer { | ||||
| 		if ok := informer.HasSynced(); !ok { | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ func GVKForObject(obj runtime.Object, scheme *runtime.Scheme) (schema.GroupVersi | |||
| 	// (unstructured, partial, etc)
 | ||||
| 
 | ||||
| 	// check for PartialObjectMetadata, which is analogous to unstructured, but isn't handled by ObjectKinds
 | ||||
| 	_, isPartial := obj.(*metav1.PartialObjectMetadata) | ||||
| 	_, isPartial := obj.(*metav1.PartialObjectMetadata) //nolint:ifshort
 | ||||
| 	_, isPartialList := obj.(*metav1.PartialObjectMetadataList) | ||||
| 	if isPartial || isPartialList { | ||||
| 		// we require that the GVK be populated in order to recognize the object
 | ||||
|  | @ -134,7 +134,7 @@ func (f serializerWithDecodedGVK) DecoderToVersion(serializer runtime.Decoder, _ | |||
| 	return serializer | ||||
| } | ||||
| 
 | ||||
| //createRestConfig copies the base config and updates needed fields for a new rest config
 | ||||
| // createRestConfig copies the base config and updates needed fields for a new rest config.
 | ||||
| func createRestConfig(gvk schema.GroupVersionKind, isUnstructured bool, baseConfig *rest.Config, codecs serializer.CodecFactory) *rest.Config { | ||||
| 	gv := gvk.GroupVersion() | ||||
| 
 | ||||
|  |  | |||
|  | @ -41,7 +41,7 @@ type dynamicRESTMapper struct { | |||
| 	initOnce sync.Once | ||||
| } | ||||
| 
 | ||||
| // DynamicRESTMapperOption is a functional option on the dynamicRESTMapper
 | ||||
| // DynamicRESTMapperOption is a functional option on the dynamicRESTMapper.
 | ||||
| type DynamicRESTMapperOption func(*dynamicRESTMapper) error | ||||
| 
 | ||||
| // WithLimiter sets the RESTMapper's underlying limiter to lim.
 | ||||
|  |  | |||
|  | @ -49,7 +49,7 @@ type WarningHandlerOptions struct { | |||
| 	AllowDuplicateLogs bool | ||||
| } | ||||
| 
 | ||||
| // Options are creation options for a Client
 | ||||
| // Options are creation options for a Client.
 | ||||
| type Options struct { | ||||
| 	// Scheme, if provided, will be used to map go structs to GroupVersionKinds
 | ||||
| 	Scheme *runtime.Scheme | ||||
|  | @ -178,7 +178,7 @@ func (c *client) RESTMapper() meta.RESTMapper { | |||
| 	return c.mapper | ||||
| } | ||||
| 
 | ||||
| // Create implements client.Client
 | ||||
| // Create implements client.Client.
 | ||||
| func (c *client) Create(ctx context.Context, obj Object, opts ...CreateOption) error { | ||||
| 	switch obj.(type) { | ||||
| 	case *unstructured.Unstructured: | ||||
|  | @ -190,7 +190,7 @@ func (c *client) Create(ctx context.Context, obj Object, opts ...CreateOption) e | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Update implements client.Client
 | ||||
| // Update implements client.Client.
 | ||||
| func (c *client) Update(ctx context.Context, obj Object, opts ...UpdateOption) error { | ||||
| 	defer c.resetGroupVersionKind(obj, obj.GetObjectKind().GroupVersionKind()) | ||||
| 	switch obj.(type) { | ||||
|  | @ -203,7 +203,7 @@ func (c *client) Update(ctx context.Context, obj Object, opts ...UpdateOption) e | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Delete implements client.Client
 | ||||
| // Delete implements client.Client.
 | ||||
| func (c *client) Delete(ctx context.Context, obj Object, opts ...DeleteOption) error { | ||||
| 	switch obj.(type) { | ||||
| 	case *unstructured.Unstructured: | ||||
|  | @ -215,7 +215,7 @@ func (c *client) Delete(ctx context.Context, obj Object, opts ...DeleteOption) e | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // DeleteAllOf implements client.Client
 | ||||
| // DeleteAllOf implements client.Client.
 | ||||
| func (c *client) DeleteAllOf(ctx context.Context, obj Object, opts ...DeleteAllOfOption) error { | ||||
| 	switch obj.(type) { | ||||
| 	case *unstructured.Unstructured: | ||||
|  | @ -227,7 +227,7 @@ func (c *client) DeleteAllOf(ctx context.Context, obj Object, opts ...DeleteAllO | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Patch implements client.Client
 | ||||
| // Patch implements client.Client.
 | ||||
| func (c *client) Patch(ctx context.Context, obj Object, patch Patch, opts ...PatchOption) error { | ||||
| 	defer c.resetGroupVersionKind(obj, obj.GetObjectKind().GroupVersionKind()) | ||||
| 	switch obj.(type) { | ||||
|  | @ -240,7 +240,7 @@ func (c *client) Patch(ctx context.Context, obj Object, patch Patch, opts ...Pat | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Get implements client.Client
 | ||||
| // Get implements client.Client.
 | ||||
| func (c *client) Get(ctx context.Context, key ObjectKey, obj Object) error { | ||||
| 	switch obj.(type) { | ||||
| 	case *unstructured.Unstructured: | ||||
|  | @ -254,7 +254,7 @@ func (c *client) Get(ctx context.Context, key ObjectKey, obj Object) error { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // List implements client.Client
 | ||||
| // List implements client.Client.
 | ||||
| func (c *client) List(ctx context.Context, obj ObjectList, opts ...ListOption) error { | ||||
| 	switch x := obj.(type) { | ||||
| 	case *unstructured.UnstructuredList: | ||||
|  | @ -288,20 +288,20 @@ func (c *client) List(ctx context.Context, obj ObjectList, opts ...ListOption) e | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Status implements client.StatusClient
 | ||||
| // Status implements client.StatusClient.
 | ||||
| func (c *client) Status() StatusWriter { | ||||
| 	return &statusWriter{client: c} | ||||
| } | ||||
| 
 | ||||
| // statusWriter is client.StatusWriter that writes status subresource
 | ||||
| // statusWriter is client.StatusWriter that writes status subresource.
 | ||||
| type statusWriter struct { | ||||
| 	client *client | ||||
| } | ||||
| 
 | ||||
| // ensure statusWriter implements client.StatusWriter
 | ||||
| // ensure statusWriter implements client.StatusWriter.
 | ||||
| var _ StatusWriter = &statusWriter{} | ||||
| 
 | ||||
| // Update implements client.StatusWriter
 | ||||
| // Update implements client.StatusWriter.
 | ||||
| func (sw *statusWriter) Update(ctx context.Context, obj Object, opts ...UpdateOption) error { | ||||
| 	defer sw.client.resetGroupVersionKind(obj, obj.GetObjectKind().GroupVersionKind()) | ||||
| 	switch obj.(type) { | ||||
|  | @ -314,7 +314,7 @@ func (sw *statusWriter) Update(ctx context.Context, obj Object, opts ...UpdateOp | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Patch implements client.Client
 | ||||
| // Patch implements client.Client.
 | ||||
| func (sw *statusWriter) Patch(ctx context.Context, obj Object, patch Patch, opts ...PatchOption) error { | ||||
| 	defer sw.client.resetGroupVersionKind(obj, obj.GetObjectKind().GroupVersionKind()) | ||||
| 	switch obj.(type) { | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ import ( | |||
| 	"sigs.k8s.io/controller-runtime/pkg/client/apiutil" | ||||
| ) | ||||
| 
 | ||||
| // clientCache creates and caches rest clients and metadata for Kubernetes types
 | ||||
| // clientCache creates and caches rest clients and metadata for Kubernetes types.
 | ||||
| type clientCache struct { | ||||
| 	// config is the rest.Config to talk to an apiserver
 | ||||
| 	config *rest.Config | ||||
|  | @ -107,7 +107,7 @@ func (c *clientCache) getResource(obj runtime.Object) (*resourceMeta, error) { | |||
| 	return r, err | ||||
| } | ||||
| 
 | ||||
| // getObjMeta returns objMeta containing both type and object metadata and state
 | ||||
| // getObjMeta returns objMeta containing both type and object metadata and state.
 | ||||
| func (c *clientCache) getObjMeta(obj runtime.Object) (*objMeta, error) { | ||||
| 	r, err := c.getResource(obj) | ||||
| 	if err != nil { | ||||
|  | @ -130,17 +130,17 @@ type resourceMeta struct { | |||
| 	mapping *meta.RESTMapping | ||||
| } | ||||
| 
 | ||||
| // isNamespaced returns true if the type is namespaced
 | ||||
| // isNamespaced returns true if the type is namespaced.
 | ||||
| func (r *resourceMeta) isNamespaced() bool { | ||||
| 	return r.mapping.Scope.Name() != meta.RESTScopeNameRoot | ||||
| } | ||||
| 
 | ||||
| // resource returns the resource name of the type
 | ||||
| // resource returns the resource name of the type.
 | ||||
| func (r *resourceMeta) resource() string { | ||||
| 	return r.mapping.Resource.Resource | ||||
| } | ||||
| 
 | ||||
| // objMeta stores type and object information about a Kubernetes type
 | ||||
| // objMeta stores type and object information about a Kubernetes type.
 | ||||
| type objMeta struct { | ||||
| 	// resourceMeta contains type information for the object
 | ||||
| 	*resourceMeta | ||||
|  |  | |||
|  | @ -55,7 +55,7 @@ func init() { | |||
| //
 | ||||
| // * In-cluster config if running in cluster
 | ||||
| //
 | ||||
| // * $HOME/.kube/config if exists
 | ||||
| // * $HOME/.kube/config if exists.
 | ||||
| func GetConfig() (*rest.Config, error) { | ||||
| 	return GetConfigWithContext("") | ||||
| } | ||||
|  | @ -75,7 +75,7 @@ func GetConfig() (*rest.Config, error) { | |||
| //
 | ||||
| // * In-cluster config if running in cluster
 | ||||
| //
 | ||||
| // * $HOME/.kube/config if exists
 | ||||
| // * $HOME/.kube/config if exists.
 | ||||
| func GetConfigWithContext(context string) (*rest.Config, error) { | ||||
| 	cfg, err := loadConfig(context) | ||||
| 	if err != nil { | ||||
|  | @ -95,9 +95,8 @@ func GetConfigWithContext(context string) (*rest.Config, error) { | |||
| // test the precedence of loading the config.
 | ||||
| var loadInClusterConfig = rest.InClusterConfig | ||||
| 
 | ||||
| // loadConfig loads a REST Config as per the rules specified in GetConfig
 | ||||
| // loadConfig loads a REST Config as per the rules specified in GetConfig.
 | ||||
| func loadConfig(context string) (*rest.Config, error) { | ||||
| 
 | ||||
| 	// If a flag is specified with the config location, use that
 | ||||
| 	if len(kubeconfig) > 0 { | ||||
| 		return loadConfigWithContext("", &clientcmd.ClientConfigLoadingRules{ExplicitPath: kubeconfig}, context) | ||||
|  |  | |||
|  | @ -46,47 +46,47 @@ func (c *dryRunClient) RESTMapper() meta.RESTMapper { | |||
| 	return c.client.RESTMapper() | ||||
| } | ||||
| 
 | ||||
| // Create implements client.Client
 | ||||
| // Create implements client.Client.
 | ||||
| func (c *dryRunClient) Create(ctx context.Context, obj Object, opts ...CreateOption) error { | ||||
| 	return c.client.Create(ctx, obj, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // Update implements client.Client
 | ||||
| // Update implements client.Client.
 | ||||
| func (c *dryRunClient) Update(ctx context.Context, obj Object, opts ...UpdateOption) error { | ||||
| 	return c.client.Update(ctx, obj, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // Delete implements client.Client
 | ||||
| // Delete implements client.Client.
 | ||||
| func (c *dryRunClient) Delete(ctx context.Context, obj Object, opts ...DeleteOption) error { | ||||
| 	return c.client.Delete(ctx, obj, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // DeleteAllOf implements client.Client
 | ||||
| // DeleteAllOf implements client.Client.
 | ||||
| func (c *dryRunClient) DeleteAllOf(ctx context.Context, obj Object, opts ...DeleteAllOfOption) error { | ||||
| 	return c.client.DeleteAllOf(ctx, obj, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // Patch implements client.Client
 | ||||
| // Patch implements client.Client.
 | ||||
| func (c *dryRunClient) Patch(ctx context.Context, obj Object, patch Patch, opts ...PatchOption) error { | ||||
| 	return c.client.Patch(ctx, obj, patch, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // Get implements client.Client
 | ||||
| // Get implements client.Client.
 | ||||
| func (c *dryRunClient) Get(ctx context.Context, key ObjectKey, obj Object) error { | ||||
| 	return c.client.Get(ctx, key, obj) | ||||
| } | ||||
| 
 | ||||
| // List implements client.Client
 | ||||
| // List implements client.Client.
 | ||||
| func (c *dryRunClient) List(ctx context.Context, obj ObjectList, opts ...ListOption) error { | ||||
| 	return c.client.List(ctx, obj, opts...) | ||||
| } | ||||
| 
 | ||||
| // Status implements client.StatusClient
 | ||||
| // Status implements client.StatusClient.
 | ||||
| func (c *dryRunClient) Status() StatusWriter { | ||||
| 	return &dryRunStatusWriter{client: c.client.Status()} | ||||
| } | ||||
| 
 | ||||
| // ensure dryRunStatusWriter implements client.StatusWriter
 | ||||
| // ensure dryRunStatusWriter implements client.StatusWriter.
 | ||||
| var _ StatusWriter = &dryRunStatusWriter{} | ||||
| 
 | ||||
| // dryRunStatusWriter is client.StatusWriter that writes status subresource with dryRun mode
 | ||||
|  | @ -95,12 +95,12 @@ type dryRunStatusWriter struct { | |||
| 	client StatusWriter | ||||
| } | ||||
| 
 | ||||
| // Update implements client.StatusWriter
 | ||||
| // Update implements client.StatusWriter.
 | ||||
| func (sw *dryRunStatusWriter) Update(ctx context.Context, obj Object, opts ...UpdateOption) error { | ||||
| 	return sw.client.Update(ctx, obj, append(opts, DryRunAll)...) | ||||
| } | ||||
| 
 | ||||
| // Patch implements client.StatusWriter
 | ||||
| // Patch implements client.StatusWriter.
 | ||||
| func (sw *dryRunStatusWriter) Patch(ctx context.Context, obj Object, patch Patch, opts ...PatchOption) error { | ||||
| 	return sw.client.Patch(ctx, obj, patch, append(opts, DryRunAll)...) | ||||
| } | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ import ( | |||
| // ObjectKey identifies a Kubernetes Object.
 | ||||
| type ObjectKey = types.NamespacedName | ||||
| 
 | ||||
| // ObjectKeyFromObject returns the ObjectKey given a runtime.Object
 | ||||
| // ObjectKeyFromObject returns the ObjectKey given a runtime.Object.
 | ||||
| func ObjectKeyFromObject(obj Object) ObjectKey { | ||||
| 	return ObjectKey{Namespace: obj.GetNamespace(), Name: obj.GetName()} | ||||
| } | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
		Reference in New Issue