mirror of https://github.com/containers/podman.git
				
				
				
			Merge pull request #4866 from TomSweeneyRedHat/dev/tsweeney/buildah1.13.1
Bump to Buildah v1.13.1
This commit is contained in:
		
						commit
						12aa9caf97
					
				
							
								
								
									
										17
									
								
								go.mod
								
								
								
								
							
							
						
						
									
										17
									
								
								go.mod
								
								
								
								
							|  | @ -10,10 +10,10 @@ require ( | |||
| 	github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd // indirect | ||||
| 	github.com/containernetworking/cni v0.7.2-0.20190904153231-83439463f784 | ||||
| 	github.com/containernetworking/plugins v0.8.2 | ||||
| 	github.com/containers/buildah v1.12.0 | ||||
| 	github.com/containers/buildah v1.13.1 | ||||
| 	github.com/containers/image/v5 v5.1.0 | ||||
| 	github.com/containers/psgo v1.4.0 | ||||
| 	github.com/containers/storage v1.15.4 | ||||
| 	github.com/containers/storage v1.15.5 | ||||
| 	github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f | ||||
| 	github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f // indirect | ||||
| 	github.com/cri-o/ocicni v0.1.1-0.20190920040751-deac903fd99b | ||||
|  | @ -41,16 +41,17 @@ require ( | |||
| 	github.com/hpcloud/tail v1.0.0 | ||||
| 	github.com/json-iterator/go v1.1.8 | ||||
| 	github.com/mrunalp/fileutils v0.0.0-20171103030105-7d4729fb3618 | ||||
| 	github.com/onsi/ginkgo v1.10.3 | ||||
| 	github.com/onsi/gomega v1.7.1 | ||||
| 	github.com/onsi/ginkgo v1.11.0 | ||||
| 	github.com/onsi/gomega v1.8.1 | ||||
| 	github.com/opencontainers/go-digest v1.0.0-rc1 | ||||
| 	github.com/opencontainers/image-spec v1.0.2-0.20190823105129-775207bd45b6 | ||||
| 	github.com/opencontainers/runc v1.0.0-rc9 | ||||
| 	github.com/opencontainers/runtime-spec v0.1.2-0.20190618234442-a950415649c7 | ||||
| 	github.com/opencontainers/runtime-tools v0.9.0 | ||||
| 	github.com/opencontainers/selinux v1.3.0 | ||||
| 	github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible // indirect | ||||
| 	github.com/opentracing/opentracing-go v1.1.0 | ||||
| 	github.com/pkg/errors v0.8.1 | ||||
| 	github.com/pkg/errors v0.9.0 | ||||
| 	github.com/pkg/profile v1.4.0 // indirect | ||||
| 	github.com/pmezard/go-difflib v1.0.0 | ||||
| 	github.com/rootless-containers/rootlesskit v0.7.1 | ||||
|  | @ -71,11 +72,9 @@ require ( | |||
| 	golang.org/x/sys v0.0.0-20191127021746-63cb32ae39b2 | ||||
| 	google.golang.org/appengine v1.6.1 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20190620144150-6af8c5fc6601 // indirect | ||||
| 	gopkg.in/inf.v0 v0.9.1 // indirect | ||||
| 	gopkg.in/yaml.v2 v2.2.7 | ||||
| 	k8s.io/api v0.0.0-20190813020757-36bff7324fb7 | ||||
| 	k8s.io/apimachinery v0.0.0-20190809020650-423f5d784010 | ||||
| 	k8s.io/api v0.17.0 | ||||
| 	k8s.io/apimachinery v0.17.0 | ||||
| 	k8s.io/client-go v0.0.0-20190620085101-78d2af792bab | ||||
| 	k8s.io/klog v0.3.3 // indirect | ||||
| 	k8s.io/utils v0.0.0-20190607212802-c55fbcfc754a // indirect | ||||
| ) | ||||
|  |  | |||
							
								
								
									
										68
									
								
								go.sum
								
								
								
								
							
							
						
						
									
										68
									
								
								go.sum
								
								
								
								
							|  | @ -7,12 +7,14 @@ github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78/go.mod h1:LmzpDX | |||
| github.com/Azure/go-autorest v11.1.2+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24= | ||||
| github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= | ||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||
| github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | ||||
| github.com/DataDog/zstd v1.4.0 h1:vhoV+DUHnRZdKW1i5UMjAk2G4JY8wN4ayRfYDNdEhwo= | ||||
| github.com/DataDog/zstd v1.4.0/go.mod h1:1jcaCB/ufaK+sKp1NBhlGmpz41jOoPQ35bpF36t7BBo= | ||||
| github.com/Microsoft/go-winio v0.4.11 h1:zoIOcVf0xPN1tnMVbTtEdI+P8OofVk3NObnwOQ6nK2Q= | ||||
| github.com/Microsoft/go-winio v0.4.11/go.mod h1:VhR8bwka0BXejwEJY73c50VrPtXAaKcyvVC4A4RozmA= | ||||
| github.com/Microsoft/go-winio v0.4.12 h1:xAfWHN1IrQ0NJ9TBC0KBZoqLjzDTr1ML+4MywiUOryc= | ||||
| github.com/Microsoft/go-winio v0.4.12/go.mod h1:VhR8bwka0BXejwEJY73c50VrPtXAaKcyvVC4A4RozmA= | ||||
| github.com/Microsoft/go-winio v0.4.14/go.mod h1:qXqCSQ3Xa7+6tgxaGTIe4Kpcdsi+P8jBhyzoq1bpyYA= | ||||
| github.com/Microsoft/go-winio v0.4.15-0.20190919025122-fc70bd9a86b5 h1:ygIc8M6trr62pF5DucadTWGdEB4mEyvzi0e2nbcmcyA= | ||||
| github.com/Microsoft/go-winio v0.4.15-0.20190919025122-fc70bd9a86b5/go.mod h1:tTuCMEN+UleMWgg9dVx4Hu52b1bJo+59jBh3ajtinzw= | ||||
| github.com/Microsoft/hcsshim v0.8.6 h1:ZfF0+zZeYdzMIVMZHKtDKJvLHj76XCuVae/jNkjj0IA= | ||||
|  | @ -23,7 +25,9 @@ github.com/Microsoft/hcsshim v0.8.7 h1:ptnOoufxGSzauVTsdE+wMYnCWA301PdoN4xg5oRdZ | |||
| github.com/Microsoft/hcsshim v0.8.7/go.mod h1:OHd7sQqRFrYd3RmSgbgji+ctCwkbq2wbEYNSzOYtcBQ= | ||||
| github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ= | ||||
| github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= | ||||
| github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= | ||||
| github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= | ||||
| github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= | ||||
| github.com/VividCortex/ewma v1.1.1 h1:MnEK4VOv6n0RSY4vtRe3h11qjxL3+t0B8yOL8iMXdcM= | ||||
| github.com/VividCortex/ewma v1.1.1/go.mod h1:2Tkkvm3sRDVXaiyucHiACn4cqf7DpdyLvmxzcbUokwA= | ||||
| github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= | ||||
|  | @ -71,8 +75,12 @@ github.com/containernetworking/plugins v0.8.2 h1:5lnwfsAYO+V7yXhysJKy3E1A2Gy9oVu | |||
| github.com/containernetworking/plugins v0.8.2/go.mod h1:TxALKWZpWL79BC3GOYKJzzXr7U8R23PdhwaLp6F3adc= | ||||
| github.com/containers/buildah v1.12.0 h1:bi/8ACl8qobazwfYgNze5y+aRuBIG+R7lMStFbnDOxE= | ||||
| github.com/containers/buildah v1.12.0/go.mod h1:yzPuQ/mJTPsfSLCyBPbeaoXgBLanjnf36M2cDzyckMg= | ||||
| github.com/containers/buildah v1.13.1 h1:EdhllQxXmOZ56mGFf68AkrpIj9XtEkkGq0WaPWFuGM0= | ||||
| github.com/containers/buildah v1.13.1/go.mod h1:U0LcOzSqoYdyQC5L2hMeLbtCDuCCLxmZV1eb+SWY4GA= | ||||
| github.com/containers/common v0.0.3 h1:C2Zshb0w720FqPa42MCRuiGfbW0kwbURRwvK1EWIC5I= | ||||
| github.com/containers/common v0.0.3/go.mod h1:CaOgMRiwi2JJHISMZ6VPPZhQYFUDRv3YYVss2RqUCMg= | ||||
| github.com/containers/common v0.0.7 h1:eKYZLKfJ2d/RNDgecLDFv45cHb4imYzIcrQHx1Y029M= | ||||
| github.com/containers/common v0.0.7/go.mod h1:lhWV3MLhO1+KGE2x6v9+K38MxpjXGso+edmpkFnCOqI= | ||||
| github.com/containers/image/v5 v5.0.0 h1:arnXgbt1ucsC/ndtSpiQY87rA0UjhF+/xQnPzqdBDn4= | ||||
| github.com/containers/image/v5 v5.0.0/go.mod h1:MgiLzCfIeo8lrHi+4Lb8HP+rh513sm0Mlk6RrhjFOLY= | ||||
| github.com/containers/image/v5 v5.1.0 h1:5FjAvPJniamuNNIQHkh4PnsL+n+xzs6Aonzaz5dqTEo= | ||||
|  | @ -86,10 +94,13 @@ github.com/containers/psgo v1.4.0/go.mod h1:ENXXLQ5E1At4K0EUsGogXBJi/C28gwqkONWe | |||
| github.com/containers/storage v1.13.2/go.mod h1:6D8nK2sU9V7nEmAraINRs88ZEscM5C5DK+8Npp27GeA= | ||||
| github.com/containers/storage v1.13.4 h1:j0bBaJDKbUHtAW1MXPFnwXJtqcH+foWeuXK1YaBV5GA= | ||||
| github.com/containers/storage v1.13.4/go.mod h1:6D8nK2sU9V7nEmAraINRs88ZEscM5C5DK+8Npp27GeA= | ||||
| github.com/containers/storage v1.13.5/go.mod h1:HELz8Sn+UVbPaUZMI8RvIG9doD4y4z6Gtg4k7xdd2ZY= | ||||
| github.com/containers/storage v1.15.3 h1:+lFSQZnnKUFyUEtguIgdoQLJfWSuYz+j/wg5GxLtsN4= | ||||
| github.com/containers/storage v1.15.3/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/containers/storage v1.15.4 h1:eiUtV9MOTnPHibO18nDRI+aDhKudY7WmAiJdyVMsqSM= | ||||
| github.com/containers/storage v1.15.4/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/containers/storage v1.15.5 h1:dBZx9yRFHod9c8FVaXlVtRqr2cmlAhpl+9rt87cE7J4= | ||||
| github.com/containers/storage v1.15.5/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= | ||||
| github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= | ||||
| github.com/coreos/go-iptables v0.4.2 h1:KH0EwId05JwWIfb96gWvkiT2cbuOu8ygqUaB+yPAwIg= | ||||
|  | @ -152,6 +163,7 @@ github.com/elazarl/goproxy v0.0.0-20190421051319-9d40249d3c2f/go.mod h1:/Zj4wYkg | |||
| github.com/elazarl/goproxy/ext v0.0.0-20190911111923-ecfe977594f1 h1:8B7WF1rIoM8H1smfpXFvOawSAzlRDMVzoGu9zE3+OCk= | ||||
| github.com/elazarl/goproxy/ext v0.0.0-20190911111923-ecfe977594f1/go.mod h1:gNh8nYJoAm43RfaxurUnxr+N1PwuFV3ZMl/efxlIlY8= | ||||
| github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= | ||||
| github.com/emicklei/go-restful v2.9.5+incompatible/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= | ||||
| github.com/etcd-io/bbolt v1.3.3 h1:gSJmxrs37LgTqR/oyJBWok6k6SvXEUerFTbltIhXkBM= | ||||
| github.com/etcd-io/bbolt v1.3.3/go.mod h1:ZF2nL25h33cCyBtcyWeZ2/I3HQOfTP+0PIEvHjkjCrw= | ||||
| github.com/evanphx/json-patch v0.0.0-20190203023257-5858425f7550/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= | ||||
|  | @ -171,10 +183,18 @@ github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeME | |||
| github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= | ||||
| github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= | ||||
| github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= | ||||
| github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas= | ||||
| github.com/go-openapi/jsonpointer v0.0.0-20160704185906-46af16f9f7b1/go.mod h1:+35s3my2LFTysnkMfxsJBAMHj/DoqoB9knIWoYG/Vk0= | ||||
| github.com/go-openapi/jsonpointer v0.19.2/go.mod h1:3akKfEdA7DF1sugOqz1dVQHBcuDBPKZGEoHC/NkiQRg= | ||||
| github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= | ||||
| github.com/go-openapi/jsonreference v0.0.0-20160704190145-13c6e3589ad9/go.mod h1:W3Z9FmVs9qj+KR4zFKmDPGiLdk1D9Rlm7cyMvf57TTg= | ||||
| github.com/go-openapi/jsonreference v0.19.2/go.mod h1:jMjeRr2HHw6nAVajTXJ4eiUwohSTlpa0o73RUL1owJc= | ||||
| github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8= | ||||
| github.com/go-openapi/spec v0.0.0-20160808142527-6aced65f8501/go.mod h1:J8+jY1nAiCcj+friV/PDoE1/3eeccG9LYBs0tYvLOWc= | ||||
| github.com/go-openapi/spec v0.19.3/go.mod h1:FpwSN1ksY1eteniUU7X0N/BgJ7a4WvBFVA8Lj9mJglo= | ||||
| github.com/go-openapi/swag v0.0.0-20160704191624-1d0bd113de87/go.mod h1:DXUve3Dpr1UfpPtxFw+EFuQ41HhCWZfha5jSVRG7C7I= | ||||
| github.com/go-openapi/swag v0.19.2/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= | ||||
| github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= | ||||
| github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= | ||||
| github.com/godbus/dbus v0.0.0-20180201030542-885f9cc04c9c/go.mod h1:/YcGZj5zSblfDWMMoOzV4fas9FZnQYTkDnsGvmh2Grw= | ||||
| github.com/godbus/dbus v0.0.0-20190422162347-ade71ed3457e h1:BWhy2j3IXJhjCbC68FptL43tDKIq8FladmaTs3Xs7Z8= | ||||
|  | @ -284,10 +304,14 @@ github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFB | |||
| github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI= | ||||
| github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= | ||||
| github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= | ||||
| github.com/kr/pty v1.1.5/go.mod h1:9r2w37qlBe7rQ6e1fg1S/9xpWHSnaqNdHD3WcMdbPDA= | ||||
| github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= | ||||
| github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= | ||||
| github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= | ||||
| github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.7.0/go.mod h1:KAzv3t3aY1NaHWoQz1+4F1ccyAH66Jk7yos7ldAVICs= | ||||
| github.com/mattn/go-isatty v0.0.4 h1:bnP0vzxcAdeI1zdubAl5PjU6zsERjGZb7raWodagDYs= | ||||
| github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= | ||||
| github.com/mattn/go-shellwords v1.0.3/go.mod h1:3xCvwCdWdlDJUrvuMn7Wuy9eWs4pE8vqg+NOMyg4B2o= | ||||
|  | @ -324,9 +348,12 @@ 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.8.0 h1:VkHVNpR4iVnU8XQR6DBm8BqYjN7CRzw+xKUbVVbbW9w= | ||||
| github.com/onsi/ginkgo v1.8.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.10.1/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.10.2/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.10.3 h1:OoxbjfXVZyod1fmWYhI7SEyaD8B00ynP3T+D5GiyHOY= | ||||
| github.com/onsi/ginkgo v1.10.3/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.11.0 h1:JAKSXpt1YjtLA7YpPiqO9ss6sNXEsPfSGdwN0UHqzrw= | ||||
| github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/gomega v0.0.0-20151007035656-2152b45fa28a/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v0.0.0-20190113212917-5533ce8a0da3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
|  | @ -335,6 +362,8 @@ github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1Cpa | |||
| github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
| github.com/onsi/gomega v1.7.1 h1:K0jcRCwNQM3vFGh1ppMtDh/+7ApJrjldlX8fA0jDTLQ= | ||||
| github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= | ||||
| github.com/onsi/gomega v1.8.1 h1:C5Dqfs/LeauYDX0jJXIe2SWmwCbGzx9yF8C8xy3Lh34= | ||||
| github.com/onsi/gomega v1.8.1/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA= | ||||
| github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
| github.com/opencontainers/go-digest v1.0.0-rc1 h1:WzifXhOVOEOuFYOJAW6aQqW0TooG2iki3E3Ii+WN7gQ= | ||||
| github.com/opencontainers/go-digest v1.0.0-rc1/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
|  | @ -360,6 +389,7 @@ github.com/opencontainers/selinux v1.2.2 h1:Kx9J6eDG5/24A6DtUquGSpJQ+m2MUTahn4Ft | |||
| github.com/opencontainers/selinux v1.2.2/go.mod h1:+BLncwf63G4dgOzykXAxcmnFlUaOlkDdmw/CqsW6pjs= | ||||
| github.com/opencontainers/selinux v1.3.0 h1:xsI95WzPZu5exzA6JzkLSfdr/DilzOhCJOqGe5TgR0g= | ||||
| github.com/opencontainers/selinux v1.3.0/go.mod h1:+BLncwf63G4dgOzykXAxcmnFlUaOlkDdmw/CqsW6pjs= | ||||
| github.com/openshift/api v0.0.0-20200106203948-7ab22a2c8316/go.mod h1:dv+J0b/HWai0QnMVb37/H0v36klkLBi2TNpPeWDxX10= | ||||
| github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible h1:s55wx8JIG/CKnewev892HifTBrtKzMdvgB3rm4rxC2s= | ||||
| github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible/go.mod h1:dh9o4Fs58gpFXGSYfnVxGR9PnV53I8TW84pQaJDdGiY= | ||||
| github.com/openshift/imagebuilder v1.1.1 h1:KAUR31p8UBJdfVO42azWgb+LeMAed2zaKQ19e0C0X2I= | ||||
|  | @ -374,6 +404,8 @@ github.com/pkg/errors v0.0.0-20190227000051-27936f6d90f9/go.mod h1:bwawxfHBFNV+L | |||
| github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I= | ||||
| github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.9.0 h1:J8lpUdobwIeCI7OiSxHqEwJUKvJwicL5+3v1oe2Yb4k= | ||||
| github.com/pkg/errors v0.9.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/profile v1.4.0 h1:uCmaf4vVbWAOZz36k1hrQD7ijGRzLwaME8Am/7a4jZI= | ||||
| github.com/pkg/profile v1.4.0/go.mod h1:NWz/XGvpEW1FyYQ7fCx4dqYBLlfTcE+A9FLAkNKqjFE= | ||||
| github.com/pmezard/go-difflib v0.0.0-20151028094244-d8ed2627bdf0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||
|  | @ -401,6 +433,7 @@ github.com/prometheus/procfs v0.0.3 h1:CTwfnzjQ+8dS6MhHHu4YswVAD99sL2wjPqP+VkURm | |||
| github.com/prometheus/procfs v0.0.3/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ= | ||||
| github.com/prometheus/procfs v0.0.5 h1:3+auTFlqw+ZaQYJARz6ArODtkaIwtvBTx3N2NehQlL8= | ||||
| github.com/prometheus/procfs v0.0.5/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ= | ||||
| github.com/remyoudompheng/bigfft v0.0.0-20170806203942-52369c62f446/go.mod h1:uYEyJGbgTkfkS4+E/PavXkNJcbFIpEtjt2B0KDQ5+9M= | ||||
| github.com/rogpeppe/go-charset v0.0.0-20180617210344-2471d30d28b4/go.mod h1:qgYeAmZ5ZIpBWTGllZSQnw97Dj+woV0toclVaRGI8pc= | ||||
| github.com/rootless-containers/rootlesskit v0.7.1 h1:enhwHIAXDjfpV83bL4xF60WZ+1ATjMB7spDDvpWAfPk= | ||||
| github.com/rootless-containers/rootlesskit v0.7.1/go.mod h1:r9YL5mKRIdnwcYk4G8E5CSc9MDeFtgYmhfE4CSvDGYA= | ||||
|  | @ -436,6 +469,7 @@ github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An | |||
| github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s= | ||||
| github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE= | ||||
| github.com/stretchr/testify v0.0.0-20151208002404-e3a8ff8ce365/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= | ||||
| github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= | ||||
| github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0Q= | ||||
|  | @ -497,15 +531,20 @@ golang.org/x/crypto v0.0.0-20181025213731-e84da0312774/go.mod h1:6SG95UA2DQfeDnf | |||
| golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190611184440-5c40567a22f8/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190927123631-a832865fa7ad h1:5E5raQxcv+6CZ11RrBYQe5WRbUIWpScjh0kvHZkZIrQ= | ||||
| golang.org/x/crypto v0.0.0-20190927123631-a832865fa7ad/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20191112222119-e1110fd1c708 h1:pXVtWnwHkrWD9ru3sDxY/qFK/bfc0egRovX91EjWjf4= | ||||
| golang.org/x/crypto v0.0.0-20191112222119-e1110fd1c708/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190312203227-4b39c73a6495/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= | ||||
| golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= | ||||
| golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= | ||||
| golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU= | ||||
| golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU15maQ/Ox0txvL9dWGYEHz965HBQE= | ||||
| golang.org/x/net v0.0.0-20170114055629-f2499483f923/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
|  | @ -520,8 +559,12 @@ golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn | |||
| golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= | ||||
| golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190628185345-da137c7871d7 h1:rTIdg5QFRR7XCaK4LCjBiPbx8j4DQRpdYMnGn/bJUEU= | ||||
| golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20191004110552-13f9640d40b9 h1:rjwSpXsdiK0dV8/Naq3kAw9ymfAeJIyd0upUIElB+lI= | ||||
| golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | ||||
| golang.org/x/oauth2 v0.0.0-20190402181905-9f3314589c9a/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||
| golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45 h1:SVwTIAaPC2U/AvvLNZ2a7OVsmBpC8L5BlwK1whH3hm0= | ||||
|  | @ -546,6 +589,7 @@ golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7w | |||
| golang.org/x/sys v0.0.0-20190425145619-16072639606e h1:4ktJgTV34+N3qOZUc5fAaG3Pb11qzMm3PkAoTAgUZ2I= | ||||
| golang.org/x/sys v0.0.0-20190425145619-16072639606e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190507160741-ecd444e8653b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190514135907-3a4b5fb9f71f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190606165138-5da285871e9c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190616124812-15dcb6c0061f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
|  | @ -553,6 +597,7 @@ golang.org/x/sys v0.0.0-20190626221950-04f50cda93cb h1:fgwFCsaw9buMuxNd6+DQfAuSF | |||
| golang.org/x/sys v0.0.0-20190626221950-04f50cda93cb/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190712062909-fae7ac547cb7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190801041406-cbf593c0f2f3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190902133755-9109b7679e13 h1:tdsQdquKbTNMsSZLqnLELJGzCANp9oXhu6zFBW6ODx4= | ||||
| golang.org/x/sys v0.0.0-20190902133755-9109b7679e13/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3 h1:7TYNF4UdlohbFwpNH04CoPMp1cHUZgO1Ebq5r2hIjfo= | ||||
|  | @ -575,10 +620,19 @@ golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGm | |||
| golang.org/x/tools v0.0.0-20181011042414-1f849cf54d09/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190206041539-40960b6deb8e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= | ||||
| golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= | ||||
| golang.org/x/tools v0.0.0-20190606124116-d0a3d012864b/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190614205625-5aca471b1d59/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190920225731-5eefd052ad72/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7 h1:9zdDQZ7Thm29KFXgAX/+yaf3eVbP7djjWp/dXAppNCc= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| gonum.org/v1/gonum v0.0.0-20190331200053-3d26580ed485/go.mod h1:2ltnJ7xHfj0zHS40VVPYEAAMTa3ZGguvHGBSJeRWqE0= | ||||
| gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= | ||||
| gonum.org/v1/netlib v0.0.0-20190331212654-76723241ea4e/go.mod h1:kS+toOQn6AQKjmKJ7gzohV1XkqsFehRA2FbsbkopSuQ= | ||||
| google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= | ||||
| google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/appengine v1.5.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
|  | @ -626,26 +680,40 @@ honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWh | |||
| k8s.io/api v0.0.0-20190620084959-7cf5895f2711/go.mod h1:TBhBqb1AWbBQbW3XRusr7n7E4v2+5ZY8r8sAMnyFC5A= | ||||
| k8s.io/api v0.0.0-20190813020757-36bff7324fb7 h1:4uJOjRn9kWq4AqJRE8+qzmAy+lJd9rh8TY455dNef4U= | ||||
| k8s.io/api v0.0.0-20190813020757-36bff7324fb7/go.mod h1:3Iy+myeAORNCLgjd/Xu9ebwN7Vh59Bw0vh9jhoX+V58= | ||||
| k8s.io/api v0.17.0 h1:H9d/lw+VkZKEVIUc8F3wgiQ+FUXTTr21M87jXLU7yqM= | ||||
| k8s.io/api v0.17.0/go.mod h1:npsyOePkeP0CPwyGfXDHxvypiYMJxBWAMpQxCaJ4ZxI= | ||||
| k8s.io/apimachinery v0.0.0-20190612205821-1799e75a0719/go.mod h1:I4A+glKBHiTgiEjQiCCQfCAIcIMFGt291SmsvcrFzJA= | ||||
| k8s.io/apimachinery v0.0.0-20190809020650-423f5d784010 h1:pyoq062NftC1y/OcnbSvgolyZDJ8y4fmUPWMkdA6gfU= | ||||
| k8s.io/apimachinery v0.0.0-20190809020650-423f5d784010/go.mod h1:Waf/xTS2FGRrgXCkO5FP3XxTOWh0qLf2QhL1qFZZ/R8= | ||||
| k8s.io/apimachinery v0.17.0 h1:xRBnuie9rXcPxUkDizUsGvPf1cnlZCFu210op7J7LJo= | ||||
| k8s.io/apimachinery v0.17.0/go.mod h1:b9qmWdKlLuU9EBh+06BtLcSf/Mu89rWL33naRxs1uZg= | ||||
| k8s.io/client-go v0.0.0-20170217214107-bcde30fb7eae/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= | ||||
| k8s.io/client-go v0.0.0-20181219152756-3dd551c0f083 h1:+Qf/nITucAbm09aIdxvoA+7X0BwaXmQGVoR8k7Ynk9o= | ||||
| k8s.io/client-go v0.0.0-20181219152756-3dd551c0f083/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= | ||||
| k8s.io/client-go v0.0.0-20190620085101-78d2af792bab h1:E8Fecph0qbNsAbijJJQryKu4Oi9QTp5cVpjTE+nqg6g= | ||||
| k8s.io/client-go v0.0.0-20190620085101-78d2af792bab/go.mod h1:E95RaSlHr79aHaX0aGSwcPNfygDiPKOVXdmivCIZT0k= | ||||
| k8s.io/code-generator v0.17.0/go.mod h1:DVmfPQgxQENqDIzVR2ddLXMH34qeszkKSdH/N+s+38s= | ||||
| k8s.io/gengo v0.0.0-20190128074634-0689ccc1d7d6/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/gengo v0.0.0-20190822140433-26a664648505/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/klog v0.0.0-20181102134211-b9b56d5dfc92/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v0.3.0/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v0.3.1/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v0.3.3 h1:niceAagH1tzskmaie/icWd7ci1wbG7Bf2c6YGcQv+3c= | ||||
| k8s.io/klog v0.3.3/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v1.0.0 h1:Pt+yjF5aB1xDSVbau4VsWe+dQNzA0qv1LlXdC2dF6Q8= | ||||
| k8s.io/klog v1.0.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= | ||||
| k8s.io/kube-openapi v0.0.0-20190228160746-b3a7cee44a30/go.mod h1:BXM9ceUBTj2QnfH2MK1odQs778ajze1RxcmP6S8RVVc= | ||||
| k8s.io/kube-openapi v0.0.0-20190709113604-33be087ad058/go.mod h1:nfDlWeOsu3pUf4yWGL+ERqohP4YsZcBJXWMK+gkzOA4= | ||||
| k8s.io/kube-openapi v0.0.0-20191107075043-30be4d16710a/go.mod h1:1TqjTSzOxsLGIKfj0lK8EeCP7K1iUG65v09OM0/WG5E= | ||||
| k8s.io/kubernetes v1.13.0/go.mod h1:ocZa8+6APFNC2tX1DZASIbocyYT5jHzqFVsY5aoB7Jk= | ||||
| k8s.io/utils v0.0.0-20190221042446-c2654d5206da/go.mod h1:8k8uAuAQ0rXslZKaEWd0c3oVhZz7sSzSiPnVZayjIX0= | ||||
| k8s.io/utils v0.0.0-20190607212802-c55fbcfc754a h1:2jUDc9gJja832Ftp+QbDV0tVhQHMISFn01els+2ZAcw= | ||||
| k8s.io/utils v0.0.0-20190607212802-c55fbcfc754a/go.mod h1:sZAwmy6armz5eXlNoLmJcl4F1QuKu7sr+mFQ0byX7Ew= | ||||
| 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= | ||||
| modernc.org/strutil v1.0.0/go.mod h1:lstksw84oURvj9y3tn8lGvRxyRC1S2+g5uuIzNfIOBs= | ||||
| modernc.org/xc v1.0.0/go.mod h1:mRNCo0bvLjGhHO9WsyuKVU4q0ceiDDDoEeWDJHrNx8I= | ||||
| sigs.k8s.io/structured-merge-diff v0.0.0-20190525122527-15d366b2352e/go.mod h1:wWxsB5ozmmv/SG7nM11ayaAW51xMvak/t1r0CSlcokI= | ||||
| sigs.k8s.io/yaml v1.1.0 h1:4A07+ZFc2wgJwo8YNlQpr1rVlgUDlxXHhPJciaPY5gs= | ||||
| sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o= | ||||
|  |  | |||
|  | @ -2,7 +2,6 @@ language: go | |||
| dist: xenial | ||||
| sudo: required | ||||
| go: | ||||
|     - 1.12.x | ||||
|     - 1.13.x | ||||
|     - tip | ||||
| go_import_path: github.com/containers/buildah | ||||
|  | @ -43,7 +42,7 @@ before_install: | |||
|     - sudo apt-get -qq install software-properties-common | ||||
|     - sudo add-apt-repository -y ppa:duggan/bats | ||||
|     - sudo apt-get update | ||||
|     - sudo apt-get -qq install bats btrfs-tools git libapparmor-dev libc-dev libdevmapper-dev libglib2.0-dev libgpgme11-dev libselinux1-dev linux-libc-dev realpath e2fslibs-dev libfuse-dev | ||||
|     - sudo apt-get -qq install bats btrfs-tools git libapparmor-dev libc-dev libdevmapper-dev libglib2.0-dev libgpgme11-dev libselinux1-dev linux-libc-dev realpath e2fslibs-dev libfuse-dev codespell | ||||
|     - sudo apt-get -qq update | ||||
|     - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce | ||||
|     - mkdir /home/travis/auth | ||||
|  |  | |||
|  | @ -2,6 +2,64 @@ | |||
| 
 | ||||
| # Changelog | ||||
| 
 | ||||
| ## v1.13.1 (2020-01-14) | ||||
| Changelog for v1.13.1 (2020-01-14) | ||||
|     Bump github.com/containers/common from 0.0.5 to 0.0.7 | ||||
|     Bump github.com/onsi/ginkgo from 1.10.3 to 1.11.0 | ||||
|     Bump github.com/pkg/errors from 0.8.1 to 0.9.0 | ||||
|     Bump github.com/onsi/gomega from 1.7.1 to 1.8.1 | ||||
|     Add codespell support | ||||
|     copyFileWithTar: close source files at the right time | ||||
|     copy: don't digest files that we ignore | ||||
|     Check for .dockerignore specifically | ||||
|     Travis: rm go 1.12.x | ||||
|     Don't setup excludes, if their is only one pattern to match | ||||
|     set HOME env to /root on chroot-isolation by default | ||||
|     docs: fix references to containers-*.5 | ||||
|     update openshift/api | ||||
|     fix bug Add check .dockerignore COPY file | ||||
|     buildah bud --volume: run from tmpdir, not source dir | ||||
|     Fix imageNamePrefix to give consistent names in buildah-from | ||||
|     cpp: use -traditional and -undef flags | ||||
|     Fix image reference in tutorial 4 | ||||
|     discard outputs coming from onbuild command on buildah-from --quiet | ||||
|     make --format columnizing consistent with buildah images | ||||
|     Bump to v1.14.0-dev | ||||
|     Bump to v1.13.0 | ||||
|     Bump to c/storage v1.15.5 | ||||
|     Update container/storage to v1.15.4 | ||||
|     Fix option handling for volumes in build | ||||
|     Rework overlay pkg for use with libpod | ||||
|     Fix buildahimage builds for buildah | ||||
|     Add support for FIPS-Mode backends | ||||
|     Set the TMPDIR for pulling/pushing image to $TMPDIR | ||||
|     WIP: safer test for pull --all-tags | ||||
|     BATS major cleanup: blobcache.bats: refactor | ||||
|     BATS major cleanup: part 4: manual stuff | ||||
|     BATS major cleanup, step 3: yet more run_buildah | ||||
|     BATS major cleanup, part 2: use more run_buildah | ||||
|     BATS major cleanup, part 1: log-level | ||||
|     Bump github.com/containers/image/v5 from 5.0.0 to 5.1.0 | ||||
|     Bump github.com/containers/common from 0.0.3 to 0.0.5 | ||||
|     Bump to v1.13.0-dev | ||||
| 
 | ||||
| ## v1.13.0 (2019-12-27) | ||||
|     Bump to c/storage v1.15.5 | ||||
|     Update container/storage to v1.15.4 | ||||
|     Fix option handling for volumes in build | ||||
|     Rework overlay pkg for use with libpod | ||||
|     Fix buildahimage builds for buildah | ||||
|     Add support for FIPS-Mode backends | ||||
|     Set the TMPDIR for pulling/pushing image to $TMPDIR | ||||
|     WIP: safer test for pull --all-tags | ||||
|     BATS major cleanup: blobcache.bats: refactor | ||||
|     BATS major cleanup: part 4: manual stuff | ||||
|     BATS major cleanup, step 3: yet more run_buildah | ||||
|     BATS major cleanup, part 2: use more run_buildah | ||||
|     BATS major cleanup, part 1: log-level | ||||
|     Bump github.com/containers/image/v5 from 5.0.0 to 5.1.0 | ||||
|     Bump github.com/containers/common from 0.0.3 to 0.0.5 | ||||
|     Bump to v1.13.0-dev | ||||
| 
 | ||||
| ## v1.12.0 (2019-12-13) | ||||
|     Allow ADD to use http src | ||||
|  |  | |||
|  | @ -68,6 +68,9 @@ docs: install.tools ## build the docs on the host | |||
| gopath: | ||||
| 	test $(shell pwd) = $(shell cd ../../../../src/github.com/containers/buildah ; pwd) | ||||
| 
 | ||||
| codespell: | ||||
| 	codespell -S build,buildah,buildah.spec,imgtype,AUTHORS,bin,vendor,.git,go.sum,CHANGELOG.md,changelog.txt,seccomp.json,.cirrus.yml,"*.xz,*.gz,*.tar,*.tgz,*ico,*.png,*.1,*.5,*.orig,*.rej" -L uint,iff,od | ||||
| 
 | ||||
| .PHONY: validate | ||||
| validate: install.tools | ||||
| 	@./tests/validate/whitespace.sh | ||||
|  |  | |||
|  | @ -215,7 +215,12 @@ func dockerIgnoreMatcher(lines []string, contextDir string) (*fileutils.PatternM | |||
| 	if contextDir == "" { | ||||
| 		return nil, nil | ||||
| 	} | ||||
| 	patterns := []string{".dockerignore"} | ||||
| 	// If there's no .dockerignore file, then we don't have to add a
 | ||||
| 	// pattern to tell copy logic to ignore it later.
 | ||||
| 	var patterns []string | ||||
| 	if _, err := os.Stat(filepath.Join(contextDir, ".dockerignore")); err == nil || !os.IsNotExist(err) { | ||||
| 		patterns = []string{".dockerignore"} | ||||
| 	} | ||||
| 	for _, ignoreSpec := range lines { | ||||
| 		ignoreSpec = strings.TrimSpace(ignoreSpec) | ||||
| 		// ignore comments passed back from .dockerignore
 | ||||
|  | @ -224,7 +229,8 @@ func dockerIgnoreMatcher(lines []string, contextDir string) (*fileutils.PatternM | |||
| 		} | ||||
| 		// if the spec starts with '!' it means the pattern
 | ||||
| 		// should be included. make a note so that we can move
 | ||||
| 		// it to the front of the updated pattern
 | ||||
| 		// it to the front of the updated pattern, and insert
 | ||||
| 		// the context dir's path in between
 | ||||
| 		includeFlag := "" | ||||
| 		if strings.HasPrefix(ignoreSpec, "!") { | ||||
| 			includeFlag = "!" | ||||
|  | @ -343,6 +349,19 @@ func (b *Builder) addHelper(excludes *fileutils.PatternMatcher, extract bool, de | |||
| 				continue | ||||
| 			} | ||||
| 
 | ||||
| 			// This source is a file
 | ||||
| 			// Check if the path matches the .dockerignore
 | ||||
| 			if excludes != nil { | ||||
| 				res, err := excludes.MatchesResult(esrc) | ||||
| 				if err != nil { | ||||
| 					return errors.Wrapf(err, "error checking if %s is an excluded path", esrc) | ||||
| 				} | ||||
| 				// Skip the file if the pattern matches
 | ||||
| 				if res.IsMatched() { | ||||
| 					return nil | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			b.ContentDigester.Start("file") | ||||
| 
 | ||||
| 			if !extract || !archive.IsArchivePath(esrc) { | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ const ( | |||
| 	Package = "buildah" | ||||
| 	// Version for the Package.  Bump version in contrib/rpm/buildah.spec
 | ||||
| 	// too.
 | ||||
| 	Version = "1.12.0" | ||||
| 	Version = "1.13.1" | ||||
| 	// The value we use to identify what type of information, currently a
 | ||||
| 	// serialized Builder structure, we are using as per-container state.
 | ||||
| 	// This should only be changed when we make incompatible changes to
 | ||||
|  |  | |||
|  | @ -1,3 +1,61 @@ | |||
| - Changelog for v1.13.1 (2020-01-14) | ||||
|   * Bump github.com/containers/common from 0.0.5 to 0.0.7 | ||||
|   * Bump github.com/onsi/ginkgo from 1.10.3 to 1.11.0 | ||||
|   * Bump github.com/pkg/errors from 0.8.1 to 0.9.0 | ||||
|   * Bump github.com/onsi/gomega from 1.7.1 to 1.8.1 | ||||
|   * Add codespell support | ||||
|   * copyFileWithTar: close source files at the right time | ||||
|   * copy: don't digest files that we ignore | ||||
|   * Check for .dockerignore specifically | ||||
|   * Travis: rm go 1.12.x | ||||
|   * Don't setup excludes, if their is only one pattern to match | ||||
|   * set HOME env to /root on chroot-isolation by default | ||||
|   * docs: fix references to containers-*.5 | ||||
|   * update openshift/api | ||||
|   * fix bug Add check .dockerignore COPY file | ||||
|   * buildah bud --volume: run from tmpdir, not source dir | ||||
|   * Fix imageNamePrefix to give consistent names in buildah-from | ||||
|   * cpp: use -traditional and -undef flags | ||||
|   * Fix image reference in tutorial 4 | ||||
|   * discard outputs coming from onbuild command on buildah-from --quiet | ||||
|   * make --format columnizing consistent with buildah images | ||||
|   * Bump to v1.14.0-dev | ||||
|   * Bump to v1.13.0 | ||||
|   * Bump to c/storage v1.15.5 | ||||
|   * Update container/storage to v1.15.4 | ||||
|   * Fix option handling for volumes in build | ||||
|   * Rework overlay pkg for use with libpod | ||||
|   * Fix buildahimage builds for buildah | ||||
|   * Add support for FIPS-Mode backends | ||||
|   * Set the TMPDIR for pulling/pushing image to $TMPDIR | ||||
|   * WIP: safer test for pull --all-tags | ||||
|   * BATS major cleanup: blobcache.bats: refactor | ||||
|   * BATS major cleanup: part 4: manual stuff | ||||
|   * BATS major cleanup, step 3: yet more run_buildah | ||||
|   * BATS major cleanup, part 2: use more run_buildah | ||||
|   * BATS major cleanup, part 1: log-level | ||||
|   * Bump github.com/containers/image/v5 from 5.0.0 to 5.1.0 | ||||
|   * Bump github.com/containers/common from 0.0.3 to 0.0.5 | ||||
|   * Bump to v1.13.0-dev | ||||
| 
 | ||||
| - Changelog for v1.13.0 (2019-12-27) | ||||
|   * Bump to c/storage v1.15.5 | ||||
|   * Update container/storage to v1.15.4 | ||||
|   * Fix option handling for volumes in build | ||||
|   * Rework overlay pkg for use with libpod | ||||
|   * Fix buildahimage builds for buildah | ||||
|   * Add support for FIPS-Mode backends | ||||
|   * Set the TMPDIR for pulling/pushing image to $TMPDIR | ||||
|   * WIP: safer test for pull --all-tags | ||||
|   * BATS major cleanup: blobcache.bats: refactor | ||||
|   * BATS major cleanup: part 4: manual stuff | ||||
|   * BATS major cleanup, step 3: yet more run_buildah | ||||
|   * BATS major cleanup, part 2: use more run_buildah | ||||
|   * BATS major cleanup, part 1: log-level | ||||
|   * Bump github.com/containers/image/v5 from 5.0.0 to 5.1.0 | ||||
|   * Bump github.com/containers/common from 0.0.3 to 0.0.5 | ||||
|   * Bump to v1.13.0-dev | ||||
| 
 | ||||
| - Changelog for v1.12.0 (2019-12-13) | ||||
|   * Allow ADD to use http src | ||||
|   * Bump to c/storage v.1.15.3 | ||||
|  |  | |||
|  | @ -5,12 +5,11 @@ go 1.12 | |||
| require ( | ||||
| 	github.com/blang/semver v3.5.0+incompatible // indirect | ||||
| 	github.com/containernetworking/cni v0.7.1 | ||||
| 	github.com/containers/common v0.0.3 | ||||
| 	github.com/containers/image/v5 v5.0.0 | ||||
| 	github.com/containers/storage v1.15.3 | ||||
| 	github.com/containers/common v0.0.7 | ||||
| 	github.com/containers/image/v5 v5.1.0 | ||||
| 	github.com/containers/storage v1.15.5 | ||||
| 	github.com/cyphar/filepath-securejoin v0.2.2 | ||||
| 	github.com/docker/distribution v2.7.1+incompatible | ||||
| 	github.com/docker/docker-credential-helpers v0.6.1 // indirect | ||||
| 	github.com/docker/go-metrics v0.0.1 // indirect | ||||
| 	github.com/docker/go-units v0.4.0 | ||||
| 	github.com/docker/libnetwork v0.8.0-dev.2.0.20190625141545-5a177b73e316 | ||||
|  | @ -18,21 +17,20 @@ require ( | |||
| 	github.com/fsouza/go-dockerclient v1.6.0 | ||||
| 	github.com/ghodss/yaml v1.0.0 | ||||
| 	github.com/hashicorp/go-multierror v1.0.0 | ||||
| 	github.com/imdario/mergo v0.3.6 // indirect | ||||
| 	github.com/ishidawataru/sctp v0.0.0-20180918013207-6e2cb1366111 // indirect | ||||
| 	github.com/mattn/go-shellwords v1.0.6 | ||||
| 	github.com/morikuni/aec v1.0.0 // indirect | ||||
| 	github.com/onsi/ginkgo v1.10.3 | ||||
| 	github.com/onsi/gomega v1.7.1 | ||||
| 	github.com/onsi/ginkgo v1.11.0 | ||||
| 	github.com/onsi/gomega v1.8.1 | ||||
| 	github.com/opencontainers/go-digest v1.0.0-rc1 | ||||
| 	github.com/opencontainers/image-spec v1.0.2-0.20190823105129-775207bd45b6 | ||||
| 	github.com/opencontainers/runc v1.0.0-rc9 | ||||
| 	github.com/opencontainers/runtime-spec v0.1.2-0.20190618234442-a950415649c7 | ||||
| 	github.com/opencontainers/runtime-tools v0.9.0 | ||||
| 	github.com/opencontainers/selinux v1.3.0 | ||||
| 	github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible | ||||
| 	github.com/openshift/api v0.0.0-20200106203948-7ab22a2c8316 | ||||
| 	github.com/openshift/imagebuilder v1.1.1 | ||||
| 	github.com/pkg/errors v0.8.1 | ||||
| 	github.com/pkg/errors v0.9.0 | ||||
| 	github.com/seccomp/containers-golang v0.0.0-20180629143253-cdfdaa7543f4 | ||||
| 	github.com/seccomp/libseccomp-golang v0.9.1 | ||||
| 	github.com/sirupsen/logrus v1.4.2 | ||||
|  | @ -43,10 +41,8 @@ require ( | |||
| 	github.com/vishvananda/netlink v1.0.0 // indirect | ||||
| 	github.com/vishvananda/netns v0.0.0-20190625233234-7109fa855b0f // indirect | ||||
| 	github.com/xeipuuv/gojsonschema v1.1.0 // indirect | ||||
| 	golang.org/x/crypto v0.0.0-20190927123631-a832865fa7ad | ||||
| 	golang.org/x/crypto v0.0.0-20191112222119-e1110fd1c708 | ||||
| 	golang.org/x/sys v0.0.0-20191127021746-63cb32ae39b2 | ||||
| 	golang.org/x/time v0.0.0-20190921001708-c4c64cad1fd0 // indirect | ||||
| 	google.golang.org/grpc v1.24.0 // indirect | ||||
| 	k8s.io/api v0.0.0-20190813020757-36bff7324fb7 // indirect | ||||
| 	k8s.io/client-go v0.0.0-20181219152756-3dd551c0f083 // indirect | ||||
| ) | ||||
|  |  | |||
|  | @ -5,6 +5,7 @@ github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78 h1:w+iIsaOQNcT7O | |||
| github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78/go.mod h1:LmzpDX56iTiv29bbRTIsUNlaFfuhWRQBWjQdVyAevI8= | ||||
| github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= | ||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||
| github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= | ||||
| github.com/DataDog/zstd v1.4.0 h1:vhoV+DUHnRZdKW1i5UMjAk2G4JY8wN4ayRfYDNdEhwo= | ||||
| github.com/DataDog/zstd v1.4.0/go.mod h1:1jcaCB/ufaK+sKp1NBhlGmpz41jOoPQ35bpF36t7BBo= | ||||
| github.com/Microsoft/go-winio v0.4.12 h1:xAfWHN1IrQ0NJ9TBC0KBZoqLjzDTr1ML+4MywiUOryc= | ||||
|  | @ -21,7 +22,9 @@ github.com/Microsoft/hcsshim v0.8.7 h1:ptnOoufxGSzauVTsdE+wMYnCWA301PdoN4xg5oRdZ | |||
| github.com/Microsoft/hcsshim v0.8.7/go.mod h1:OHd7sQqRFrYd3RmSgbgji+ctCwkbq2wbEYNSzOYtcBQ= | ||||
| github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ= | ||||
| github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= | ||||
| github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= | ||||
| github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= | ||||
| github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= | ||||
| github.com/VividCortex/ewma v1.1.1 h1:MnEK4VOv6n0RSY4vtRe3h11qjxL3+t0B8yOL8iMXdcM= | ||||
| github.com/VividCortex/ewma v1.1.1/go.mod h1:2Tkkvm3sRDVXaiyucHiACn4cqf7DpdyLvmxzcbUokwA= | ||||
| github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= | ||||
|  | @ -38,6 +41,7 @@ github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDk | |||
| github.com/containerd/cgroups v0.0.0-20190919134610-bf292b21730f h1:tSNMc+rJDfmYntojat8lljbt1mgKNpTxUZJsSzJ9Y1s= | ||||
| github.com/containerd/cgroups v0.0.0-20190919134610-bf292b21730f/go.mod h1:OApqhQ4XNSNC13gXIwDjhOQxjWa/NxkwZXJ1EvqT0ko= | ||||
| github.com/containerd/console v0.0.0-20180822173158-c12b1e7919c1/go.mod h1:Tj/on1eG8kiEhd0+fhSDzsPAFESxzBBvdyEgyryXffw= | ||||
| github.com/containerd/containerd v1.2.10/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA= | ||||
| github.com/containerd/containerd v1.3.0-beta.2.0.20190828155532-0293cbd26c69/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA= | ||||
| github.com/containerd/containerd v1.3.0 h1:xjvXQWABwS2uiv3TWgQt5Uth60Gu86LTGZXMJkjc7rY= | ||||
| github.com/containerd/containerd v1.3.0/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA= | ||||
|  | @ -54,12 +58,20 @@ github.com/containernetworking/cni v0.7.1 h1:fE3r16wpSEyaqY4Z4oFrLMmIGfBYIKpPrHK | |||
| github.com/containernetworking/cni v0.7.1/go.mod h1:LGwApLUm2FpoOfxTDEeq8T9ipbpZ61X79hmU3w8FmsY= | ||||
| github.com/containers/common v0.0.3 h1:C2Zshb0w720FqPa42MCRuiGfbW0kwbURRwvK1EWIC5I= | ||||
| github.com/containers/common v0.0.3/go.mod h1:CaOgMRiwi2JJHISMZ6VPPZhQYFUDRv3YYVss2RqUCMg= | ||||
| github.com/containers/common v0.0.5 h1:Hi4+eyUZx8hXB4reLNPbdT6XT8MGMAzdlbg8V+WifkQ= | ||||
| github.com/containers/common v0.0.5/go.mod h1:lhWV3MLhO1+KGE2x6v9+K38MxpjXGso+edmpkFnCOqI= | ||||
| github.com/containers/common v0.0.7 h1:eKYZLKfJ2d/RNDgecLDFv45cHb4imYzIcrQHx1Y029M= | ||||
| github.com/containers/common v0.0.7/go.mod h1:lhWV3MLhO1+KGE2x6v9+K38MxpjXGso+edmpkFnCOqI= | ||||
| github.com/containers/image/v4 v4.0.1 h1:idNGHChj0Pyv3vLrxul2oSVMZLeFqpoq3CjLeVgapSQ= | ||||
| github.com/containers/image/v4 v4.0.1/go.mod h1:0ASJH1YgJiX/eqFZObqepgsvIA4XjCgpyfwn9pDGafA= | ||||
| github.com/containers/image/v5 v5.0.0 h1:arnXgbt1ucsC/ndtSpiQY87rA0UjhF+/xQnPzqdBDn4= | ||||
| github.com/containers/image/v5 v5.0.0/go.mod h1:MgiLzCfIeo8lrHi+4Lb8HP+rh513sm0Mlk6RrhjFOLY= | ||||
| github.com/containers/image/v5 v5.1.0 h1:5FjAvPJniamuNNIQHkh4PnsL+n+xzs6Aonzaz5dqTEo= | ||||
| github.com/containers/image/v5 v5.1.0/go.mod h1:BKlMD34WxRo1ruGHHEOrPQP0Qci7SWoPwU6fS7arsCU= | ||||
| github.com/containers/libtrust v0.0.0-20190913040956-14b96171aa3b h1:Q8ePgVfHDplZ7U33NwHZkrVELsZP5fYj9pM5WBZB2GE= | ||||
| github.com/containers/libtrust v0.0.0-20190913040956-14b96171aa3b/go.mod h1:9rfv8iPl1ZP7aqh9YA68wnZv2NUDbXdcdPHVz0pFbPY= | ||||
| github.com/containers/ocicrypt v0.0.0-20190930154801-b87a4a69c741 h1:8tQkOcednLJtUcZgK7sPglscXtxvMOnFOa6wd09VWLM= | ||||
| github.com/containers/ocicrypt v0.0.0-20190930154801-b87a4a69c741/go.mod h1:MeJDzk1RJHv89LjsH0Sp5KTY3ZYkjXO/C+bKAeWFIrc= | ||||
| github.com/containers/storage v1.13.2/go.mod h1:6D8nK2sU9V7nEmAraINRs88ZEscM5C5DK+8Npp27GeA= | ||||
| github.com/containers/storage v1.13.4 h1:j0bBaJDKbUHtAW1MXPFnwXJtqcH+foWeuXK1YaBV5GA= | ||||
| github.com/containers/storage v1.13.4/go.mod h1:6D8nK2sU9V7nEmAraINRs88ZEscM5C5DK+8Npp27GeA= | ||||
|  | @ -77,6 +89,10 @@ github.com/containers/storage v1.15.2 h1:hLgafU4tuyQk/smMkXZfHTS8FtAQsqQvfWCp4bs | |||
| github.com/containers/storage v1.15.2/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/containers/storage v1.15.3 h1:+lFSQZnnKUFyUEtguIgdoQLJfWSuYz+j/wg5GxLtsN4= | ||||
| github.com/containers/storage v1.15.3/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/containers/storage v1.15.4 h1:eiUtV9MOTnPHibO18nDRI+aDhKudY7WmAiJdyVMsqSM= | ||||
| github.com/containers/storage v1.15.4/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/containers/storage v1.15.5 h1:dBZx9yRFHod9c8FVaXlVtRqr2cmlAhpl+9rt87cE7J4= | ||||
| github.com/containers/storage v1.15.5/go.mod h1:v0lq/3f+cXH3Y/HiDaFYRR0zilwDve7I4W7U5xQxvF8= | ||||
| github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= | ||||
| github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= | ||||
| github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= | ||||
|  | @ -84,6 +100,7 @@ github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7 | |||
| github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f h1:JOrtw2xFKzlg+cbHpyrpLDmnN1HqhBfnX7WDiW7eG2c= | ||||
| github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= | ||||
| github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE= | ||||
| github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= | ||||
| github.com/cyphar/filepath-securejoin v0.2.2 h1:jCwT2GTP+PY5nBz3c/YL5PAIbusElVrPujOBSCj8xRg= | ||||
| github.com/cyphar/filepath-securejoin v0.2.2/go.mod h1:FpkQEhXnPnOthhzymB7CGsFk2G9VLXONKD9G7QGMM+4= | ||||
| github.com/davecgh/go-spew v0.0.0-20151105211317-5215b55f46b2/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||
|  | @ -104,6 +121,8 @@ github.com/docker/docker v1.4.2-0.20191101170500-ac7306503d23/go.mod h1:eEKB0N0r | |||
| github.com/docker/docker-credential-helpers v0.6.0/go.mod h1:WRaJzqw3CTB9bk10avuGsjVBZsD05qeibJ1/TYlvc0Y= | ||||
| github.com/docker/docker-credential-helpers v0.6.1 h1:Dq4iIfcM7cNtddhLVWe9h4QDjsi4OER3Z8voPu/I52g= | ||||
| github.com/docker/docker-credential-helpers v0.6.1/go.mod h1:WRaJzqw3CTB9bk10avuGsjVBZsD05qeibJ1/TYlvc0Y= | ||||
| github.com/docker/docker-credential-helpers v0.6.3 h1:zI2p9+1NQYdnG6sMU26EX4aVGlqbInSQxQXLvzJ4RPQ= | ||||
| github.com/docker/docker-credential-helpers v0.6.3/go.mod h1:WRaJzqw3CTB9bk10avuGsjVBZsD05qeibJ1/TYlvc0Y= | ||||
| github.com/docker/go-connections v0.0.0-20180212134524-7beb39f0b969/go.mod h1:Gbd7IOopHjR8Iph03tsViu4nIes5XhDvyHbTtUxmeec= | ||||
| github.com/docker/go-connections v0.4.0 h1:El9xVISelRB7BuFusrZozjnkIM5YnzCViNKohAFqRJQ= | ||||
| github.com/docker/go-connections v0.4.0/go.mod h1:Gbd7IOopHjR8Iph03tsViu4nIes5XhDvyHbTtUxmeec= | ||||
|  | @ -118,6 +137,7 @@ github.com/docker/libtrust v0.0.0-20160708172513-aabc10ec26b7/go.mod h1:cyGadeNE | |||
| github.com/docker/spdystream v0.0.0-20160310174837-449fdfce4d96/go.mod h1:Qh8CwZgvJUkLughtfhJv5dyTYa91l1fOUCrgjqmcifM= | ||||
| github.com/elazarl/goproxy v0.0.0-20170405201442-c4fc26588b6e/go.mod h1:/Zj4wYkgs4iZTTu3o/KG3Itv/qCCa8VVMlb3i9OVuzc= | ||||
| github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= | ||||
| github.com/emicklei/go-restful v2.9.5+incompatible/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= | ||||
| github.com/etcd-io/bbolt v1.3.3 h1:gSJmxrs37LgTqR/oyJBWok6k6SvXEUerFTbltIhXkBM= | ||||
| github.com/etcd-io/bbolt v1.3.3/go.mod h1:ZF2nL25h33cCyBtcyWeZ2/I3HQOfTP+0PIEvHjkjCrw= | ||||
| github.com/evanphx/json-patch v4.2.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= | ||||
|  | @ -129,6 +149,8 @@ github.com/fsouza/go-dockerclient v1.5.0 h1:7OtayOe5HnoG+KWMHgyyPymwaodnB2IDYuVf | |||
| github.com/fsouza/go-dockerclient v1.5.0/go.mod h1:AqZZK/zFO3phxYxlTsAaeAMSdQ9mgHuhy+bjN034Qds= | ||||
| github.com/fsouza/go-dockerclient v1.6.0 h1:f7j+AX94143JL1H3TiqSMkM4EcLDI0De1qD4GGn3Hig= | ||||
| github.com/fsouza/go-dockerclient v1.6.0/go.mod h1:YWwtNPuL4XTX1SKJQk86cWPmmqwx+4np9qfPbb+znGc= | ||||
| github.com/fullsailor/pkcs7 v0.0.0-20190404230743-d7302db945fa h1:RDBNVkRviHZtvDvId8XSGPu3rmpmSe+wKRcEWNgsfWU= | ||||
| github.com/fullsailor/pkcs7 v0.0.0-20190404230743-d7302db945fa/go.mod h1:KnogPXtdwXqoenmZCw6S+25EAm2MkxbG0deNDu4cbSA= | ||||
| github.com/ghodss/yaml v0.0.0-20150909031657-73d445a93680/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= | ||||
| github.com/ghodss/yaml v0.0.0-20161207003320-04f313413ffd/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= | ||||
| github.com/ghodss/yaml v1.0.0 h1:wQHKEahhL6wmXdzwWG11gIVCkOv05bNOh+Rxn0yngAk= | ||||
|  | @ -136,10 +158,18 @@ github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeME | |||
| github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= | ||||
| github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= | ||||
| github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= | ||||
| github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas= | ||||
| github.com/go-openapi/jsonpointer v0.0.0-20160704185906-46af16f9f7b1/go.mod h1:+35s3my2LFTysnkMfxsJBAMHj/DoqoB9knIWoYG/Vk0= | ||||
| github.com/go-openapi/jsonpointer v0.19.2/go.mod h1:3akKfEdA7DF1sugOqz1dVQHBcuDBPKZGEoHC/NkiQRg= | ||||
| github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= | ||||
| github.com/go-openapi/jsonreference v0.0.0-20160704190145-13c6e3589ad9/go.mod h1:W3Z9FmVs9qj+KR4zFKmDPGiLdk1D9Rlm7cyMvf57TTg= | ||||
| github.com/go-openapi/jsonreference v0.19.2/go.mod h1:jMjeRr2HHw6nAVajTXJ4eiUwohSTlpa0o73RUL1owJc= | ||||
| github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8= | ||||
| github.com/go-openapi/spec v0.0.0-20160808142527-6aced65f8501/go.mod h1:J8+jY1nAiCcj+friV/PDoE1/3eeccG9LYBs0tYvLOWc= | ||||
| github.com/go-openapi/spec v0.19.3/go.mod h1:FpwSN1ksY1eteniUU7X0N/BgJ7a4WvBFVA8Lj9mJglo= | ||||
| github.com/go-openapi/swag v0.0.0-20160704191624-1d0bd113de87/go.mod h1:DXUve3Dpr1UfpPtxFw+EFuQ41HhCWZfha5jSVRG7C7I= | ||||
| github.com/go-openapi/swag v0.19.2/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= | ||||
| github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= | ||||
| github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= | ||||
| github.com/godbus/dbus v0.0.0-20190422162347-ade71ed3457e h1:BWhy2j3IXJhjCbC68FptL43tDKIq8FladmaTs3Xs7Z8= | ||||
| github.com/godbus/dbus v0.0.0-20190422162347-ade71ed3457e/go.mod h1:bBOAhwG1umN6/6ZUMtDFBMQR8jRg9O75tm9K00oMsK4= | ||||
|  | @ -191,6 +221,8 @@ github.com/ijc/Gotty v0.0.0-20170406111628-a8b993ba6abd/go.mod h1:3LVOLeyx9XVvwP | |||
| github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= | ||||
| github.com/imdario/mergo v0.3.6 h1:xTNEAn+kxVO7dTZGu0CegyqKZmoWFI0rF8UxjlB2d28= | ||||
| github.com/imdario/mergo v0.3.6/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= | ||||
| github.com/imdario/mergo v0.3.8 h1:CGgOkSJeqMRmt0D9XLWExdT4m4F1vd3FV3VPt+0VxkQ= | ||||
| github.com/imdario/mergo v0.3.8/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= | ||||
| github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NHg9XEKhtSvM= | ||||
| github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= | ||||
| github.com/ishidawataru/sctp v0.0.0-20180918013207-6e2cb1366111 h1:NAAiV9ass6VReWFjuxqrMIq12WKlSULI6Gs3PxQghLA= | ||||
|  | @ -199,6 +231,7 @@ github.com/json-iterator/go v0.0.0-20180612202835-f2b4162afba3/go.mod h1:+SdeFBv | |||
| github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= | ||||
| github.com/json-iterator/go v1.1.7 h1:KfgG9LzI+pYjr4xvmz/5H4FXjokeP+rlHLhv3iH62Fo= | ||||
| github.com/json-iterator/go v1.1.7/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= | ||||
| github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= | ||||
| github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= | ||||
| github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q= | ||||
| github.com/kisielk/errcheck v1.2.0/go.mod h1:/BMXB+zMLi60iA8Vv6Ksmxu/1UDYcXs4uQLJ+jE2L00= | ||||
|  | @ -227,10 +260,14 @@ github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFB | |||
| github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI= | ||||
| github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= | ||||
| github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= | ||||
| github.com/kr/pty v1.1.5/go.mod h1:9r2w37qlBe7rQ6e1fg1S/9xpWHSnaqNdHD3WcMdbPDA= | ||||
| github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= | ||||
| github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= | ||||
| github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= | ||||
| github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= | ||||
| github.com/mailru/easyjson v0.7.0/go.mod h1:KAzv3t3aY1NaHWoQz1+4F1ccyAH66Jk7yos7ldAVICs= | ||||
| github.com/mattn/go-isatty v0.0.4 h1:bnP0vzxcAdeI1zdubAl5PjU6zsERjGZb7raWodagDYs= | ||||
| github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= | ||||
| github.com/mattn/go-shellwords v1.0.5 h1:JhhFTIOslh5ZsPrpa3Wdg8bF0WI3b44EMblmU9wIsXc= | ||||
|  | @ -269,6 +306,8 @@ github.com/onsi/ginkgo v1.10.2 h1:uqH7bpe+ERSiDa34FDOF7RikN6RzXgduUF8yarlZp94= | |||
| github.com/onsi/ginkgo v1.10.2/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.10.3 h1:OoxbjfXVZyod1fmWYhI7SEyaD8B00ynP3T+D5GiyHOY= | ||||
| github.com/onsi/ginkgo v1.10.3/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/ginkgo v1.11.0 h1:JAKSXpt1YjtLA7YpPiqO9ss6sNXEsPfSGdwN0UHqzrw= | ||||
| github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= | ||||
| github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= | ||||
| github.com/onsi/gomega v1.5.0 h1:izbySO9zDPmjJ8rDjLvkA2zJHIo+HkYXHnf7eN7SSyo= | ||||
| github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
|  | @ -276,6 +315,8 @@ github.com/onsi/gomega v1.7.0 h1:XPnZz8VVBHjVsy1vzJmRwIcSwiUO+JFfrv/xGiigmME= | |||
| github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= | ||||
| github.com/onsi/gomega v1.7.1 h1:K0jcRCwNQM3vFGh1ppMtDh/+7ApJrjldlX8fA0jDTLQ= | ||||
| github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= | ||||
| github.com/onsi/gomega v1.8.1 h1:C5Dqfs/LeauYDX0jJXIe2SWmwCbGzx9yF8C8xy3Lh34= | ||||
| github.com/onsi/gomega v1.8.1/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA= | ||||
| github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
| github.com/opencontainers/go-digest v1.0.0-rc1 h1:WzifXhOVOEOuFYOJAW6aQqW0TooG2iki3E3Ii+WN7gQ= | ||||
| github.com/opencontainers/go-digest v1.0.0-rc1/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= | ||||
|  | @ -301,6 +342,8 @@ github.com/opencontainers/selinux v1.2.2 h1:Kx9J6eDG5/24A6DtUquGSpJQ+m2MUTahn4Ft | |||
| github.com/opencontainers/selinux v1.2.2/go.mod h1:+BLncwf63G4dgOzykXAxcmnFlUaOlkDdmw/CqsW6pjs= | ||||
| github.com/opencontainers/selinux v1.3.0 h1:xsI95WzPZu5exzA6JzkLSfdr/DilzOhCJOqGe5TgR0g= | ||||
| github.com/opencontainers/selinux v1.3.0/go.mod h1:+BLncwf63G4dgOzykXAxcmnFlUaOlkDdmw/CqsW6pjs= | ||||
| github.com/openshift/api v0.0.0-20200106203948-7ab22a2c8316 h1:enQG2QUGwug4fR1yM6hL0Fjzx6Km/exZY6RbSPwMu3o= | ||||
| github.com/openshift/api v0.0.0-20200106203948-7ab22a2c8316/go.mod h1:dv+J0b/HWai0QnMVb37/H0v36klkLBi2TNpPeWDxX10= | ||||
| github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible h1:s55wx8JIG/CKnewev892HifTBrtKzMdvgB3rm4rxC2s= | ||||
| github.com/openshift/api v3.9.1-0.20190810003144-27fb16909b15+incompatible/go.mod h1:dh9o4Fs58gpFXGSYfnVxGR9PnV53I8TW84pQaJDdGiY= | ||||
| github.com/openshift/imagebuilder v1.1.0 h1:oT704SkwMEzmIMU/+Uv1Wmvt+p10q3v2WuYMeFI18c4= | ||||
|  | @ -313,6 +356,8 @@ github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/9 | |||
| github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.8.1 h1:iURUrRGxPUNPdy5/HRSm+Yj6okJ6UtLINN0Q9M4+h3I= | ||||
| github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pkg/errors v0.9.0 h1:J8lpUdobwIeCI7OiSxHqEwJUKvJwicL5+3v1oe2Yb4k= | ||||
| github.com/pkg/errors v0.9.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||
| github.com/pmezard/go-difflib v0.0.0-20151028094244-d8ed2627bdf0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||
| github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | ||||
| github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||
|  | @ -336,7 +381,9 @@ github.com/prometheus/procfs v0.0.3 h1:CTwfnzjQ+8dS6MhHHu4YswVAD99sL2wjPqP+VkURm | |||
| github.com/prometheus/procfs v0.0.3/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ= | ||||
| github.com/prometheus/procfs v0.0.5 h1:3+auTFlqw+ZaQYJARz6ArODtkaIwtvBTx3N2NehQlL8= | ||||
| github.com/prometheus/procfs v0.0.5/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ= | ||||
| github.com/remyoudompheng/bigfft v0.0.0-20170806203942-52369c62f446/go.mod h1:uYEyJGbgTkfkS4+E/PavXkNJcbFIpEtjt2B0KDQ5+9M= | ||||
| github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g= | ||||
| github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | ||||
| github.com/saschagrunert/storage v1.12.3-0.20191015073819-a34ddea087da h1:5aEGhStFh+0r/t0kT0utSi5C6MIMHBgMHkeIu1JUvfA= | ||||
| github.com/saschagrunert/storage v1.12.3-0.20191015073819-a34ddea087da/go.mod h1:imKnA8Ozb99yPWt64WPrtNOR0v0HKQZFH4oLV45N22k= | ||||
| github.com/saschagrunert/storage v1.12.3-0.20191018073047-1d43d5290f84 h1:iBs6FOO2GpFpdaa3WC4XhqHI6S2LE7RTlgn8LodsXVo= | ||||
|  | @ -365,6 +412,7 @@ github.com/seccomp/containers-golang v0.0.0-20180629143253-cdfdaa7543f4 h1:rOG9o | |||
| github.com/seccomp/containers-golang v0.0.0-20180629143253-cdfdaa7543f4/go.mod h1:f/98/SnvAzhAEFQJ3u836FePXvcbE8BS0YGMQNn4mhA= | ||||
| github.com/seccomp/libseccomp-golang v0.9.1 h1:NJjM5DNFOs0s3kYE1WUOr6G8V97sdt46rlXTMfXGWBo= | ||||
| github.com/seccomp/libseccomp-golang v0.9.1/go.mod h1:GbW5+tmTXfcxTToHLXlScSlAvWlF4P2Ca7zGrPiEpWo= | ||||
| github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= | ||||
| github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= | ||||
| github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q= | ||||
| github.com/sirupsen/logrus v1.4.2 h1:SPIRibHv4MatM3XXNO2BJeFLZwZ2LvZgfQ5+UNI2im4= | ||||
|  | @ -383,6 +431,7 @@ github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DM | |||
| github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/objx v0.1.1 h1:2vfRuCMp5sSVIDSqO8oNnWJq7mPa6KVP3iPIwFBuy8A= | ||||
| github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE= | ||||
| github.com/stretchr/testify v0.0.0-20151208002404-e3a8ff8ce365/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= | ||||
| github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= | ||||
| github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0Q= | ||||
|  | @ -398,10 +447,13 @@ github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljT | |||
| github.com/ulikunitz/xz v0.5.6 h1:jGHAfXawEGZQ3blwU5wnWKQJvAraT7Ftq9EXjnXYgt8= | ||||
| github.com/ulikunitz/xz v0.5.6/go.mod h1:2bypXElzHzzJZwzH67Y6wb67pO62Rzfn7BSiF4ABRW8= | ||||
| github.com/urfave/cli v0.0.0-20171014202726-7bc6a0acffa5/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA= | ||||
| github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0= | ||||
| github.com/vbatts/tar-split v0.11.1 h1:0Odu65rhcZ3JZaPHxl7tCI3V/C/Q9Zf82UFravl02dE= | ||||
| github.com/vbatts/tar-split v0.11.1/go.mod h1:LEuURwDEiWjRjwu46yU3KVGuUdVv/dcnpcEPSzR8z6g= | ||||
| github.com/vbauerster/mpb v3.4.0+incompatible h1:mfiiYw87ARaeRW6x5gWwYRUawxaW1tLAD8IceomUCNw= | ||||
| github.com/vbauerster/mpb v3.4.0+incompatible/go.mod h1:zAHG26FUhVKETRu+MWqYXcI70POlC6N8up9p1dID7SU= | ||||
| github.com/vbauerster/mpb/v4 v4.11.1 h1:ZOYQSVHgmeanXsbyC44aDg76tBGCS/54Rk8VkL8dJGA= | ||||
| github.com/vbauerster/mpb/v4 v4.11.1/go.mod h1:vMLa1J/ZKC83G2lB/52XpqT+ZZtFG4aZOdKhmpRL1uM= | ||||
| github.com/vishvananda/netlink v1.0.0 h1:bqNY2lgheFIu1meHUFSH3d7vG93AFyqg3oGbJCOJgSM= | ||||
| github.com/vishvananda/netlink v1.0.0/go.mod h1:+SR5DhBJrl6ZM7CoCKvpw5BKroDKQ+PJqOg65H/2ktk= | ||||
| github.com/vishvananda/netns v0.0.0-20190625233234-7109fa855b0f h1:nBX3nTcmxEtHSERBJaIo1Qa26VwRaopnZmfDQUXsF4I= | ||||
|  | @ -425,14 +477,21 @@ golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnf | |||
| golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2 h1:VklqNMn3ovrHsnt90PveolxSbWFaJdECFbxSq0Mqo2M= | ||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||
| golang.org/x/crypto v0.0.0-20190611184440-5c40567a22f8/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4 h1:HuIa8hRrWRSrqYzx1qI49NNxhdi2PrY7gxVSq1JjLDc= | ||||
| golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20190927123631-a832865fa7ad h1:5E5raQxcv+6CZ11RrBYQe5WRbUIWpScjh0kvHZkZIrQ= | ||||
| golang.org/x/crypto v0.0.0-20190927123631-a832865fa7ad/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||
| golang.org/x/crypto v0.0.0-20191112222119-e1110fd1c708 h1:pXVtWnwHkrWD9ru3sDxY/qFK/bfc0egRovX91EjWjf4= | ||||
| golang.org/x/crypto v0.0.0-20191112222119-e1110fd1c708/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||
| golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= | ||||
| golang.org/x/exp v0.0.0-20190312203227-4b39c73a6495/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= | ||||
| golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= | ||||
| golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= | ||||
| golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU= | ||||
| golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= | ||||
| golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU15maQ/Ox0txvL9dWGYEHz965HBQE= | ||||
| golang.org/x/net v0.0.0-20170114055629-f2499483f923/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
| golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= | ||||
|  | @ -443,8 +502,12 @@ golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn | |||
| golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= | ||||
| golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190628185345-da137c7871d7 h1:rTIdg5QFRR7XCaK4LCjBiPbx8j4DQRpdYMnGn/bJUEU= | ||||
| golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/net v0.0.0-20191004110552-13f9640d40b9 h1:rjwSpXsdiK0dV8/Naq3kAw9ymfAeJIyd0upUIElB+lI= | ||||
| golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= | ||||
| golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | ||||
| golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
| golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||
|  | @ -460,6 +523,7 @@ golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5h | |||
| golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/sys v0.0.0-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190422165155-953cdadca894 h1:Cz4ceDQGXuKRnVBDTS23GTn/pU5OE2C0WrNTOYK1Uuc= | ||||
| golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
|  | @ -473,10 +537,12 @@ golang.org/x/sys v0.0.0-20190710143415-6ec70d6a5542 h1:6ZQFf1D2YYDDI7eSwW8adlkka | |||
| golang.org/x/sys v0.0.0-20190710143415-6ec70d6a5542/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190801041406-cbf593c0f2f3 h1:4y9KwBHBgBNwDbtu44R5o1fdOCQUEXhbk/P4A9WmJq0= | ||||
| golang.org/x/sys v0.0.0-20190801041406-cbf593c0f2f3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190902133755-9109b7679e13 h1:tdsQdquKbTNMsSZLqnLELJGzCANp9oXhu6zFBW6ODx4= | ||||
| golang.org/x/sys v0.0.0-20190902133755-9109b7679e13/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3 h1:7TYNF4UdlohbFwpNH04CoPMp1cHUZgO1Ebq5r2hIjfo= | ||||
| golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191113165036-4c7a9d0fe056/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/sys v0.0.0-20191127021746-63cb32ae39b2 h1:/J2nHFg1MTqaRLFO7M+J78ASNsJoz3r0cvHBPQ77fsE= | ||||
| golang.org/x/sys v0.0.0-20191127021746-63cb32ae39b2/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||
| golang.org/x/text v0.0.0-20160726164857-2910a502d2bf/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
|  | @ -492,9 +558,18 @@ golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGm | |||
| golang.org/x/tools v0.0.0-20181011042414-1f849cf54d09/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190206041539-40960b6deb8e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | ||||
| golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= | ||||
| golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= | ||||
| golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= | ||||
| golang.org/x/tools v0.0.0-20190614205625-5aca471b1d59/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= | ||||
| golang.org/x/tools v0.0.0-20190920225731-5eefd052ad72/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7 h1:9zdDQZ7Thm29KFXgAX/+yaf3eVbP7djjWp/dXAppNCc= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| gonum.org/v1/gonum v0.0.0-20190331200053-3d26580ed485/go.mod h1:2ltnJ7xHfj0zHS40VVPYEAAMTa3ZGguvHGBSJeRWqE0= | ||||
| gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= | ||||
| gonum.org/v1/netlib v0.0.0-20190331212654-76723241ea4e/go.mod h1:kS+toOQn6AQKjmKJ7gzohV1XkqsFehRA2FbsbkopSuQ= | ||||
| google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= | ||||
| google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= | ||||
| google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= | ||||
|  | @ -518,6 +593,10 @@ gopkg.in/fsnotify.v1 v1.4.7 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4= | |||
| gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys= | ||||
| gopkg.in/inf.v0 v0.9.0 h1:3zYtXIO92bvsdS3ggAdA8Gb4Azj0YU+TVY1uGYNFA8o= | ||||
| gopkg.in/inf.v0 v0.9.0/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= | ||||
| gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc= | ||||
| gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= | ||||
| gopkg.in/square/go-jose.v2 v2.3.1 h1:SK5KegNXmKmqE342YYN2qPHEnUYeoMiXXl1poUlI+o4= | ||||
| gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI= | ||||
| gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= | ||||
| gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= | ||||
| gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
|  | @ -532,17 +611,31 @@ honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWh | |||
| honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| k8s.io/api v0.0.0-20190813020757-36bff7324fb7 h1:4uJOjRn9kWq4AqJRE8+qzmAy+lJd9rh8TY455dNef4U= | ||||
| k8s.io/api v0.0.0-20190813020757-36bff7324fb7/go.mod h1:3Iy+myeAORNCLgjd/Xu9ebwN7Vh59Bw0vh9jhoX+V58= | ||||
| k8s.io/api v0.17.0 h1:H9d/lw+VkZKEVIUc8F3wgiQ+FUXTTr21M87jXLU7yqM= | ||||
| k8s.io/api v0.17.0/go.mod h1:npsyOePkeP0CPwyGfXDHxvypiYMJxBWAMpQxCaJ4ZxI= | ||||
| k8s.io/apimachinery v0.0.0-20190809020650-423f5d784010 h1:pyoq062NftC1y/OcnbSvgolyZDJ8y4fmUPWMkdA6gfU= | ||||
| k8s.io/apimachinery v0.0.0-20190809020650-423f5d784010/go.mod h1:Waf/xTS2FGRrgXCkO5FP3XxTOWh0qLf2QhL1qFZZ/R8= | ||||
| k8s.io/apimachinery v0.17.0 h1:xRBnuie9rXcPxUkDizUsGvPf1cnlZCFu210op7J7LJo= | ||||
| k8s.io/apimachinery v0.17.0/go.mod h1:b9qmWdKlLuU9EBh+06BtLcSf/Mu89rWL33naRxs1uZg= | ||||
| k8s.io/client-go v0.0.0-20170217214107-bcde30fb7eae/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= | ||||
| k8s.io/client-go v0.0.0-20181219152756-3dd551c0f083 h1:+Qf/nITucAbm09aIdxvoA+7X0BwaXmQGVoR8k7Ynk9o= | ||||
| k8s.io/client-go v0.0.0-20181219152756-3dd551c0f083/go.mod h1:7vJpHMYJwNQCWgzmNV+VYUl1zCObLyodBc8nIyt8L5s= | ||||
| k8s.io/code-generator v0.17.0/go.mod h1:DVmfPQgxQENqDIzVR2ddLXMH34qeszkKSdH/N+s+38s= | ||||
| k8s.io/gengo v0.0.0-20190128074634-0689ccc1d7d6/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/gengo v0.0.0-20190822140433-26a664648505/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= | ||||
| k8s.io/klog v0.0.0-20181102134211-b9b56d5dfc92/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v0.3.1 h1:RVgyDHY/kFKtLqh67NvEWIgkMneNoIrdkN0CxDSQc68= | ||||
| k8s.io/klog v0.3.1/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= | ||||
| k8s.io/klog v1.0.0 h1:Pt+yjF5aB1xDSVbau4VsWe+dQNzA0qv1LlXdC2dF6Q8= | ||||
| k8s.io/klog v1.0.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= | ||||
| k8s.io/kube-openapi v0.0.0-20190709113604-33be087ad058/go.mod h1:nfDlWeOsu3pUf4yWGL+ERqohP4YsZcBJXWMK+gkzOA4= | ||||
| k8s.io/kube-openapi v0.0.0-20191107075043-30be4d16710a/go.mod h1:1TqjTSzOxsLGIKfj0lK8EeCP7K1iUG65v09OM0/WG5E= | ||||
| k8s.io/kubernetes v1.13.0/go.mod h1:ocZa8+6APFNC2tX1DZASIbocyYT5jHzqFVsY5aoB7Jk= | ||||
| 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= | ||||
| modernc.org/strutil v1.0.0/go.mod h1:lstksw84oURvj9y3tn8lGvRxyRC1S2+g5uuIzNfIOBs= | ||||
| modernc.org/xc v1.0.0/go.mod h1:mRNCo0bvLjGhHO9WsyuKVU4q0ceiDDDoEeWDJHrNx8I= | ||||
| sigs.k8s.io/structured-merge-diff v0.0.0-20190525122527-15d366b2352e/go.mod h1:wWxsB5ozmmv/SG7nM11ayaAW51xMvak/t1r0CSlcokI= | ||||
| sigs.k8s.io/yaml v1.1.0 h1:4A07+ZFc2wgJwo8YNlQpr1rVlgUDlxXHhPJciaPY5gs= | ||||
| sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o= | ||||
|  |  | |||
|  | @ -280,7 +280,7 @@ func preprocessDockerfileContents(r io.Reader, ctxDir string) (rdrCloser *io.Rea | |||
| 	stdout := bytes.Buffer{} | ||||
| 	stderr := bytes.Buffer{} | ||||
| 
 | ||||
| 	cmd := exec.Command(cppPath, "-E", "-iquote", ctxDir, "-") | ||||
| 	cmd := exec.Command(cppPath, "-E", "-iquote", ctxDir, "-traditional", "-undef", "-") | ||||
| 	cmd.Stdout = &stdout | ||||
| 	cmd.Stderr = &stderr | ||||
| 
 | ||||
|  |  | |||
|  | @ -68,14 +68,14 @@ func getImageName(name string, img *storage.Image) string { | |||
| 
 | ||||
| func imageNamePrefix(imageName string) string { | ||||
| 	prefix := imageName | ||||
| 	s := strings.Split(imageName, "/") | ||||
| 	if len(s) > 0 { | ||||
| 		prefix = s[len(s)-1] | ||||
| 	} | ||||
| 	s = strings.Split(prefix, ":") | ||||
| 	s := strings.Split(prefix, ":") | ||||
| 	if len(s) > 0 { | ||||
| 		prefix = s[0] | ||||
| 	} | ||||
| 	s = strings.Split(prefix, "/") | ||||
| 	if len(s) > 0 { | ||||
| 		prefix = s[len(s)-1] | ||||
| 	} | ||||
| 	s = strings.Split(prefix, "@") | ||||
| 	if len(s) > 0 { | ||||
| 		prefix = s[0] | ||||
|  |  | |||
|  | @ -25,9 +25,11 @@ func GetUser(rootdir, userspec string) (uint32, uint32, string, error) { | |||
| 	spec := strings.SplitN(userspec, ":", 2) | ||||
| 	userspec = spec[0] | ||||
| 	groupspec := "" | ||||
| 
 | ||||
| 	if userspec == "" { | ||||
| 		return 0, 0, "/", nil | ||||
| 		userspec = "0" | ||||
| 	} | ||||
| 
 | ||||
| 	if len(spec) > 1 { | ||||
| 		groupspec = spec[1] | ||||
| 	} | ||||
|  |  | |||
|  | @ -209,7 +209,7 @@ func GetFromAndBudFlags(flags *FromAndBudResults, usernsResults *UserNSResults, | |||
| 	fs.StringArrayVar(&flags.SecurityOpt, "security-opt", []string{}, "security options (default [])") | ||||
| 	fs.StringVar(&flags.ShmSize, "shm-size", "65536k", "size of '/dev/shm'. The format is `<number><unit>`.") | ||||
| 	fs.StringSliceVar(&flags.Ulimit, "ulimit", []string{}, "ulimit options (default [])") | ||||
| 	fs.StringSliceVarP(&flags.Volumes, "volume", "v", []string{}, "bind mount a volume into the container (default [])") | ||||
| 	fs.StringArrayVarP(&flags.Volumes, "volume", "v", []string{}, "bind mount a volume into the container (default [])") | ||||
| 
 | ||||
| 	// Add in the usernamespace and namespaceflags
 | ||||
| 	usernsFlags := GetUserNSFlags(usernsResults) | ||||
|  |  | |||
|  | @ -9,46 +9,48 @@ import ( | |||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/containers/common/pkg/unshare" | ||||
| 	"github.com/containers/storage" | ||||
| 	"github.com/containers/storage/pkg/idtools" | ||||
| 	"github.com/containers/storage/pkg/system" | ||||
| 	"github.com/opencontainers/runtime-spec/specs-go" | ||||
| 	"github.com/pkg/errors" | ||||
| 	"golang.org/x/sys/unix" | ||||
| ) | ||||
| 
 | ||||
| // MountTemp creates a subdir of the contentDir based on the source directory
 | ||||
| // from the source system.  It then mounts up the source directory on to the
 | ||||
| // generated mount point and returns the mount point to the caller.
 | ||||
| func MountTemp(store storage.Store, containerID, source, dest string, rootUID, rootGID int) (mount specs.Mount, contentDir string, Err error) { | ||||
| // TempDir generates an overlay Temp directory in the container content
 | ||||
| func TempDir(containerDir string, rootUID, rootGID int) (string, error) { | ||||
| 
 | ||||
| 	containerDir, err := store.ContainerDirectory(containerID) | ||||
| 	if err != nil { | ||||
| 		return mount, "", err | ||||
| 	} | ||||
| 	contentDir = filepath.Join(containerDir, "overlay") | ||||
| 	contentDir := filepath.Join(containerDir, "overlay") | ||||
| 	if err := idtools.MkdirAllAs(contentDir, 0700, rootUID, rootGID); err != nil { | ||||
| 		return mount, "", errors.Wrapf(err, "failed to create the overlay %s directory", contentDir) | ||||
| 		return "", errors.Wrapf(err, "failed to create the overlay %s directory", contentDir) | ||||
| 	} | ||||
| 
 | ||||
| 	contentDir, err = ioutil.TempDir(contentDir, "") | ||||
| 	contentDir, err := ioutil.TempDir(contentDir, "") | ||||
| 	if err != nil { | ||||
| 		return mount, "", errors.Wrapf(err, "failed to create TempDir in the overlay %s directory", contentDir) | ||||
| 		return "", errors.Wrapf(err, "failed to create the overlay tmpdir in %s directory", contentDir) | ||||
| 	} | ||||
| 	defer func() { | ||||
| 		if Err != nil { | ||||
| 			os.RemoveAll(contentDir) | ||||
| 		} | ||||
| 	}() | ||||
| 
 | ||||
| 	upperDir := filepath.Join(contentDir, "upper") | ||||
| 	workDir := filepath.Join(contentDir, "work") | ||||
| 	if err := idtools.MkdirAllAs(upperDir, 0700, rootUID, rootGID); err != nil { | ||||
| 		return mount, "", errors.Wrapf(err, "failed to create the overlay %s directory", upperDir) | ||||
| 		return "", errors.Wrapf(err, "failed to create the overlay %s directory", upperDir) | ||||
| 	} | ||||
| 	if err := idtools.MkdirAllAs(workDir, 0700, rootUID, rootGID); err != nil { | ||||
| 		return mount, "", errors.Wrapf(err, "failed to create the overlay %s directory", workDir) | ||||
| 		return "", errors.Wrapf(err, "failed to create the overlay %s directory", workDir) | ||||
| 	} | ||||
| 	mergeDir := filepath.Join(contentDir, "merge") | ||||
| 	if err := idtools.MkdirAllAs(mergeDir, 0700, rootUID, rootGID); err != nil { | ||||
| 		return "", errors.Wrapf(err, "failed to create the overlay %s directory", mergeDir) | ||||
| 	} | ||||
| 
 | ||||
| 	return contentDir, nil | ||||
| } | ||||
| 
 | ||||
| // Mount creates a subdir of the contentDir based on the source directory
 | ||||
| // from the source system.  It then mounts up the source directory on to the
 | ||||
| // generated mount point and returns the mount point to the caller.
 | ||||
| func Mount(contentDir, source, dest string, rootUID, rootGID int, graphOptions []string) (mount specs.Mount, Err error) { | ||||
| 	upperDir := filepath.Join(contentDir, "upper") | ||||
| 	workDir := filepath.Join(contentDir, "work") | ||||
| 	mergeDir := filepath.Join(contentDir, "merge") | ||||
| 	overlayOptions := fmt.Sprintf("lowerdir=%s,upperdir=%s,workdir=%s,private", source, upperDir, workDir) | ||||
| 
 | ||||
| 	if unshare.IsRootless() { | ||||
|  | @ -60,36 +62,30 @@ func MountTemp(store storage.Store, containerID, source, dest string, rootUID, r | |||
| 			"overlay2.mount_program": true, | ||||
| 		} | ||||
| 
 | ||||
| 		for _, i := range store.GraphOptions() { | ||||
| 		for _, i := range graphOptions { | ||||
| 			s := strings.SplitN(i, "=", 2) | ||||
| 			if len(s) != 2 { | ||||
| 				continue | ||||
| 			} | ||||
| 			k := s[0] | ||||
| 			v := s[1] | ||||
| 			if mountMap[k] { | ||||
| 				mountProgram = v | ||||
| 			key := s[0] | ||||
| 			val := s[1] | ||||
| 			if mountMap[key] { | ||||
| 				mountProgram = val | ||||
| 				break | ||||
| 			} | ||||
| 		} | ||||
| 		if mountProgram != "" { | ||||
| 			mergeDir := filepath.Join(contentDir, "merge") | ||||
| 
 | ||||
| 			if err := idtools.MkdirAllAs(mergeDir, 0700, rootUID, rootGID); err != nil { | ||||
| 				return mount, "", errors.Wrapf(err, "failed to create the overlay %s directory", mergeDir) | ||||
| 			} | ||||
| 
 | ||||
| 			cmd := exec.Command(mountProgram, "-o", overlayOptions, mergeDir) | ||||
| 
 | ||||
| 			if err := cmd.Run(); err != nil { | ||||
| 				return mount, "", errors.Wrapf(err, "exec %s", mountProgram) | ||||
| 				return mount, errors.Wrapf(err, "exec %s", mountProgram) | ||||
| 			} | ||||
| 
 | ||||
| 			mount.Source = mergeDir | ||||
| 			mount.Destination = dest | ||||
| 			mount.Type = "bind" | ||||
| 			mount.Options = []string{"bind", "slave"} | ||||
| 			return mount, contentDir, nil | ||||
| 			return mount, nil | ||||
| 		} | ||||
| 		/* If a mount_program is not specified, fallback to try mount native overlay.  */ | ||||
| 	} | ||||
|  | @ -99,23 +95,59 @@ func MountTemp(store storage.Store, containerID, source, dest string, rootUID, r | |||
| 	mount.Type = "overlay" | ||||
| 	mount.Options = strings.Split(overlayOptions, ",") | ||||
| 
 | ||||
| 	return mount, contentDir, nil | ||||
| 	return mount, nil | ||||
| } | ||||
| 
 | ||||
| // RemoveTemp removes temporary mountpoint and all content from its parent
 | ||||
| // directory
 | ||||
| func RemoveTemp(contentDir string) error { | ||||
| 	if unshare.IsRootless() { | ||||
| 		mergeDir := filepath.Join(contentDir, "merge") | ||||
| 		if err := unix.Unmount(mergeDir, 0); err != nil { | ||||
| 			if !os.IsNotExist(err) { | ||||
| 				return errors.Wrapf(err, "unmount overlay %s", mergeDir) | ||||
| 			} | ||||
| 		if err := Unmount(contentDir); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	return os.RemoveAll(contentDir) | ||||
| } | ||||
| 
 | ||||
| // Unmount the overlay mountpoint
 | ||||
| func Unmount(contentDir string) (Err error) { | ||||
| 	mergeDir := filepath.Join(contentDir, "merge") | ||||
| 	if err := unix.Unmount(mergeDir, 0); err != nil && !os.IsNotExist(err) { | ||||
| 		return errors.Wrapf(err, "unmount overlay %s", mergeDir) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func recreate(contentDir string) error { | ||||
| 	st, err := system.Stat(contentDir) | ||||
| 	if err != nil { | ||||
| 		if os.IsNotExist(err) { | ||||
| 			return nil | ||||
| 		} | ||||
| 		return errors.Wrapf(err, "failed to stat overlay upper %s directory", contentDir) | ||||
| 	} | ||||
| 
 | ||||
| 	if err := os.RemoveAll(contentDir); err != nil { | ||||
| 		return errors.Wrapf(err, "failed to cleanup overlay %s directory", contentDir) | ||||
| 	} | ||||
| 
 | ||||
| 	if err := idtools.MkdirAllAs(contentDir, os.FileMode(st.Mode()), int(st.UID()), int(st.GID())); err != nil { | ||||
| 		return errors.Wrapf(err, "failed to create the overlay %s directory", contentDir) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // CleanupMount removes all temporary mountpoint content
 | ||||
| func CleanupMount(contentDir string) (Err error) { | ||||
| 	if err := recreate(filepath.Join(contentDir, "upper")); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := recreate(filepath.Join(contentDir, "work")); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // CleanupContent removes all temporary mountpoint and all content from
 | ||||
| // directory
 | ||||
| func CleanupContent(containerDir string) (Err error) { | ||||
|  |  | |||
|  | @ -102,7 +102,7 @@ func CommonBuildOptions(c *cobra.Command) (*buildah.CommonBuildOptions, error) { | |||
| 	if _, err := units.FromHumanSize(c.Flag("shm-size").Value.String()); err != nil { | ||||
| 		return nil, errors.Wrapf(err, "invalid --shm-size") | ||||
| 	} | ||||
| 	volumes, _ := c.Flags().GetStringSlice("volume") | ||||
| 	volumes, _ := c.Flags().GetStringArray("volume") | ||||
| 	if err := Volumes(volumes); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | @ -589,6 +589,7 @@ func SystemContextFromOptions(c *cobra.Command) (*types.SystemContext, error) { | |||
| 	if arch, err := c.Flags().GetString("override-arch"); err == nil { | ||||
| 		ctx.ArchitectureChoice = arch | ||||
| 	} | ||||
| 	ctx.BigFilesTemporaryDir = GetTempDir() | ||||
| 	return ctx, nil | ||||
| } | ||||
| 
 | ||||
|  | @ -956,3 +957,10 @@ func isValidDeviceMode(mode string) bool { | |||
| 	} | ||||
| 	return true | ||||
| } | ||||
| 
 | ||||
| func GetTempDir() string { | ||||
| 	if tmpdir, ok := os.LookupEnv("TMPDIR"); ok { | ||||
| 		return tmpdir | ||||
| 	} | ||||
| 	return "/var/tmp" | ||||
| } | ||||
|  |  | |||
|  | @ -148,12 +148,21 @@ func getMountsMap(path string) (string, string, error) { | |||
| } | ||||
| 
 | ||||
| // SecretMounts copies, adds, and mounts the secrets to the container root filesystem
 | ||||
| // Deprecated, Please use SecretMountWithUIDGID
 | ||||
| func SecretMounts(mountLabel, containerWorkingDir, mountFile string, rootless, disableFips bool) []rspec.Mount { | ||||
| 	return SecretMountsWithUIDGID(mountLabel, containerWorkingDir, mountFile, containerWorkingDir, 0, 0, rootless, disableFips) | ||||
| } | ||||
| 
 | ||||
| // SecretMountsWithUIDGID specifies the uid/gid of the owner
 | ||||
| func SecretMountsWithUIDGID(mountLabel, containerWorkingDir, mountFile, mountPrefix string, uid, gid int, rootless, disableFips bool) []rspec.Mount { | ||||
| // SecretMountsWithUIDGID copies, adds, and mounts the secrets to the container root filesystem
 | ||||
| // mountLabel: MAC/SELinux label for container content
 | ||||
| // containerWorkingDir: Private data for storing secrets on the host mounted in container.
 | ||||
| // mountFile: Additional mount points required for the container.
 | ||||
| // mountPoint: Container image mountpoint
 | ||||
| // uid: to assign to content created for secrets
 | ||||
| // gid: to assign to content created for secrets
 | ||||
| // rootless: indicates whether container is running in rootless mode
 | ||||
| // disableFips: indicates whether system should ignore fips mode
 | ||||
| func SecretMountsWithUIDGID(mountLabel, containerWorkingDir, mountFile, mountPoint string, uid, gid int, rootless, disableFips bool) []rspec.Mount { | ||||
| 	var ( | ||||
| 		secretMounts []rspec.Mount | ||||
| 		mountFiles   []string | ||||
|  | @ -171,7 +180,7 @@ func SecretMountsWithUIDGID(mountLabel, containerWorkingDir, mountFile, mountPre | |||
| 	} | ||||
| 	for _, file := range mountFiles { | ||||
| 		if _, err := os.Stat(file); err == nil { | ||||
| 			mounts, err := addSecretsFromMountsFile(file, mountLabel, containerWorkingDir, mountPrefix, uid, gid) | ||||
| 			mounts, err := addSecretsFromMountsFile(file, mountLabel, containerWorkingDir, uid, gid) | ||||
| 			if err != nil { | ||||
| 				logrus.Warnf("error mounting secrets, skipping entry in %s: %v", file, err) | ||||
| 			} | ||||
|  | @ -187,7 +196,7 @@ func SecretMountsWithUIDGID(mountLabel, containerWorkingDir, mountFile, mountPre | |||
| 	// Add FIPS mode secret if /etc/system-fips exists on the host
 | ||||
| 	_, err := os.Stat("/etc/system-fips") | ||||
| 	if err == nil { | ||||
| 		if err := addFIPSModeSecret(&secretMounts, containerWorkingDir, mountPrefix, mountLabel, uid, gid); err != nil { | ||||
| 		if err := addFIPSModeSecret(&secretMounts, containerWorkingDir, mountPoint, mountLabel, uid, gid); err != nil { | ||||
| 			logrus.Errorf("error adding FIPS mode secret to container: %v", err) | ||||
| 		} | ||||
| 	} else if os.IsNotExist(err) { | ||||
|  | @ -206,7 +215,7 @@ func rchown(chowndir string, uid, gid int) error { | |||
| 
 | ||||
| // addSecretsFromMountsFile copies the contents of host directory to container directory
 | ||||
| // and returns a list of mounts
 | ||||
| func addSecretsFromMountsFile(filePath, mountLabel, containerWorkingDir, mountPrefix string, uid, gid int) ([]rspec.Mount, error) { | ||||
| func addSecretsFromMountsFile(filePath, mountLabel, containerWorkingDir string, uid, gid int) ([]rspec.Mount, error) { | ||||
| 	var mounts []rspec.Mount | ||||
| 	defaultMountsPaths := getMounts(filePath) | ||||
| 	for _, path := range defaultMountsPaths { | ||||
|  | @ -285,7 +294,7 @@ func addSecretsFromMountsFile(filePath, mountLabel, containerWorkingDir, mountPr | |||
| 		} | ||||
| 
 | ||||
| 		m := rspec.Mount{ | ||||
| 			Source:      filepath.Join(mountPrefix, ctrDirOrFile), | ||||
| 			Source:      ctrDirOrFileOnHost, | ||||
| 			Destination: ctrDirOrFile, | ||||
| 			Type:        "bind", | ||||
| 			Options:     []string{"bind", "rprivate"}, | ||||
|  | @ -300,15 +309,15 @@ func addSecretsFromMountsFile(filePath, mountLabel, containerWorkingDir, mountPr | |||
| // root filesystem if /etc/system-fips exists on hosts.
 | ||||
| // This enables the container to be FIPS compliant and run openssl in
 | ||||
| // FIPS mode as the host is also in FIPS mode.
 | ||||
| func addFIPSModeSecret(mounts *[]rspec.Mount, containerWorkingDir, mountPrefix, mountLabel string, uid, gid int) error { | ||||
| func addFIPSModeSecret(mounts *[]rspec.Mount, containerWorkingDir, mountPoint, mountLabel string, uid, gid int) error { | ||||
| 	secretsDir := "/run/secrets" | ||||
| 	ctrDirOnHost := filepath.Join(containerWorkingDir, secretsDir) | ||||
| 	if _, err := os.Stat(ctrDirOnHost); os.IsNotExist(err) { | ||||
| 		if err = idtools.MkdirAllAs(ctrDirOnHost, 0755, uid, gid); err != nil { | ||||
| 			return errors.Wrapf(err, "making container directory on host failed") | ||||
| 			return errors.Wrapf(err, "making container directory %q on host failed", ctrDirOnHost) | ||||
| 		} | ||||
| 		if err = label.Relabel(ctrDirOnHost, mountLabel, false); err != nil { | ||||
| 			return errors.Wrap(err, "error applying correct labels") | ||||
| 			return errors.Wrapf(err, "error applying correct labels on %q", ctrDirOnHost) | ||||
| 		} | ||||
| 	} | ||||
| 	fipsFile := filepath.Join(ctrDirOnHost, "system-fips") | ||||
|  | @ -323,7 +332,7 @@ func addFIPSModeSecret(mounts *[]rspec.Mount, containerWorkingDir, mountPrefix, | |||
| 
 | ||||
| 	if !mountExists(*mounts, secretsDir) { | ||||
| 		m := rspec.Mount{ | ||||
| 			Source:      filepath.Join(mountPrefix, secretsDir), | ||||
| 			Source:      ctrDirOnHost, | ||||
| 			Destination: secretsDir, | ||||
| 			Type:        "bind", | ||||
| 			Options:     []string{"bind", "rprivate"}, | ||||
|  | @ -331,6 +340,25 @@ func addFIPSModeSecret(mounts *[]rspec.Mount, containerWorkingDir, mountPrefix, | |||
| 		*mounts = append(*mounts, m) | ||||
| 	} | ||||
| 
 | ||||
| 	srcBackendDir := "/usr/share/crypto-policies/back-ends/FIPS" | ||||
| 	destDir := "/etc/crypto-policies/back-ends" | ||||
| 	srcOnHost := filepath.Join(mountPoint, srcBackendDir) | ||||
| 	if _, err := os.Stat(srcOnHost); err != nil { | ||||
| 		if os.IsNotExist(err) { | ||||
| 			return nil | ||||
| 		} | ||||
| 		return errors.Wrapf(err, "failed to stat FIPS Backend directory %q", ctrDirOnHost) | ||||
| 	} | ||||
| 
 | ||||
| 	if !mountExists(*mounts, destDir) { | ||||
| 		m := rspec.Mount{ | ||||
| 			Source:      srcOnHost, | ||||
| 			Destination: destDir, | ||||
| 			Type:        "bind", | ||||
| 			Options:     []string{"bind", "rprivate"}, | ||||
| 		} | ||||
| 		*mounts = append(*mounts, m) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -460,7 +460,7 @@ func (b *Builder) setupMounts(mountPoint string, spec *specs.Spec, bundlePath st | |||
| 	} | ||||
| 
 | ||||
| 	// Get the list of secrets mounts.
 | ||||
| 	secretMounts := secrets.SecretMountsWithUIDGID(b.MountLabel, cdir, b.DefaultMountsFilePath, cdir, int(rootUID), int(rootGID), unshare.IsRootless(), false) | ||||
| 	secretMounts := secrets.SecretMountsWithUIDGID(b.MountLabel, cdir, b.DefaultMountsFilePath, mountPoint, int(rootUID), int(rootGID), unshare.IsRootless(), false) | ||||
| 
 | ||||
| 	// Add temporary copies of the contents of volume locations at the
 | ||||
| 	// volume locations, unless we already have something there.
 | ||||
|  | @ -1670,7 +1670,17 @@ func (b *Builder) runSetupVolumeMounts(mountLabel string, volumeMounts []string, | |||
| 			} | ||||
| 		} | ||||
| 		if foundO { | ||||
| 			overlayMount, contentDir, err := overlay.MountTemp(b.store, b.ContainerID, host, container, rootUID, rootGID) | ||||
| 			containerDir, err := b.store.ContainerDirectory(b.ContainerID) | ||||
| 			if err != nil { | ||||
| 				return specs.Mount{}, err | ||||
| 			} | ||||
| 
 | ||||
| 			contentDir, err := overlay.TempDir(containerDir, rootUID, rootGID) | ||||
| 			if err != nil { | ||||
| 				return specs.Mount{}, errors.Wrapf(err, "failed to create TempDir in the %s directory", containerDir) | ||||
| 			} | ||||
| 
 | ||||
| 			overlayMount, err := overlay.Mount(contentDir, host, container, rootUID, rootGID, b.store.GraphOptions()) | ||||
| 			if err == nil { | ||||
| 
 | ||||
| 				b.TempVolumes[contentDir] = true | ||||
|  |  | |||
|  | @ -165,11 +165,6 @@ func (b *Builder) copyFileWithTar(tarIDMappingOptions *IDMappingOptions, chownOp | |||
| 				if err != nil { | ||||
| 					return errors.Wrapf(err, "error opening %q to copy its contents", src) | ||||
| 				} | ||||
| 				defer func() { | ||||
| 					if err := f.Close(); err != nil { | ||||
| 						logrus.Debugf("error closing %s: %v", fi.Name(), err) | ||||
| 					} | ||||
| 				}() | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
|  | @ -200,6 +195,9 @@ func (b *Builder) copyFileWithTar(tarIDMappingOptions *IDMappingOptions, chownOp | |||
| 					logrus.Debugf("error copying contents of %s: %v", fi.Name(), err) | ||||
| 					copyErr = err | ||||
| 				} | ||||
| 				if err = srcFile.Close(); err != nil { | ||||
| 					logrus.Debugf("error closing %s: %v", fi.Name(), err) | ||||
| 				} | ||||
| 			} | ||||
| 			if err = writer.Close(); err != nil { | ||||
| 				logrus.Debugf("error closing write pipe for %s: %v", hdr.Name, err) | ||||
|  | @ -213,7 +211,6 @@ func (b *Builder) copyFileWithTar(tarIDMappingOptions *IDMappingOptions, chownOp | |||
| 		if err == nil { | ||||
| 			err = copyErr | ||||
| 		} | ||||
| 		f = nil | ||||
| 		if pipeWriter != nil { | ||||
| 			pipeWriter.Close() | ||||
| 		} | ||||
|  |  | |||
|  | @ -1,593 +1,22 @@ | |||
| // +build linux
 | ||||
| 
 | ||||
| package unshare | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"os" | ||||
| 	"os/exec" | ||||
| 	"os/user" | ||||
| 	"runtime" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 	"syscall" | ||||
| 
 | ||||
| 	"github.com/containers/storage/pkg/idtools" | ||||
| 	"github.com/containers/storage/pkg/reexec" | ||||
| 	"github.com/opencontainers/runtime-spec/specs-go" | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/syndtr/gocapability/capability" | ||||
| ) | ||||
| 
 | ||||
| // Cmd wraps an exec.Cmd created by the reexec package in unshare(), and
 | ||||
| // handles setting ID maps and other related settings by triggering
 | ||||
| // initialization code in the child.
 | ||||
| type Cmd struct { | ||||
| 	*exec.Cmd | ||||
| 	UnshareFlags               int | ||||
| 	UseNewuidmap               bool | ||||
| 	UidMappings                []specs.LinuxIDMapping | ||||
| 	UseNewgidmap               bool | ||||
| 	GidMappings                []specs.LinuxIDMapping | ||||
| 	GidMappingsEnableSetgroups bool | ||||
| 	Setsid                     bool | ||||
| 	Setpgrp                    bool | ||||
| 	Ctty                       *os.File | ||||
| 	OOMScoreAdj                *int | ||||
| 	Hook                       func(pid int) error | ||||
| } | ||||
| 
 | ||||
| // Command creates a new Cmd which can be customized.
 | ||||
| func Command(args ...string) *Cmd { | ||||
| 	cmd := reexec.Command(args...) | ||||
| 	return &Cmd{ | ||||
| 		Cmd: cmd, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Start() error { | ||||
| 	runtime.LockOSThread() | ||||
| 	defer runtime.UnlockOSThread() | ||||
| 
 | ||||
| 	// Set an environment variable to tell the child to synchronize its startup.
 | ||||
| 	if c.Env == nil { | ||||
| 		c.Env = os.Environ() | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-unshare=%d", c.UnshareFlags)) | ||||
| 
 | ||||
| 	// Please the libpod "rootless" package to find the expected env variables.
 | ||||
| 	if os.Geteuid() != 0 { | ||||
| 		c.Env = append(c.Env, "_CONTAINERS_USERNS_CONFIGURED=done") | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_CONTAINERS_ROOTLESS_UID=%d", os.Geteuid())) | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_CONTAINERS_ROOTLESS_GID=%d", os.Getegid())) | ||||
| 	} | ||||
| 
 | ||||
| 	// Create the pipe for reading the child's PID.
 | ||||
| 	pidRead, pidWrite, err := os.Pipe() | ||||
| 	if err != nil { | ||||
| 		return errors.Wrapf(err, "error creating pid pipe") | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-pid-pipe=%d", len(c.ExtraFiles)+3)) | ||||
| 	c.ExtraFiles = append(c.ExtraFiles, pidWrite) | ||||
| 
 | ||||
| 	// Create the pipe for letting the child know to proceed.
 | ||||
| 	continueRead, continueWrite, err := os.Pipe() | ||||
| 	if err != nil { | ||||
| 		pidRead.Close() | ||||
| 		pidWrite.Close() | ||||
| 		return errors.Wrapf(err, "error creating pid pipe") | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-continue-pipe=%d", len(c.ExtraFiles)+3)) | ||||
| 	c.ExtraFiles = append(c.ExtraFiles, continueRead) | ||||
| 
 | ||||
| 	// Pass along other instructions.
 | ||||
| 	if c.Setsid { | ||||
| 		c.Env = append(c.Env, "_Containers-setsid=1") | ||||
| 	} | ||||
| 	if c.Setpgrp { | ||||
| 		c.Env = append(c.Env, "_Containers-setpgrp=1") | ||||
| 	} | ||||
| 	if c.Ctty != nil { | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_Containers-ctty=%d", len(c.ExtraFiles)+3)) | ||||
| 		c.ExtraFiles = append(c.ExtraFiles, c.Ctty) | ||||
| 	} | ||||
| 
 | ||||
| 	// Make sure we clean up our pipes.
 | ||||
| 	defer func() { | ||||
| 		if pidRead != nil { | ||||
| 			pidRead.Close() | ||||
| 		} | ||||
| 		if pidWrite != nil { | ||||
| 			pidWrite.Close() | ||||
| 		} | ||||
| 		if continueRead != nil { | ||||
| 			continueRead.Close() | ||||
| 		} | ||||
| 		if continueWrite != nil { | ||||
| 			continueWrite.Close() | ||||
| 		} | ||||
| 	}() | ||||
| 
 | ||||
| 	// Start the new process.
 | ||||
| 	err = c.Cmd.Start() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	// Close the ends of the pipes that the parent doesn't need.
 | ||||
| 	continueRead.Close() | ||||
| 	continueRead = nil | ||||
| 	pidWrite.Close() | ||||
| 	pidWrite = nil | ||||
| 
 | ||||
| 	// Read the child's PID from the pipe.
 | ||||
| 	pidString := "" | ||||
| 	b := new(bytes.Buffer) | ||||
| 	if _, err := io.Copy(b, pidRead); err != nil { | ||||
| 		return errors.Wrapf(err, "error reading child PID") | ||||
| 	} | ||||
| 	pidString = b.String() | ||||
| 	pid, err := strconv.Atoi(pidString) | ||||
| 	if err != nil { | ||||
| 		fmt.Fprintf(continueWrite, "error parsing PID %q: %v", pidString, err) | ||||
| 		return errors.Wrapf(err, "error parsing PID %q", pidString) | ||||
| 	} | ||||
| 	pidString = fmt.Sprintf("%d", pid) | ||||
| 
 | ||||
| 	// If we created a new user namespace, set any specified mappings.
 | ||||
| 	if c.UnshareFlags&syscall.CLONE_NEWUSER != 0 { | ||||
| 		// Always set "setgroups".
 | ||||
| 		setgroups, err := os.OpenFile(fmt.Sprintf("/proc/%s/setgroups", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 		if err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error opening setgroups: %v", err) | ||||
| 			return errors.Wrapf(err, "error opening /proc/%s/setgroups", pidString) | ||||
| 		} | ||||
| 		defer setgroups.Close() | ||||
| 		if c.GidMappingsEnableSetgroups { | ||||
| 			if _, err := fmt.Fprintf(setgroups, "allow"); err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error writing \"allow\" to setgroups: %v", err) | ||||
| 				return errors.Wrapf(err, "error opening \"allow\" to /proc/%s/setgroups", pidString) | ||||
| 			} | ||||
| 		} else { | ||||
| 			if _, err := fmt.Fprintf(setgroups, "deny"); err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error writing \"deny\" to setgroups: %v", err) | ||||
| 				return errors.Wrapf(err, "error writing \"deny\" to /proc/%s/setgroups", pidString) | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.UidMappings) == 0 || len(c.GidMappings) == 0 { | ||||
| 			uidmap, gidmap, err := GetHostIDMappings("") | ||||
| 			if err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error reading ID mappings in parent: %v", err) | ||||
| 				return errors.Wrapf(err, "error reading ID mappings in parent") | ||||
| 			} | ||||
| 			if len(c.UidMappings) == 0 { | ||||
| 				c.UidMappings = uidmap | ||||
| 				for i := range c.UidMappings { | ||||
| 					c.UidMappings[i].HostID = c.UidMappings[i].ContainerID | ||||
| 				} | ||||
| 			} | ||||
| 			if len(c.GidMappings) == 0 { | ||||
| 				c.GidMappings = gidmap | ||||
| 				for i := range c.GidMappings { | ||||
| 					c.GidMappings[i].HostID = c.GidMappings[i].ContainerID | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.GidMappings) > 0 { | ||||
| 			// Build the GID map, since writing to the proc file has to be done all at once.
 | ||||
| 			g := new(bytes.Buffer) | ||||
| 			for _, m := range c.GidMappings { | ||||
| 				fmt.Fprintf(g, "%d %d %d\n", m.ContainerID, m.HostID, m.Size) | ||||
| 			} | ||||
| 			gidmapSet := false | ||||
| 			// Set the GID map.
 | ||||
| 			if c.UseNewgidmap { | ||||
| 				cmd := exec.Command("newgidmap", append([]string{pidString}, strings.Fields(strings.Replace(g.String(), "\n", " ", -1))...)...) | ||||
| 				g.Reset() | ||||
| 				cmd.Stdout = g | ||||
| 				cmd.Stderr = g | ||||
| 				err := cmd.Run() | ||||
| 				if err == nil { | ||||
| 					gidmapSet = true | ||||
| 				} else { | ||||
| 					logrus.Warnf("error running newgidmap: %v: %s", err, g.String()) | ||||
| 					logrus.Warnf("falling back to single mapping") | ||||
| 					g.Reset() | ||||
| 					g.Write([]byte(fmt.Sprintf("0 %d 1\n", os.Getegid()))) | ||||
| 				} | ||||
| 			} | ||||
| 			if !gidmapSet { | ||||
| 				if c.UseNewgidmap { | ||||
| 					setgroups, err := os.OpenFile(fmt.Sprintf("/proc/%s/setgroups", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 					if err != nil { | ||||
| 						fmt.Fprintf(continueWrite, "error opening /proc/%s/setgroups: %v", pidString, err) | ||||
| 						return errors.Wrapf(err, "error opening /proc/%s/setgroups", pidString) | ||||
| 					} | ||||
| 					defer setgroups.Close() | ||||
| 					if _, err := fmt.Fprintf(setgroups, "deny"); err != nil { | ||||
| 						fmt.Fprintf(continueWrite, "error writing 'deny' to /proc/%s/setgroups: %v", pidString, err) | ||||
| 						return errors.Wrapf(err, "error writing 'deny' to /proc/%s/setgroups", pidString) | ||||
| 					} | ||||
| 				} | ||||
| 				gidmap, err := os.OpenFile(fmt.Sprintf("/proc/%s/gid_map", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 				if err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error opening /proc/%s/gid_map: %v", pidString, err) | ||||
| 					return errors.Wrapf(err, "error opening /proc/%s/gid_map", pidString) | ||||
| 				} | ||||
| 				defer gidmap.Close() | ||||
| 				if _, err := fmt.Fprintf(gidmap, "%s", g.String()); err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error writing %q to /proc/%s/gid_map: %v", g.String(), pidString, err) | ||||
| 					return errors.Wrapf(err, "error writing %q to /proc/%s/gid_map", g.String(), pidString) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.UidMappings) > 0 { | ||||
| 			// Build the UID map, since writing to the proc file has to be done all at once.
 | ||||
| 			u := new(bytes.Buffer) | ||||
| 			for _, m := range c.UidMappings { | ||||
| 				fmt.Fprintf(u, "%d %d %d\n", m.ContainerID, m.HostID, m.Size) | ||||
| 			} | ||||
| 			uidmapSet := false | ||||
| 			// Set the GID map.
 | ||||
| 			if c.UseNewuidmap { | ||||
| 				cmd := exec.Command("newuidmap", append([]string{pidString}, strings.Fields(strings.Replace(u.String(), "\n", " ", -1))...)...) | ||||
| 				u.Reset() | ||||
| 				cmd.Stdout = u | ||||
| 				cmd.Stderr = u | ||||
| 				err := cmd.Run() | ||||
| 				if err == nil { | ||||
| 					uidmapSet = true | ||||
| 				} else { | ||||
| 					logrus.Warnf("error running newuidmap: %v: %s", err, u.String()) | ||||
| 					logrus.Warnf("falling back to single mapping") | ||||
| 					u.Reset() | ||||
| 					u.Write([]byte(fmt.Sprintf("0 %d 1\n", os.Geteuid()))) | ||||
| 				} | ||||
| 			} | ||||
| 			if !uidmapSet { | ||||
| 				uidmap, err := os.OpenFile(fmt.Sprintf("/proc/%s/uid_map", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 				if err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error opening /proc/%s/uid_map: %v", pidString, err) | ||||
| 					return errors.Wrapf(err, "error opening /proc/%s/uid_map", pidString) | ||||
| 				} | ||||
| 				defer uidmap.Close() | ||||
| 				if _, err := fmt.Fprintf(uidmap, "%s", u.String()); err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error writing %q to /proc/%s/uid_map: %v", u.String(), pidString, err) | ||||
| 					return errors.Wrapf(err, "error writing %q to /proc/%s/uid_map", u.String(), pidString) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if c.OOMScoreAdj != nil { | ||||
| 		oomScoreAdj, err := os.OpenFile(fmt.Sprintf("/proc/%s/oom_score_adj", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 		if err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error opening oom_score_adj: %v", err) | ||||
| 			return errors.Wrapf(err, "error opening /proc/%s/oom_score_adj", pidString) | ||||
| 		} | ||||
| 		defer oomScoreAdj.Close() | ||||
| 		if _, err := fmt.Fprintf(oomScoreAdj, "%d\n", *c.OOMScoreAdj); err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error writing \"%d\" to oom_score_adj: %v", c.OOMScoreAdj, err) | ||||
| 			return errors.Wrapf(err, "error writing \"%d\" to /proc/%s/oom_score_adj", c.OOMScoreAdj, pidString) | ||||
| 		} | ||||
| 	} | ||||
| 	// Run any additional setup that we want to do before the child starts running proper.
 | ||||
| 	if c.Hook != nil { | ||||
| 		if err = c.Hook(pid); err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "hook error: %v", err) | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Run() error { | ||||
| 	if err := c.Start(); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return c.Wait() | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) CombinedOutput() ([]byte, error) { | ||||
| 	return nil, errors.New("unshare: CombinedOutput() not implemented") | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Output() ([]byte, error) { | ||||
| 	return nil, errors.New("unshare: Output() not implemented") | ||||
| } | ||||
| 
 | ||||
| var ( | ||||
| 	isRootlessOnce sync.Once | ||||
| 	isRootless     bool | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	// UsernsEnvName is the environment variable, if set indicates in rootless mode
 | ||||
| 	UsernsEnvName = "_CONTAINERS_USERNS_CONFIGURED" | ||||
| ) | ||||
| 
 | ||||
| // IsRootless tells us if we are running in rootless mode
 | ||||
| func IsRootless() bool { | ||||
| 	isRootlessOnce.Do(func() { | ||||
| 		isRootless = os.Geteuid() != 0 || os.Getenv(UsernsEnvName) != "" | ||||
| 	}) | ||||
| 	return isRootless | ||||
| } | ||||
| 
 | ||||
| // GetRootlessUID returns the UID of the user in the parent userNS
 | ||||
| func GetRootlessUID() int { | ||||
| 	uidEnv := os.Getenv("_CONTAINERS_ROOTLESS_UID") | ||||
| 	if uidEnv != "" { | ||||
| 		u, _ := strconv.Atoi(uidEnv) | ||||
| 		return u | ||||
| 	} | ||||
| 	return os.Getuid() | ||||
| } | ||||
| 
 | ||||
| // RootlessEnv returns the environment settings for the rootless containers
 | ||||
| func RootlessEnv() []string { | ||||
| 	return append(os.Environ(), UsernsEnvName+"=done") | ||||
| } | ||||
| 
 | ||||
| type Runnable interface { | ||||
| 	Run() error | ||||
| } | ||||
| 
 | ||||
| func bailOnError(err error, format string, a ...interface{}) { | ||||
| 	if err != nil { | ||||
| 		if format != "" { | ||||
| 			logrus.Errorf("%s: %v", fmt.Sprintf(format, a...), err) | ||||
| 		} else { | ||||
| 			logrus.Errorf("%v", err) | ||||
| 		} | ||||
| 		os.Exit(1) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // MaybeReexecUsingUserNamespace re-exec the process in a new namespace
 | ||||
| func MaybeReexecUsingUserNamespace(evenForRoot bool) { | ||||
| 	// If we've already been through this once, no need to try again.
 | ||||
| 	if os.Geteuid() == 0 && IsRootless() { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var uidNum, gidNum uint64 | ||||
| 	// Figure out who we are.
 | ||||
| 	me, err := user.Current() | ||||
| 	if !os.IsNotExist(err) { | ||||
| 		bailOnError(err, "error determining current user") | ||||
| 		uidNum, err = strconv.ParseUint(me.Uid, 10, 32) | ||||
| 		bailOnError(err, "error parsing current UID %s", me.Uid) | ||||
| 		gidNum, err = strconv.ParseUint(me.Gid, 10, 32) | ||||
| 		bailOnError(err, "error parsing current GID %s", me.Gid) | ||||
| 	} | ||||
| 
 | ||||
| 	runtime.LockOSThread() | ||||
| 	defer runtime.UnlockOSThread() | ||||
| 
 | ||||
| 	// ID mappings to use to reexec ourselves.
 | ||||
| 	var uidmap, gidmap []specs.LinuxIDMapping | ||||
| 	if uidNum != 0 || evenForRoot { | ||||
| 		// Read the set of ID mappings that we're allowed to use.  Each
 | ||||
| 		// range in /etc/subuid and /etc/subgid file is a starting host
 | ||||
| 		// ID and a range size.
 | ||||
| 		uidmap, gidmap, err = GetSubIDMappings(me.Username, me.Username) | ||||
| 		if err != nil { | ||||
| 			logrus.Warnf("error reading allowed ID mappings: %v", err) | ||||
| 		} | ||||
| 		if len(uidmap) == 0 { | ||||
| 			logrus.Warnf("Found no UID ranges set aside for user %q in /etc/subuid.", me.Username) | ||||
| 		} | ||||
| 		if len(gidmap) == 0 { | ||||
| 			logrus.Warnf("Found no GID ranges set aside for user %q in /etc/subgid.", me.Username) | ||||
| 		} | ||||
| 		// Map our UID and GID, then the subuid and subgid ranges,
 | ||||
| 		// consecutively, starting at 0, to get the mappings to use for
 | ||||
| 		// a copy of ourselves.
 | ||||
| 		uidmap = append([]specs.LinuxIDMapping{{HostID: uint32(uidNum), ContainerID: 0, Size: 1}}, uidmap...) | ||||
| 		gidmap = append([]specs.LinuxIDMapping{{HostID: uint32(gidNum), ContainerID: 0, Size: 1}}, gidmap...) | ||||
| 		var rangeStart uint32 | ||||
| 		for i := range uidmap { | ||||
| 			uidmap[i].ContainerID = rangeStart | ||||
| 			rangeStart += uidmap[i].Size | ||||
| 		} | ||||
| 		rangeStart = 0 | ||||
| 		for i := range gidmap { | ||||
| 			gidmap[i].ContainerID = rangeStart | ||||
| 			rangeStart += gidmap[i].Size | ||||
| 		} | ||||
| 	} else { | ||||
| 		// If we have CAP_SYS_ADMIN, then we don't need to create a new namespace in order to be able
 | ||||
| 		// to use unshare(), so don't bother creating a new user namespace at this point.
 | ||||
| 		capabilities, err := capability.NewPid(0) | ||||
| 		bailOnError(err, "error reading the current capabilities sets") | ||||
| 		if capabilities.Get(capability.EFFECTIVE, capability.CAP_SYS_ADMIN) { | ||||
| 			return | ||||
| 		} | ||||
| 		// Read the set of ID mappings that we're currently using.
 | ||||
| 		uidmap, gidmap, err = GetHostIDMappings("") | ||||
| 		bailOnError(err, "error reading current ID mappings") | ||||
| 		// Just reuse them.
 | ||||
| 		for i := range uidmap { | ||||
| 			uidmap[i].HostID = uidmap[i].ContainerID | ||||
| 		} | ||||
| 		for i := range gidmap { | ||||
| 			gidmap[i].HostID = gidmap[i].ContainerID | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Unlike most uses of reexec or unshare, we're using a name that
 | ||||
| 	// _won't_ be recognized as a registered reexec handler, since we
 | ||||
| 	// _want_ to fall through reexec.Init() to the normal main().
 | ||||
| 	cmd := Command(append([]string{fmt.Sprintf("%s-in-a-user-namespace", os.Args[0])}, os.Args[1:]...)...) | ||||
| 
 | ||||
| 	// If, somehow, we don't become UID 0 in our child, indicate that the child shouldn't try again.
 | ||||
| 	err = os.Setenv(UsernsEnvName, "1") | ||||
| 	bailOnError(err, "error setting %s=1 in environment", UsernsEnvName) | ||||
| 
 | ||||
| 	// Set the default isolation type to use the "rootless" method.
 | ||||
| 	if _, present := os.LookupEnv("BUILDAH_ISOLATION"); !present { | ||||
| 		if err = os.Setenv("BUILDAH_ISOLATION", "rootless"); err != nil { | ||||
| 			if err := os.Setenv("BUILDAH_ISOLATION", "rootless"); err != nil { | ||||
| 				logrus.Errorf("error setting BUILDAH_ISOLATION=rootless in environment: %v", err) | ||||
| 				os.Exit(1) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Reuse our stdio.
 | ||||
| 	cmd.Stdin = os.Stdin | ||||
| 	cmd.Stdout = os.Stdout | ||||
| 	cmd.Stderr = os.Stderr | ||||
| 
 | ||||
| 	// Set up a new user namespace with the ID mapping.
 | ||||
| 	cmd.UnshareFlags = syscall.CLONE_NEWUSER | syscall.CLONE_NEWNS | ||||
| 	cmd.UseNewuidmap = uidNum != 0 | ||||
| 	cmd.UidMappings = uidmap | ||||
| 	cmd.UseNewgidmap = uidNum != 0 | ||||
| 	cmd.GidMappings = gidmap | ||||
| 	cmd.GidMappingsEnableSetgroups = true | ||||
| 
 | ||||
| 	// Finish up.
 | ||||
| 	logrus.Debugf("running %+v with environment %+v, UID map %+v, and GID map %+v", cmd.Cmd.Args, os.Environ(), cmd.UidMappings, cmd.GidMappings) | ||||
| 	ExecRunnable(cmd, nil) | ||||
| } | ||||
| 
 | ||||
| // ExecRunnable runs the specified unshare command, captures its exit status,
 | ||||
| // and exits with the same status.
 | ||||
| func ExecRunnable(cmd Runnable, cleanup func()) { | ||||
| 	exit := func(status int) { | ||||
| 		if cleanup != nil { | ||||
| 			cleanup() | ||||
| 		} | ||||
| 		os.Exit(status) | ||||
| 	} | ||||
| 	if err := cmd.Run(); err != nil { | ||||
| 		if exitError, ok := errors.Cause(err).(*exec.ExitError); ok { | ||||
| 			if exitError.ProcessState.Exited() { | ||||
| 				if waitStatus, ok := exitError.ProcessState.Sys().(syscall.WaitStatus); ok { | ||||
| 					if waitStatus.Exited() { | ||||
| 						logrus.Errorf("%v", exitError) | ||||
| 						exit(waitStatus.ExitStatus()) | ||||
| 					} | ||||
| 					if waitStatus.Signaled() { | ||||
| 						logrus.Errorf("%v", exitError) | ||||
| 						exit(int(waitStatus.Signal()) + 128) | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		logrus.Errorf("%v", err) | ||||
| 		logrus.Errorf("(unable to determine exit status)") | ||||
| 		exit(1) | ||||
| 	} | ||||
| 	exit(0) | ||||
| } | ||||
| 
 | ||||
| // getHostIDMappings reads mappings from the named node under /proc.
 | ||||
| func getHostIDMappings(path string) ([]specs.LinuxIDMapping, error) { | ||||
| 	var mappings []specs.LinuxIDMapping | ||||
| 	f, err := os.Open(path) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(err, "error reading ID mappings from %q", path) | ||||
| 	} | ||||
| 	defer f.Close() | ||||
| 	scanner := bufio.NewScanner(f) | ||||
| 	for scanner.Scan() { | ||||
| 		line := scanner.Text() | ||||
| 		fields := strings.Fields(line) | ||||
| 		if len(fields) != 3 { | ||||
| 			return nil, errors.Errorf("line %q from %q has %d fields, not 3", line, path, len(fields)) | ||||
| 		} | ||||
| 		cid, err := strconv.ParseUint(fields[0], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing container ID value %q from line %q in %q", fields[0], line, path) | ||||
| 		} | ||||
| 		hid, err := strconv.ParseUint(fields[1], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing host ID value %q from line %q in %q", fields[1], line, path) | ||||
| 		} | ||||
| 		size, err := strconv.ParseUint(fields[2], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing size value %q from line %q in %q", fields[2], line, path) | ||||
| 		} | ||||
| 		mappings = append(mappings, specs.LinuxIDMapping{ContainerID: uint32(cid), HostID: uint32(hid), Size: uint32(size)}) | ||||
| 	} | ||||
| 	return mappings, nil | ||||
| } | ||||
| 
 | ||||
| // GetHostIDMappings reads mappings for the specified process (or the current
 | ||||
| // process if pid is "self" or an empty string) from the kernel.
 | ||||
| func GetHostIDMappings(pid string) ([]specs.LinuxIDMapping, []specs.LinuxIDMapping, error) { | ||||
| 	if pid == "" { | ||||
| 		pid = "self" | ||||
| 	} | ||||
| 	uidmap, err := getHostIDMappings(fmt.Sprintf("/proc/%s/uid_map", pid)) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	gidmap, err := getHostIDMappings(fmt.Sprintf("/proc/%s/gid_map", pid)) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	return uidmap, gidmap, nil | ||||
| } | ||||
| 
 | ||||
| // GetSubIDMappings reads mappings from /etc/subuid and /etc/subgid.
 | ||||
| func GetSubIDMappings(user, group string) ([]specs.LinuxIDMapping, []specs.LinuxIDMapping, error) { | ||||
| 	mappings, err := idtools.NewIDMappings(user, group) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, errors.Wrapf(err, "error reading subuid mappings for user %q and subgid mappings for group %q", user, group) | ||||
| 	} | ||||
| 	var uidmap, gidmap []specs.LinuxIDMapping | ||||
| 	for _, m := range mappings.UIDs() { | ||||
| 		uidmap = append(uidmap, specs.LinuxIDMapping{ | ||||
| 			ContainerID: uint32(m.ContainerID), | ||||
| 			HostID:      uint32(m.HostID), | ||||
| 			Size:        uint32(m.Size), | ||||
| 		}) | ||||
| 	} | ||||
| 	for _, m := range mappings.GIDs() { | ||||
| 		gidmap = append(gidmap, specs.LinuxIDMapping{ | ||||
| 			ContainerID: uint32(m.ContainerID), | ||||
| 			HostID:      uint32(m.HostID), | ||||
| 			Size:        uint32(m.Size), | ||||
| 		}) | ||||
| 	} | ||||
| 	return uidmap, gidmap, nil | ||||
| } | ||||
| 
 | ||||
| // ParseIDMappings parses mapping triples.
 | ||||
| func ParseIDMappings(uidmap, gidmap []string) ([]idtools.IDMap, []idtools.IDMap, error) { | ||||
| 	uid, err := idtools.ParseIDMap(uidmap, "userns-uid-map") | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	gid, err := idtools.ParseIDMap(gidmap, "userns-gid-map") | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	return uid, gid, nil | ||||
| } | ||||
| 
 | ||||
| // HomeDir returns the home directory for the current user.
 | ||||
| func HomeDir() (string, error) { | ||||
|         home := os.Getenv("HOME") | ||||
|         if home == "" { | ||||
|                 usr, err := user.LookupId(fmt.Sprintf("%d", GetRootlessUID())) | ||||
|                 if err != nil { | ||||
|                         return "", errors.Wrapf(err, "unable to resolve HOME directory") | ||||
|                 } | ||||
|                 home = usr.HomeDir | ||||
|         } | ||||
|         return home, nil | ||||
| 	home := os.Getenv("HOME") | ||||
| 	if home == "" { | ||||
| 		usr, err := user.LookupId(fmt.Sprintf("%d", GetRootlessUID())) | ||||
| 		if err != nil { | ||||
| 			return "", errors.Wrapf(err, "unable to resolve HOME directory") | ||||
| 		} | ||||
| 		home = usr.HomeDir | ||||
| 	} | ||||
| 	return home, nil | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,580 @@ | |||
| // +build linux
 | ||||
| 
 | ||||
| package unshare | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"os" | ||||
| 	"os/exec" | ||||
| 	"os/user" | ||||
| 	"runtime" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 	"syscall" | ||||
| 
 | ||||
| 	"github.com/containers/storage/pkg/idtools" | ||||
| 	"github.com/containers/storage/pkg/reexec" | ||||
| 	"github.com/opencontainers/runtime-spec/specs-go" | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/syndtr/gocapability/capability" | ||||
| ) | ||||
| 
 | ||||
| // Cmd wraps an exec.Cmd created by the reexec package in unshare(), and
 | ||||
| // handles setting ID maps and other related settings by triggering
 | ||||
| // initialization code in the child.
 | ||||
| type Cmd struct { | ||||
| 	*exec.Cmd | ||||
| 	UnshareFlags               int | ||||
| 	UseNewuidmap               bool | ||||
| 	UidMappings                []specs.LinuxIDMapping | ||||
| 	UseNewgidmap               bool | ||||
| 	GidMappings                []specs.LinuxIDMapping | ||||
| 	GidMappingsEnableSetgroups bool | ||||
| 	Setsid                     bool | ||||
| 	Setpgrp                    bool | ||||
| 	Ctty                       *os.File | ||||
| 	OOMScoreAdj                *int | ||||
| 	Hook                       func(pid int) error | ||||
| } | ||||
| 
 | ||||
| // Command creates a new Cmd which can be customized.
 | ||||
| func Command(args ...string) *Cmd { | ||||
| 	cmd := reexec.Command(args...) | ||||
| 	return &Cmd{ | ||||
| 		Cmd: cmd, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Start() error { | ||||
| 	runtime.LockOSThread() | ||||
| 	defer runtime.UnlockOSThread() | ||||
| 
 | ||||
| 	// Set an environment variable to tell the child to synchronize its startup.
 | ||||
| 	if c.Env == nil { | ||||
| 		c.Env = os.Environ() | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-unshare=%d", c.UnshareFlags)) | ||||
| 
 | ||||
| 	// Please the libpod "rootless" package to find the expected env variables.
 | ||||
| 	if os.Geteuid() != 0 { | ||||
| 		c.Env = append(c.Env, "_CONTAINERS_USERNS_CONFIGURED=done") | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_CONTAINERS_ROOTLESS_UID=%d", os.Geteuid())) | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_CONTAINERS_ROOTLESS_GID=%d", os.Getegid())) | ||||
| 	} | ||||
| 
 | ||||
| 	// Create the pipe for reading the child's PID.
 | ||||
| 	pidRead, pidWrite, err := os.Pipe() | ||||
| 	if err != nil { | ||||
| 		return errors.Wrapf(err, "error creating pid pipe") | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-pid-pipe=%d", len(c.ExtraFiles)+3)) | ||||
| 	c.ExtraFiles = append(c.ExtraFiles, pidWrite) | ||||
| 
 | ||||
| 	// Create the pipe for letting the child know to proceed.
 | ||||
| 	continueRead, continueWrite, err := os.Pipe() | ||||
| 	if err != nil { | ||||
| 		pidRead.Close() | ||||
| 		pidWrite.Close() | ||||
| 		return errors.Wrapf(err, "error creating pid pipe") | ||||
| 	} | ||||
| 	c.Env = append(c.Env, fmt.Sprintf("_Containers-continue-pipe=%d", len(c.ExtraFiles)+3)) | ||||
| 	c.ExtraFiles = append(c.ExtraFiles, continueRead) | ||||
| 
 | ||||
| 	// Pass along other instructions.
 | ||||
| 	if c.Setsid { | ||||
| 		c.Env = append(c.Env, "_Containers-setsid=1") | ||||
| 	} | ||||
| 	if c.Setpgrp { | ||||
| 		c.Env = append(c.Env, "_Containers-setpgrp=1") | ||||
| 	} | ||||
| 	if c.Ctty != nil { | ||||
| 		c.Env = append(c.Env, fmt.Sprintf("_Containers-ctty=%d", len(c.ExtraFiles)+3)) | ||||
| 		c.ExtraFiles = append(c.ExtraFiles, c.Ctty) | ||||
| 	} | ||||
| 
 | ||||
| 	// Make sure we clean up our pipes.
 | ||||
| 	defer func() { | ||||
| 		if pidRead != nil { | ||||
| 			pidRead.Close() | ||||
| 		} | ||||
| 		if pidWrite != nil { | ||||
| 			pidWrite.Close() | ||||
| 		} | ||||
| 		if continueRead != nil { | ||||
| 			continueRead.Close() | ||||
| 		} | ||||
| 		if continueWrite != nil { | ||||
| 			continueWrite.Close() | ||||
| 		} | ||||
| 	}() | ||||
| 
 | ||||
| 	// Start the new process.
 | ||||
| 	err = c.Cmd.Start() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	// Close the ends of the pipes that the parent doesn't need.
 | ||||
| 	continueRead.Close() | ||||
| 	continueRead = nil | ||||
| 	pidWrite.Close() | ||||
| 	pidWrite = nil | ||||
| 
 | ||||
| 	// Read the child's PID from the pipe.
 | ||||
| 	pidString := "" | ||||
| 	b := new(bytes.Buffer) | ||||
| 	if _, err := io.Copy(b, pidRead); err != nil { | ||||
| 		return errors.Wrapf(err, "error reading child PID") | ||||
| 	} | ||||
| 	pidString = b.String() | ||||
| 	pid, err := strconv.Atoi(pidString) | ||||
| 	if err != nil { | ||||
| 		fmt.Fprintf(continueWrite, "error parsing PID %q: %v", pidString, err) | ||||
| 		return errors.Wrapf(err, "error parsing PID %q", pidString) | ||||
| 	} | ||||
| 	pidString = fmt.Sprintf("%d", pid) | ||||
| 
 | ||||
| 	// If we created a new user namespace, set any specified mappings.
 | ||||
| 	if c.UnshareFlags&syscall.CLONE_NEWUSER != 0 { | ||||
| 		// Always set "setgroups".
 | ||||
| 		setgroups, err := os.OpenFile(fmt.Sprintf("/proc/%s/setgroups", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 		if err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error opening setgroups: %v", err) | ||||
| 			return errors.Wrapf(err, "error opening /proc/%s/setgroups", pidString) | ||||
| 		} | ||||
| 		defer setgroups.Close() | ||||
| 		if c.GidMappingsEnableSetgroups { | ||||
| 			if _, err := fmt.Fprintf(setgroups, "allow"); err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error writing \"allow\" to setgroups: %v", err) | ||||
| 				return errors.Wrapf(err, "error opening \"allow\" to /proc/%s/setgroups", pidString) | ||||
| 			} | ||||
| 		} else { | ||||
| 			if _, err := fmt.Fprintf(setgroups, "deny"); err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error writing \"deny\" to setgroups: %v", err) | ||||
| 				return errors.Wrapf(err, "error writing \"deny\" to /proc/%s/setgroups", pidString) | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.UidMappings) == 0 || len(c.GidMappings) == 0 { | ||||
| 			uidmap, gidmap, err := GetHostIDMappings("") | ||||
| 			if err != nil { | ||||
| 				fmt.Fprintf(continueWrite, "error reading ID mappings in parent: %v", err) | ||||
| 				return errors.Wrapf(err, "error reading ID mappings in parent") | ||||
| 			} | ||||
| 			if len(c.UidMappings) == 0 { | ||||
| 				c.UidMappings = uidmap | ||||
| 				for i := range c.UidMappings { | ||||
| 					c.UidMappings[i].HostID = c.UidMappings[i].ContainerID | ||||
| 				} | ||||
| 			} | ||||
| 			if len(c.GidMappings) == 0 { | ||||
| 				c.GidMappings = gidmap | ||||
| 				for i := range c.GidMappings { | ||||
| 					c.GidMappings[i].HostID = c.GidMappings[i].ContainerID | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.GidMappings) > 0 { | ||||
| 			// Build the GID map, since writing to the proc file has to be done all at once.
 | ||||
| 			g := new(bytes.Buffer) | ||||
| 			for _, m := range c.GidMappings { | ||||
| 				fmt.Fprintf(g, "%d %d %d\n", m.ContainerID, m.HostID, m.Size) | ||||
| 			} | ||||
| 			gidmapSet := false | ||||
| 			// Set the GID map.
 | ||||
| 			if c.UseNewgidmap { | ||||
| 				cmd := exec.Command("newgidmap", append([]string{pidString}, strings.Fields(strings.Replace(g.String(), "\n", " ", -1))...)...) | ||||
| 				g.Reset() | ||||
| 				cmd.Stdout = g | ||||
| 				cmd.Stderr = g | ||||
| 				err := cmd.Run() | ||||
| 				if err == nil { | ||||
| 					gidmapSet = true | ||||
| 				} else { | ||||
| 					logrus.Warnf("error running newgidmap: %v: %s", err, g.String()) | ||||
| 					logrus.Warnf("falling back to single mapping") | ||||
| 					g.Reset() | ||||
| 					g.Write([]byte(fmt.Sprintf("0 %d 1\n", os.Getegid()))) | ||||
| 				} | ||||
| 			} | ||||
| 			if !gidmapSet { | ||||
| 				if c.UseNewgidmap { | ||||
| 					setgroups, err := os.OpenFile(fmt.Sprintf("/proc/%s/setgroups", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 					if err != nil { | ||||
| 						fmt.Fprintf(continueWrite, "error opening /proc/%s/setgroups: %v", pidString, err) | ||||
| 						return errors.Wrapf(err, "error opening /proc/%s/setgroups", pidString) | ||||
| 					} | ||||
| 					defer setgroups.Close() | ||||
| 					if _, err := fmt.Fprintf(setgroups, "deny"); err != nil { | ||||
| 						fmt.Fprintf(continueWrite, "error writing 'deny' to /proc/%s/setgroups: %v", pidString, err) | ||||
| 						return errors.Wrapf(err, "error writing 'deny' to /proc/%s/setgroups", pidString) | ||||
| 					} | ||||
| 				} | ||||
| 				gidmap, err := os.OpenFile(fmt.Sprintf("/proc/%s/gid_map", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 				if err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error opening /proc/%s/gid_map: %v", pidString, err) | ||||
| 					return errors.Wrapf(err, "error opening /proc/%s/gid_map", pidString) | ||||
| 				} | ||||
| 				defer gidmap.Close() | ||||
| 				if _, err := fmt.Fprintf(gidmap, "%s", g.String()); err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error writing %q to /proc/%s/gid_map: %v", g.String(), pidString, err) | ||||
| 					return errors.Wrapf(err, "error writing %q to /proc/%s/gid_map", g.String(), pidString) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(c.UidMappings) > 0 { | ||||
| 			// Build the UID map, since writing to the proc file has to be done all at once.
 | ||||
| 			u := new(bytes.Buffer) | ||||
| 			for _, m := range c.UidMappings { | ||||
| 				fmt.Fprintf(u, "%d %d %d\n", m.ContainerID, m.HostID, m.Size) | ||||
| 			} | ||||
| 			uidmapSet := false | ||||
| 			// Set the GID map.
 | ||||
| 			if c.UseNewuidmap { | ||||
| 				cmd := exec.Command("newuidmap", append([]string{pidString}, strings.Fields(strings.Replace(u.String(), "\n", " ", -1))...)...) | ||||
| 				u.Reset() | ||||
| 				cmd.Stdout = u | ||||
| 				cmd.Stderr = u | ||||
| 				err := cmd.Run() | ||||
| 				if err == nil { | ||||
| 					uidmapSet = true | ||||
| 				} else { | ||||
| 					logrus.Warnf("error running newuidmap: %v: %s", err, u.String()) | ||||
| 					logrus.Warnf("falling back to single mapping") | ||||
| 					u.Reset() | ||||
| 					u.Write([]byte(fmt.Sprintf("0 %d 1\n", os.Geteuid()))) | ||||
| 				} | ||||
| 			} | ||||
| 			if !uidmapSet { | ||||
| 				uidmap, err := os.OpenFile(fmt.Sprintf("/proc/%s/uid_map", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 				if err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error opening /proc/%s/uid_map: %v", pidString, err) | ||||
| 					return errors.Wrapf(err, "error opening /proc/%s/uid_map", pidString) | ||||
| 				} | ||||
| 				defer uidmap.Close() | ||||
| 				if _, err := fmt.Fprintf(uidmap, "%s", u.String()); err != nil { | ||||
| 					fmt.Fprintf(continueWrite, "error writing %q to /proc/%s/uid_map: %v", u.String(), pidString, err) | ||||
| 					return errors.Wrapf(err, "error writing %q to /proc/%s/uid_map", u.String(), pidString) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if c.OOMScoreAdj != nil { | ||||
| 		oomScoreAdj, err := os.OpenFile(fmt.Sprintf("/proc/%s/oom_score_adj", pidString), os.O_TRUNC|os.O_WRONLY, 0) | ||||
| 		if err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error opening oom_score_adj: %v", err) | ||||
| 			return errors.Wrapf(err, "error opening /proc/%s/oom_score_adj", pidString) | ||||
| 		} | ||||
| 		defer oomScoreAdj.Close() | ||||
| 		if _, err := fmt.Fprintf(oomScoreAdj, "%d\n", *c.OOMScoreAdj); err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "error writing \"%d\" to oom_score_adj: %v", c.OOMScoreAdj, err) | ||||
| 			return errors.Wrapf(err, "error writing \"%d\" to /proc/%s/oom_score_adj", c.OOMScoreAdj, pidString) | ||||
| 		} | ||||
| 	} | ||||
| 	// Run any additional setup that we want to do before the child starts running proper.
 | ||||
| 	if c.Hook != nil { | ||||
| 		if err = c.Hook(pid); err != nil { | ||||
| 			fmt.Fprintf(continueWrite, "hook error: %v", err) | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Run() error { | ||||
| 	if err := c.Start(); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return c.Wait() | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) CombinedOutput() ([]byte, error) { | ||||
| 	return nil, errors.New("unshare: CombinedOutput() not implemented") | ||||
| } | ||||
| 
 | ||||
| func (c *Cmd) Output() ([]byte, error) { | ||||
| 	return nil, errors.New("unshare: Output() not implemented") | ||||
| } | ||||
| 
 | ||||
| var ( | ||||
| 	isRootlessOnce sync.Once | ||||
| 	isRootless     bool | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	// UsernsEnvName is the environment variable, if set indicates in rootless mode
 | ||||
| 	UsernsEnvName = "_CONTAINERS_USERNS_CONFIGURED" | ||||
| ) | ||||
| 
 | ||||
| // IsRootless tells us if we are running in rootless mode
 | ||||
| func IsRootless() bool { | ||||
| 	isRootlessOnce.Do(func() { | ||||
| 		isRootless = os.Geteuid() != 0 || os.Getenv(UsernsEnvName) != "" | ||||
| 	}) | ||||
| 	return isRootless | ||||
| } | ||||
| 
 | ||||
| // GetRootlessUID returns the UID of the user in the parent userNS
 | ||||
| func GetRootlessUID() int { | ||||
| 	uidEnv := os.Getenv("_CONTAINERS_ROOTLESS_UID") | ||||
| 	if uidEnv != "" { | ||||
| 		u, _ := strconv.Atoi(uidEnv) | ||||
| 		return u | ||||
| 	} | ||||
| 	return os.Getuid() | ||||
| } | ||||
| 
 | ||||
| // RootlessEnv returns the environment settings for the rootless containers
 | ||||
| func RootlessEnv() []string { | ||||
| 	return append(os.Environ(), UsernsEnvName+"=done") | ||||
| } | ||||
| 
 | ||||
| type Runnable interface { | ||||
| 	Run() error | ||||
| } | ||||
| 
 | ||||
| func bailOnError(err error, format string, a ...interface{}) { | ||||
| 	if err != nil { | ||||
| 		if format != "" { | ||||
| 			logrus.Errorf("%s: %v", fmt.Sprintf(format, a...), err) | ||||
| 		} else { | ||||
| 			logrus.Errorf("%v", err) | ||||
| 		} | ||||
| 		os.Exit(1) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // MaybeReexecUsingUserNamespace re-exec the process in a new namespace
 | ||||
| func MaybeReexecUsingUserNamespace(evenForRoot bool) { | ||||
| 	// If we've already been through this once, no need to try again.
 | ||||
| 	if os.Geteuid() == 0 && IsRootless() { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var uidNum, gidNum uint64 | ||||
| 	// Figure out who we are.
 | ||||
| 	me, err := user.Current() | ||||
| 	if !os.IsNotExist(err) { | ||||
| 		bailOnError(err, "error determining current user") | ||||
| 		uidNum, err = strconv.ParseUint(me.Uid, 10, 32) | ||||
| 		bailOnError(err, "error parsing current UID %s", me.Uid) | ||||
| 		gidNum, err = strconv.ParseUint(me.Gid, 10, 32) | ||||
| 		bailOnError(err, "error parsing current GID %s", me.Gid) | ||||
| 	} | ||||
| 
 | ||||
| 	runtime.LockOSThread() | ||||
| 	defer runtime.UnlockOSThread() | ||||
| 
 | ||||
| 	// ID mappings to use to reexec ourselves.
 | ||||
| 	var uidmap, gidmap []specs.LinuxIDMapping | ||||
| 	if uidNum != 0 || evenForRoot { | ||||
| 		// Read the set of ID mappings that we're allowed to use.  Each
 | ||||
| 		// range in /etc/subuid and /etc/subgid file is a starting host
 | ||||
| 		// ID and a range size.
 | ||||
| 		uidmap, gidmap, err = GetSubIDMappings(me.Username, me.Username) | ||||
| 		if err != nil { | ||||
| 			logrus.Warnf("error reading allowed ID mappings: %v", err) | ||||
| 		} | ||||
| 		if len(uidmap) == 0 { | ||||
| 			logrus.Warnf("Found no UID ranges set aside for user %q in /etc/subuid.", me.Username) | ||||
| 		} | ||||
| 		if len(gidmap) == 0 { | ||||
| 			logrus.Warnf("Found no GID ranges set aside for user %q in /etc/subgid.", me.Username) | ||||
| 		} | ||||
| 		// Map our UID and GID, then the subuid and subgid ranges,
 | ||||
| 		// consecutively, starting at 0, to get the mappings to use for
 | ||||
| 		// a copy of ourselves.
 | ||||
| 		uidmap = append([]specs.LinuxIDMapping{{HostID: uint32(uidNum), ContainerID: 0, Size: 1}}, uidmap...) | ||||
| 		gidmap = append([]specs.LinuxIDMapping{{HostID: uint32(gidNum), ContainerID: 0, Size: 1}}, gidmap...) | ||||
| 		var rangeStart uint32 | ||||
| 		for i := range uidmap { | ||||
| 			uidmap[i].ContainerID = rangeStart | ||||
| 			rangeStart += uidmap[i].Size | ||||
| 		} | ||||
| 		rangeStart = 0 | ||||
| 		for i := range gidmap { | ||||
| 			gidmap[i].ContainerID = rangeStart | ||||
| 			rangeStart += gidmap[i].Size | ||||
| 		} | ||||
| 	} else { | ||||
| 		// If we have CAP_SYS_ADMIN, then we don't need to create a new namespace in order to be able
 | ||||
| 		// to use unshare(), so don't bother creating a new user namespace at this point.
 | ||||
| 		capabilities, err := capability.NewPid(0) | ||||
| 		bailOnError(err, "error reading the current capabilities sets") | ||||
| 		if capabilities.Get(capability.EFFECTIVE, capability.CAP_SYS_ADMIN) { | ||||
| 			return | ||||
| 		} | ||||
| 		// Read the set of ID mappings that we're currently using.
 | ||||
| 		uidmap, gidmap, err = GetHostIDMappings("") | ||||
| 		bailOnError(err, "error reading current ID mappings") | ||||
| 		// Just reuse them.
 | ||||
| 		for i := range uidmap { | ||||
| 			uidmap[i].HostID = uidmap[i].ContainerID | ||||
| 		} | ||||
| 		for i := range gidmap { | ||||
| 			gidmap[i].HostID = gidmap[i].ContainerID | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Unlike most uses of reexec or unshare, we're using a name that
 | ||||
| 	// _won't_ be recognized as a registered reexec handler, since we
 | ||||
| 	// _want_ to fall through reexec.Init() to the normal main().
 | ||||
| 	cmd := Command(append([]string{fmt.Sprintf("%s-in-a-user-namespace", os.Args[0])}, os.Args[1:]...)...) | ||||
| 
 | ||||
| 	// If, somehow, we don't become UID 0 in our child, indicate that the child shouldn't try again.
 | ||||
| 	err = os.Setenv(UsernsEnvName, "1") | ||||
| 	bailOnError(err, "error setting %s=1 in environment", UsernsEnvName) | ||||
| 
 | ||||
| 	// Set the default isolation type to use the "rootless" method.
 | ||||
| 	if _, present := os.LookupEnv("BUILDAH_ISOLATION"); !present { | ||||
| 		if err = os.Setenv("BUILDAH_ISOLATION", "rootless"); err != nil { | ||||
| 			if err := os.Setenv("BUILDAH_ISOLATION", "rootless"); err != nil { | ||||
| 				logrus.Errorf("error setting BUILDAH_ISOLATION=rootless in environment: %v", err) | ||||
| 				os.Exit(1) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Reuse our stdio.
 | ||||
| 	cmd.Stdin = os.Stdin | ||||
| 	cmd.Stdout = os.Stdout | ||||
| 	cmd.Stderr = os.Stderr | ||||
| 
 | ||||
| 	// Set up a new user namespace with the ID mapping.
 | ||||
| 	cmd.UnshareFlags = syscall.CLONE_NEWUSER | syscall.CLONE_NEWNS | ||||
| 	cmd.UseNewuidmap = uidNum != 0 | ||||
| 	cmd.UidMappings = uidmap | ||||
| 	cmd.UseNewgidmap = uidNum != 0 | ||||
| 	cmd.GidMappings = gidmap | ||||
| 	cmd.GidMappingsEnableSetgroups = true | ||||
| 
 | ||||
| 	// Finish up.
 | ||||
| 	logrus.Debugf("running %+v with environment %+v, UID map %+v, and GID map %+v", cmd.Cmd.Args, os.Environ(), cmd.UidMappings, cmd.GidMappings) | ||||
| 	ExecRunnable(cmd, nil) | ||||
| } | ||||
| 
 | ||||
| // ExecRunnable runs the specified unshare command, captures its exit status,
 | ||||
| // and exits with the same status.
 | ||||
| func ExecRunnable(cmd Runnable, cleanup func()) { | ||||
| 	exit := func(status int) { | ||||
| 		if cleanup != nil { | ||||
| 			cleanup() | ||||
| 		} | ||||
| 		os.Exit(status) | ||||
| 	} | ||||
| 	if err := cmd.Run(); err != nil { | ||||
| 		if exitError, ok := errors.Cause(err).(*exec.ExitError); ok { | ||||
| 			if exitError.ProcessState.Exited() { | ||||
| 				if waitStatus, ok := exitError.ProcessState.Sys().(syscall.WaitStatus); ok { | ||||
| 					if waitStatus.Exited() { | ||||
| 						logrus.Errorf("%v", exitError) | ||||
| 						exit(waitStatus.ExitStatus()) | ||||
| 					} | ||||
| 					if waitStatus.Signaled() { | ||||
| 						logrus.Errorf("%v", exitError) | ||||
| 						exit(int(waitStatus.Signal()) + 128) | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		logrus.Errorf("%v", err) | ||||
| 		logrus.Errorf("(unable to determine exit status)") | ||||
| 		exit(1) | ||||
| 	} | ||||
| 	exit(0) | ||||
| } | ||||
| 
 | ||||
| // getHostIDMappings reads mappings from the named node under /proc.
 | ||||
| func getHostIDMappings(path string) ([]specs.LinuxIDMapping, error) { | ||||
| 	var mappings []specs.LinuxIDMapping | ||||
| 	f, err := os.Open(path) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(err, "error reading ID mappings from %q", path) | ||||
| 	} | ||||
| 	defer f.Close() | ||||
| 	scanner := bufio.NewScanner(f) | ||||
| 	for scanner.Scan() { | ||||
| 		line := scanner.Text() | ||||
| 		fields := strings.Fields(line) | ||||
| 		if len(fields) != 3 { | ||||
| 			return nil, errors.Errorf("line %q from %q has %d fields, not 3", line, path, len(fields)) | ||||
| 		} | ||||
| 		cid, err := strconv.ParseUint(fields[0], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing container ID value %q from line %q in %q", fields[0], line, path) | ||||
| 		} | ||||
| 		hid, err := strconv.ParseUint(fields[1], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing host ID value %q from line %q in %q", fields[1], line, path) | ||||
| 		} | ||||
| 		size, err := strconv.ParseUint(fields[2], 10, 32) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(err, "error parsing size value %q from line %q in %q", fields[2], line, path) | ||||
| 		} | ||||
| 		mappings = append(mappings, specs.LinuxIDMapping{ContainerID: uint32(cid), HostID: uint32(hid), Size: uint32(size)}) | ||||
| 	} | ||||
| 	return mappings, nil | ||||
| } | ||||
| 
 | ||||
| // GetHostIDMappings reads mappings for the specified process (or the current
 | ||||
| // process if pid is "self" or an empty string) from the kernel.
 | ||||
| func GetHostIDMappings(pid string) ([]specs.LinuxIDMapping, []specs.LinuxIDMapping, error) { | ||||
| 	if pid == "" { | ||||
| 		pid = "self" | ||||
| 	} | ||||
| 	uidmap, err := getHostIDMappings(fmt.Sprintf("/proc/%s/uid_map", pid)) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	gidmap, err := getHostIDMappings(fmt.Sprintf("/proc/%s/gid_map", pid)) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	return uidmap, gidmap, nil | ||||
| } | ||||
| 
 | ||||
| // GetSubIDMappings reads mappings from /etc/subuid and /etc/subgid.
 | ||||
| func GetSubIDMappings(user, group string) ([]specs.LinuxIDMapping, []specs.LinuxIDMapping, error) { | ||||
| 	mappings, err := idtools.NewIDMappings(user, group) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, errors.Wrapf(err, "error reading subuid mappings for user %q and subgid mappings for group %q", user, group) | ||||
| 	} | ||||
| 	var uidmap, gidmap []specs.LinuxIDMapping | ||||
| 	for _, m := range mappings.UIDs() { | ||||
| 		uidmap = append(uidmap, specs.LinuxIDMapping{ | ||||
| 			ContainerID: uint32(m.ContainerID), | ||||
| 			HostID:      uint32(m.HostID), | ||||
| 			Size:        uint32(m.Size), | ||||
| 		}) | ||||
| 	} | ||||
| 	for _, m := range mappings.GIDs() { | ||||
| 		gidmap = append(gidmap, specs.LinuxIDMapping{ | ||||
| 			ContainerID: uint32(m.ContainerID), | ||||
| 			HostID:      uint32(m.HostID), | ||||
| 			Size:        uint32(m.Size), | ||||
| 		}) | ||||
| 	} | ||||
| 	return uidmap, gidmap, nil | ||||
| } | ||||
| 
 | ||||
| // ParseIDMappings parses mapping triples.
 | ||||
| func ParseIDMappings(uidmap, gidmap []string) ([]idtools.IDMap, []idtools.IDMap, error) { | ||||
| 	uid, err := idtools.ParseIDMap(uidmap, "userns-uid-map") | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	gid, err := idtools.ParseIDMap(gidmap, "userns-gid-map") | ||||
| 	if err != nil { | ||||
| 		return nil, nil, err | ||||
| 	} | ||||
| 	return uid, gid, nil | ||||
| } | ||||
|  | @ -1 +1 @@ | |||
| 1.15.4 | ||||
| 1.15.5 | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ import ( | |||
| 	"github.com/containers/storage/pkg/archive" | ||||
| 	"github.com/containers/storage/pkg/idtools" | ||||
| 	"github.com/containers/storage/pkg/ioutils" | ||||
| 	"github.com/containers/storage/pkg/mount" | ||||
| 	"github.com/containers/storage/pkg/stringid" | ||||
| 	"github.com/containers/storage/pkg/system" | ||||
| 	"github.com/containers/storage/pkg/tarlog" | ||||
|  | @ -776,8 +777,17 @@ func (r *layerStore) Mount(id string, options drivers.MountOpts) (string, error) | |||
| 		return "", ErrLayerUnknown | ||||
| 	} | ||||
| 	if layer.MountCount > 0 { | ||||
| 		layer.MountCount++ | ||||
| 		return layer.MountPoint, r.saveMounts() | ||||
| 		mounted, err := mount.Mounted(layer.MountPoint) | ||||
| 		if err != nil { | ||||
| 			return "", err | ||||
| 		} | ||||
| 		// If the container is not mounted then we have a condition
 | ||||
| 		// where the kernel umounted the mount point. This means
 | ||||
| 		// that the mount count never got decremented.
 | ||||
| 		if mounted { | ||||
| 			layer.MountCount++ | ||||
| 			return layer.MountPoint, r.saveMounts() | ||||
| 		} | ||||
| 	} | ||||
| 	if options.MountLabel == "" { | ||||
| 		options.MountLabel = layer.MountLabel | ||||
|  |  | |||
|  | @ -1,8 +1,7 @@ | |||
| language: go | ||||
| go: | ||||
|   - 1.10.x | ||||
|   - 1.11.x | ||||
|   - 1.12.x | ||||
|   - 1.13.x | ||||
|   - tip | ||||
| 
 | ||||
| # allow internal package imports, necessary for forked repositories | ||||
|  |  | |||
|  | @ -1,3 +1,11 @@ | |||
| ## 1.11.0 | ||||
| 
 | ||||
| ### Features | ||||
| - Add syscall for riscv64 architecture [f66e896] | ||||
| - teamcity reporter: output location of test failure as well as test definition (#626) [9869142] | ||||
| - teamcity reporter: output newline after every service message (#625) [3cfa02d] | ||||
| - Add support for go module when running `generate` command (#578) [9c89e3f] | ||||
| 
 | ||||
| ## 1.10.3 | ||||
| 
 | ||||
| ### Fixes | ||||
|  |  | |||
|  | @ -20,7 +20,7 @@ import ( | |||
| 	"fmt" | ||||
| ) | ||||
| 
 | ||||
| const VERSION = "1.10.3" | ||||
| const VERSION = "1.11.0" | ||||
| 
 | ||||
| type GinkgoConfigType struct { | ||||
| 	RandomSeed         int64 | ||||
|  |  | |||
|  | @ -1,10 +1,12 @@ | |||
| package main | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"flag" | ||||
| 	"fmt" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"text/template" | ||||
| ) | ||||
|  | @ -158,11 +160,90 @@ func formatSubject(name string) string { | |||
| 	return name | ||||
| } | ||||
| 
 | ||||
| // moduleName returns module name from go.mod from given module root directory
 | ||||
| func moduleName(modRoot string) string { | ||||
| 	modFile, err := os.Open(filepath.Join(modRoot, "go.mod")) | ||||
| 	if err != nil { | ||||
| 		return "" | ||||
| 	} | ||||
| 
 | ||||
| 	mod := make([]byte, 128) | ||||
| 	_, err = modFile.Read(mod) | ||||
| 	if err != nil { | ||||
| 		return "" | ||||
| 	} | ||||
| 
 | ||||
| 	slashSlash := []byte("//") | ||||
| 	moduleStr := []byte("module") | ||||
| 
 | ||||
| 	for len(mod) > 0 { | ||||
| 		line := mod | ||||
| 		mod = nil | ||||
| 		if i := bytes.IndexByte(line, '\n'); i >= 0 { | ||||
| 			line, mod = line[:i], line[i+1:] | ||||
| 		} | ||||
| 		if i := bytes.Index(line, slashSlash); i >= 0 { | ||||
| 			line = line[:i] | ||||
| 		} | ||||
| 		line = bytes.TrimSpace(line) | ||||
| 		if !bytes.HasPrefix(line, moduleStr) { | ||||
| 			continue | ||||
| 		} | ||||
| 		line = line[len(moduleStr):] | ||||
| 		n := len(line) | ||||
| 		line = bytes.TrimSpace(line) | ||||
| 		if len(line) == n || len(line) == 0 { | ||||
| 			continue | ||||
| 		} | ||||
| 
 | ||||
| 		if line[0] == '"' || line[0] == '`' { | ||||
| 			p, err := strconv.Unquote(string(line)) | ||||
| 			if err != nil { | ||||
| 				return "" // malformed quoted string or multiline module path
 | ||||
| 			} | ||||
| 			return p | ||||
| 		} | ||||
| 
 | ||||
| 		return string(line) | ||||
| 	} | ||||
| 
 | ||||
| 	return "" // missing module path
 | ||||
| } | ||||
| 
 | ||||
| func findModuleRoot(dir string) (root string) { | ||||
| 	dir = filepath.Clean(dir) | ||||
| 
 | ||||
| 	// Look for enclosing go.mod.
 | ||||
| 	for { | ||||
| 		if fi, err := os.Stat(filepath.Join(dir, "go.mod")); err == nil && !fi.IsDir() { | ||||
| 			return dir | ||||
| 		} | ||||
| 		d := filepath.Dir(dir) | ||||
| 		if d == dir { | ||||
| 			break | ||||
| 		} | ||||
| 		dir = d | ||||
| 	} | ||||
| 	return "" | ||||
| } | ||||
| 
 | ||||
| func getPackageImportPath() string { | ||||
| 	workingDir, err := os.Getwd() | ||||
| 	if err != nil { | ||||
| 		panic(err.Error()) | ||||
| 	} | ||||
| 
 | ||||
| 	// Try go.mod file first
 | ||||
| 	modRoot := findModuleRoot(workingDir) | ||||
| 	if modRoot != "" { | ||||
| 		modName := moduleName(modRoot) | ||||
| 		if modName != "" { | ||||
| 			cd := strings.Replace(workingDir, modRoot, "", -1) | ||||
| 			return modName + cd | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Fallback to GOPATH structure
 | ||||
| 	sep := string(filepath.Separator) | ||||
| 	paths := strings.Split(workingDir, sep+"src"+sep) | ||||
| 	if len(paths) == 1 { | ||||
|  |  | |||
							
								
								
									
										11
									
								
								vendor/github.com/onsi/ginkgo/internal/remote/syscall_dup_linux_riscv64.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										11
									
								
								vendor/github.com/onsi/ginkgo/internal/remote/syscall_dup_linux_riscv64.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,11 @@ | |||
| // +build linux,riscv64
 | ||||
| 
 | ||||
| package remote | ||||
| 
 | ||||
| import "syscall" | ||||
| 
 | ||||
| // linux_riscv64 doesn't have syscall.Dup2 which ginkgo uses, so
 | ||||
| // use the nearly identical syscall.Dup3 instead
 | ||||
| func syscallDup(oldfd int, newfd int) (err error) { | ||||
| 	return syscall.Dup3(oldfd, newfd, 0) | ||||
| } | ||||
|  | @ -1,4 +1,5 @@ | |||
| // +build !linux !arm64
 | ||||
| // +build !linux !riscv64
 | ||||
| // +build !windows
 | ||||
| // +build !solaris
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -35,7 +35,7 @@ func NewTeamCityReporter(writer io.Writer) *TeamCityReporter { | |||
| 
 | ||||
| func (reporter *TeamCityReporter) SpecSuiteWillBegin(config config.GinkgoConfigType, summary *types.SuiteSummary) { | ||||
| 	reporter.testSuiteName = escape(summary.SuiteDescription) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testSuiteStarted name='%s']", messageId, reporter.testSuiteName) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testSuiteStarted name='%s']\n", messageId, reporter.testSuiteName) | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) BeforeSuiteDidRun(setupSummary *types.SetupSummary) { | ||||
|  | @ -49,18 +49,18 @@ func (reporter *TeamCityReporter) AfterSuiteDidRun(setupSummary *types.SetupSumm | |||
| func (reporter *TeamCityReporter) handleSetupSummary(name string, setupSummary *types.SetupSummary) { | ||||
| 	if setupSummary.State != types.SpecStatePassed { | ||||
| 		testName := escape(name) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testStarted name='%s']", messageId, testName) | ||||
| 		message := escape(setupSummary.Failure.ComponentCodeLocation.String()) | ||||
| 		details := escape(setupSummary.Failure.Message) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFailed name='%s' message='%s' details='%s']", messageId, testName, message, details) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testStarted name='%s']\n", messageId, testName) | ||||
| 		message := reporter.failureMessage(setupSummary.Failure) | ||||
| 		details := reporter.failureDetails(setupSummary.Failure) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFailed name='%s' message='%s' details='%s']\n", messageId, testName, message, details) | ||||
| 		durationInMilliseconds := setupSummary.RunTime.Seconds() * 1000 | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFinished name='%s' duration='%v']", messageId, testName, durationInMilliseconds) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFinished name='%s' duration='%v']\n", messageId, testName, durationInMilliseconds) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) SpecWillRun(specSummary *types.SpecSummary) { | ||||
| 	testName := escape(strings.Join(specSummary.ComponentTexts[1:], " ")) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testStarted name='%s']", messageId, testName) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testStarted name='%s']\n", messageId, testName) | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) SpecDidComplete(specSummary *types.SpecSummary) { | ||||
|  | @ -68,23 +68,31 @@ func (reporter *TeamCityReporter) SpecDidComplete(specSummary *types.SpecSummary | |||
| 
 | ||||
| 	if reporter.ReporterConfig.ReportPassed && specSummary.State == types.SpecStatePassed { | ||||
| 		details := escape(specSummary.CapturedOutput) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testPassed name='%s' details='%s']", messageId, testName, details) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testPassed name='%s' details='%s']\n", messageId, testName, details) | ||||
| 	} | ||||
| 	if specSummary.State == types.SpecStateFailed || specSummary.State == types.SpecStateTimedOut || specSummary.State == types.SpecStatePanicked { | ||||
| 		message := escape(specSummary.Failure.ComponentCodeLocation.String()) | ||||
| 		details := escape(specSummary.Failure.Message) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFailed name='%s' message='%s' details='%s']", messageId, testName, message, details) | ||||
| 		message := reporter.failureMessage(specSummary.Failure) | ||||
| 		details := reporter.failureDetails(specSummary.Failure) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testFailed name='%s' message='%s' details='%s']\n", messageId, testName, message, details) | ||||
| 	} | ||||
| 	if specSummary.State == types.SpecStateSkipped || specSummary.State == types.SpecStatePending { | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testIgnored name='%s']", messageId, testName) | ||||
| 		fmt.Fprintf(reporter.writer, "%s[testIgnored name='%s']\n", messageId, testName) | ||||
| 	} | ||||
| 
 | ||||
| 	durationInMilliseconds := specSummary.RunTime.Seconds() * 1000 | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testFinished name='%s' duration='%v']", messageId, testName, durationInMilliseconds) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testFinished name='%s' duration='%v']\n", messageId, testName, durationInMilliseconds) | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) SpecSuiteDidEnd(summary *types.SuiteSummary) { | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testSuiteFinished name='%s']", messageId, reporter.testSuiteName) | ||||
| 	fmt.Fprintf(reporter.writer, "%s[testSuiteFinished name='%s']\n", messageId, reporter.testSuiteName) | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) failureMessage(failure types.SpecFailure) string { | ||||
| 	return escape(failure.ComponentCodeLocation.String()) | ||||
| } | ||||
| 
 | ||||
| func (reporter *TeamCityReporter) failureDetails(failure types.SpecFailure) string { | ||||
| 	return escape(fmt.Sprintf("%s\n%s", failure.Message, failure.Location.String())) | ||||
| } | ||||
| 
 | ||||
| func escape(output string) string { | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ SuiteSummary represents the a summary of the test suite and is passed to both | |||
| Reporter.SpecSuiteWillBegin | ||||
| Reporter.SpecSuiteDidEnd | ||||
| 
 | ||||
| this is unfortunate as these two methods should receive different objects.  When running in parallel | ||||
| this is unfortunate as these two methods should receive different objects. When running in parallel | ||||
| each node does not deterministically know how many specs it will end up running. | ||||
| 
 | ||||
| Unfortunately making such a change would break backward compatibility. | ||||
|  |  | |||
|  | @ -1,9 +1,8 @@ | |||
| language: go | ||||
| 
 | ||||
| go: | ||||
|   - 1.10.x | ||||
|   - 1.11.x | ||||
|   - 1.12.x | ||||
|   - 1.13.x | ||||
|   - gotip | ||||
| 
 | ||||
| env: | ||||
|  |  | |||
|  | @ -1,3 +1,14 @@ | |||
| ## 1.8.1 | ||||
| 
 | ||||
| ### Fixes | ||||
| - Fix unexpected MatchError() behaviour (#375) [8ae7b2f] | ||||
| 
 | ||||
| ## 1.8.0 | ||||
| 
 | ||||
| ### Features | ||||
| - Allow optional description to be lazily evaluated function (#364) [bf64010] | ||||
| - Support wrapped errors (#359) [0a981cb] | ||||
| 
 | ||||
| ## 1.7.1 | ||||
| 
 | ||||
| ### Fixes | ||||
|  |  | |||
|  | @ -9,6 +9,7 @@ require ( | |||
| 	golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f // indirect | ||||
| 	golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e // indirect | ||||
| 	golang.org/x/text v0.3.0 // indirect | ||||
| 	golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7 | ||||
| 	gopkg.in/fsnotify.v1 v1.4.7 // indirect | ||||
| 	gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 // indirect | ||||
| 	gopkg.in/yaml.v2 v2.2.4 | ||||
|  |  | |||
|  | @ -14,6 +14,8 @@ golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e h1:o3PsSEY8E4eXWkXrIP9YJALUk | |||
| golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||
| golang.org/x/text v0.3.0 h1:g61tztE5qeGQ89tm6NTjjM9VPIm088od1l6aSorWRWg= | ||||
| golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7 h1:9zdDQZ7Thm29KFXgAX/+yaf3eVbP7djjWp/dXAppNCc= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= | ||||
| gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | ||||
| gopkg.in/fsnotify.v1 v1.4.7 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4= | ||||
|  |  | |||
|  | @ -24,7 +24,7 @@ import ( | |||
| 	"github.com/onsi/gomega/types" | ||||
| ) | ||||
| 
 | ||||
| const GOMEGA_VERSION = "1.7.1" | ||||
| const GOMEGA_VERSION = "1.8.1" | ||||
| 
 | ||||
| const nilFailHandlerPanic = `You are trying to make an assertion, but Gomega's fail handler is nil. | ||||
| If you're using Ginkgo then you probably forgot to put your assertion in an It(). | ||||
|  | @ -293,16 +293,18 @@ func SetDefaultConsistentlyPollingInterval(t time.Duration) { | |||
| // AsyncAssertion is returned by Eventually and Consistently and polls the actual value passed into Eventually against
 | ||||
| // the matcher passed to the Should and ShouldNot methods.
 | ||||
| //
 | ||||
| // Both Should and ShouldNot take a variadic optionalDescription argument.  This is passed on to
 | ||||
| // fmt.Sprintf() and is used to annotate failure messages.  This allows you to make your failure messages more
 | ||||
| // descriptive.
 | ||||
| // Both Should and ShouldNot take a variadic optionalDescription argument.
 | ||||
| // This argument allows you to make your failure messages more descriptive.
 | ||||
| // If a single argument of type `func() string` is passed, this function will be lazily evaluated if a failure occurs
 | ||||
| // and the returned string is used to annotate the failure message.
 | ||||
| // Otherwise, this argument is passed on to fmt.Sprintf() and then used to annotate the failure message.
 | ||||
| //
 | ||||
| // Both Should and ShouldNot return a boolean that is true if the assertion passed and false if it failed.
 | ||||
| //
 | ||||
| // Example:
 | ||||
| //
 | ||||
| //   Eventually(myChannel).Should(Receive(), "Something should have come down the pipe.")
 | ||||
| //   Consistently(myChannel).ShouldNot(Receive(), "Nothing should have come down the pipe.")
 | ||||
| //   Consistently(myChannel).ShouldNot(Receive(), func() string { return "Nothing should have come down the pipe." })
 | ||||
| type AsyncAssertion interface { | ||||
| 	Should(matcher types.GomegaMatcher, optionalDescription ...interface{}) bool | ||||
| 	ShouldNot(matcher types.GomegaMatcher, optionalDescription ...interface{}) bool | ||||
|  | @ -317,8 +319,11 @@ type GomegaAsyncAssertion = AsyncAssertion | |||
| // Typically Should/ShouldNot are used with Ω and To/ToNot/NotTo are used with Expect
 | ||||
| // though this is not enforced.
 | ||||
| //
 | ||||
| // All methods take a variadic optionalDescription argument.  This is passed on to fmt.Sprintf()
 | ||||
| // and is used to annotate failure messages.
 | ||||
| // All methods take a variadic optionalDescription argument.
 | ||||
| // This argument allows you to make your failure messages more descriptive.
 | ||||
| // If a single argument of type `func() string` is passed, this function will be lazily evaluated if a failure occurs
 | ||||
| // and the returned string is used to annotate the failure message.
 | ||||
| // Otherwise, this argument is passed on to fmt.Sprintf() and then used to annotate the failure message.
 | ||||
| //
 | ||||
| // All methods return a bool that is true if the assertion passed and false if it failed.
 | ||||
| //
 | ||||
|  |  | |||
|  | @ -52,16 +52,19 @@ func (assertion *Assertion) buildDescription(optionalDescription ...interface{}) | |||
| 	switch len(optionalDescription) { | ||||
| 	case 0: | ||||
| 		return "" | ||||
| 	default: | ||||
| 		return fmt.Sprintf(optionalDescription[0].(string), optionalDescription[1:]...) + "\n" | ||||
| 	case 1: | ||||
| 		if describe, ok := optionalDescription[0].(func() string); ok { | ||||
| 			return describe() + "\n" | ||||
| 		} | ||||
| 	} | ||||
| 	return fmt.Sprintf(optionalDescription[0].(string), optionalDescription[1:]...) + "\n" | ||||
| } | ||||
| 
 | ||||
| func (assertion *Assertion) match(matcher types.GomegaMatcher, desiredMatch bool, optionalDescription ...interface{}) bool { | ||||
| 	matches, err := matcher.Match(assertion.actualInput) | ||||
| 	description := assertion.buildDescription(optionalDescription...) | ||||
| 	assertion.failWrapper.TWithHelper.Helper() | ||||
| 	if err != nil { | ||||
| 		description := assertion.buildDescription(optionalDescription...) | ||||
| 		assertion.failWrapper.Fail(description+err.Error(), 2+assertion.offset) | ||||
| 		return false | ||||
| 	} | ||||
|  | @ -72,6 +75,7 @@ func (assertion *Assertion) match(matcher types.GomegaMatcher, desiredMatch bool | |||
| 		} else { | ||||
| 			message = matcher.NegatedFailureMessage(assertion.actualInput) | ||||
| 		} | ||||
| 		description := assertion.buildDescription(optionalDescription...) | ||||
| 		assertion.failWrapper.Fail(description+message, 2+assertion.offset) | ||||
| 		return false | ||||
| 	} | ||||
|  |  | |||
|  | @ -60,9 +60,12 @@ func (assertion *AsyncAssertion) buildDescription(optionalDescription ...interfa | |||
| 	switch len(optionalDescription) { | ||||
| 	case 0: | ||||
| 		return "" | ||||
| 	default: | ||||
| 		return fmt.Sprintf(optionalDescription[0].(string), optionalDescription[1:]...) + "\n" | ||||
| 	case 1: | ||||
| 		if describe, ok := optionalDescription[0].(func() string); ok { | ||||
| 			return describe() + "\n" | ||||
| 		} | ||||
| 	} | ||||
| 	return fmt.Sprintf(optionalDescription[0].(string), optionalDescription[1:]...) + "\n" | ||||
| } | ||||
| 
 | ||||
| func (assertion *AsyncAssertion) actualInputIsAFunction() bool { | ||||
|  | @ -103,8 +106,6 @@ func (assertion *AsyncAssertion) match(matcher types.GomegaMatcher, desiredMatch | |||
| 	timer := time.Now() | ||||
| 	timeout := time.After(assertion.timeoutInterval) | ||||
| 
 | ||||
| 	description := assertion.buildDescription(optionalDescription...) | ||||
| 
 | ||||
| 	var matches bool | ||||
| 	var err error | ||||
| 	mayChange := true | ||||
|  | @ -129,6 +130,7 @@ func (assertion *AsyncAssertion) match(matcher types.GomegaMatcher, desiredMatch | |||
| 			} | ||||
| 		} | ||||
| 		assertion.failWrapper.TWithHelper.Helper() | ||||
| 		description := assertion.buildDescription(optionalDescription...) | ||||
| 		assertion.failWrapper.Fail(fmt.Sprintf("%s after %.3fs.\n%s%s%s", preamble, time.Since(timer).Seconds(), description, message, errMsg), 3+assertion.offset) | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -5,6 +5,7 @@ import ( | |||
| 	"reflect" | ||||
| 
 | ||||
| 	"github.com/onsi/gomega/format" | ||||
| 	"golang.org/x/xerrors" | ||||
| ) | ||||
| 
 | ||||
| type MatchErrorMatcher struct { | ||||
|  | @ -21,25 +22,28 @@ func (matcher *MatchErrorMatcher) Match(actual interface{}) (success bool, err e | |||
| 	} | ||||
| 
 | ||||
| 	actualErr := actual.(error) | ||||
| 	expected := matcher.Expected | ||||
| 
 | ||||
| 	if isError(matcher.Expected) { | ||||
| 		return reflect.DeepEqual(actualErr, matcher.Expected), nil | ||||
| 	if isError(expected) { | ||||
| 		return reflect.DeepEqual(actualErr, expected) || xerrors.Is(actualErr, expected.(error)), nil | ||||
| 	} | ||||
| 
 | ||||
| 	if isString(matcher.Expected) { | ||||
| 		return actualErr.Error() == matcher.Expected, nil | ||||
| 	if isString(expected) { | ||||
| 		return actualErr.Error() == expected, nil | ||||
| 	} | ||||
| 
 | ||||
| 	var subMatcher omegaMatcher | ||||
| 	var hasSubMatcher bool | ||||
| 	if matcher.Expected != nil { | ||||
| 		subMatcher, hasSubMatcher = (matcher.Expected).(omegaMatcher) | ||||
| 	if expected != nil { | ||||
| 		subMatcher, hasSubMatcher = (expected).(omegaMatcher) | ||||
| 		if hasSubMatcher { | ||||
| 			return subMatcher.Match(actualErr.Error()) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return false, fmt.Errorf("MatchError must be passed an error, string, or Matcher that can match on strings.  Got:\n%s", format.Object(matcher.Expected, 1)) | ||||
| 	return false, fmt.Errorf( | ||||
| 		"MatchError must be passed an error, a string, or a Matcher that can match on strings. Got:\n%s", | ||||
| 		format.Object(expected, 1)) | ||||
| } | ||||
| 
 | ||||
| func (matcher *MatchErrorMatcher) FailureMessage(actual interface{}) (message string) { | ||||
|  |  | |||
|  | @ -1,15 +1,10 @@ | |||
| language: go | ||||
| go_import_path: github.com/pkg/errors | ||||
| go: | ||||
|   - 1.4.x | ||||
|   - 1.5.x | ||||
|   - 1.6.x | ||||
|   - 1.7.x | ||||
|   - 1.8.x | ||||
|   - 1.9.x | ||||
|   - 1.10.x | ||||
|   - 1.11.x | ||||
|   - 1.12.x | ||||
|   - 1.13.x | ||||
|   - tip | ||||
| 
 | ||||
| script: | ||||
|   - go test -v ./... | ||||
|   - make check | ||||
|  |  | |||
|  | @ -0,0 +1,44 @@ | |||
| PKGS := github.com/pkg/errors | ||||
| SRCDIRS := $(shell go list -f '{{.Dir}}' $(PKGS)) | ||||
| GO := go | ||||
| 
 | ||||
| check: test vet gofmt misspell unconvert staticcheck ineffassign unparam | ||||
| 
 | ||||
| test:  | ||||
| 	$(GO) test $(PKGS) | ||||
| 
 | ||||
| vet: | test | ||||
| 	$(GO) vet $(PKGS) | ||||
| 
 | ||||
| staticcheck: | ||||
| 	$(GO) get honnef.co/go/tools/cmd/staticcheck | ||||
| 	staticcheck -checks all $(PKGS) | ||||
| 
 | ||||
| misspell: | ||||
| 	$(GO) get github.com/client9/misspell/cmd/misspell | ||||
| 	misspell \
 | ||||
| 		-locale GB \
 | ||||
| 		-error \
 | ||||
| 		*.md *.go | ||||
| 
 | ||||
| unconvert: | ||||
| 	$(GO) get github.com/mdempsky/unconvert | ||||
| 	unconvert -v $(PKGS) | ||||
| 
 | ||||
| ineffassign: | ||||
| 	$(GO) get github.com/gordonklaus/ineffassign | ||||
| 	find $(SRCDIRS) -name '*.go' | xargs ineffassign | ||||
| 
 | ||||
| pedantic: check errcheck | ||||
| 
 | ||||
| unparam: | ||||
| 	$(GO) get mvdan.cc/unparam | ||||
| 	unparam ./... | ||||
| 
 | ||||
| errcheck: | ||||
| 	$(GO) get github.com/kisielk/errcheck | ||||
| 	errcheck $(PKGS) | ||||
| 
 | ||||
| gofmt:   | ||||
| 	@echo Checking code is gofmted | ||||
| 	@test -z "$(shell gofmt -s -l -d -e $(SRCDIRS) | tee /dev/stderr)" | ||||
|  | @ -41,11 +41,18 @@ default: | |||
| 
 | ||||
| [Read the package documentation for more information](https://godoc.org/github.com/pkg/errors). | ||||
| 
 | ||||
| ## Roadmap | ||||
| 
 | ||||
| With the upcoming [Go2 error proposals](https://go.googlesource.com/proposal/+/master/design/go2draft.md) this package is moving into maintenance mode. The roadmap for a 1.0 release is as follows: | ||||
| 
 | ||||
| - 0.9. Remove pre Go 1.9 and Go 1.10 support, address outstanding pull requests (if possible) | ||||
| - 1.0. Final release. | ||||
| 
 | ||||
| ## Contributing | ||||
| 
 | ||||
| We welcome pull requests, bug fixes and issue reports. With that said, the bar for adding new symbols to this package is intentionally set high. | ||||
| Because of the Go2 errors changes, this package is not accepting proposals for new functionality. With that said, we welcome pull requests, bug fixes and issue reports.  | ||||
| 
 | ||||
| Before proposing a change, please discuss your change by raising an issue. | ||||
| Before sending a PR, please discuss your change by raising an issue. | ||||
| 
 | ||||
| ## License | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,29 @@ | |||
| // +build !go1.13
 | ||||
| 
 | ||||
| package errors | ||||
| 
 | ||||
| // Cause recursively unwraps an error chain and returns the underlying cause of
 | ||||
| // the error, if possible. An error value has a cause if it implements the
 | ||||
| // following interface:
 | ||||
| //
 | ||||
| //     type causer interface {
 | ||||
| //            Cause() error
 | ||||
| //     }
 | ||||
| //
 | ||||
| // If the error does not implement Cause, the original error will
 | ||||
| // be returned. If the error is nil, nil will be returned without further
 | ||||
| // investigation.
 | ||||
| func Cause(err error) error { | ||||
| 	type causer interface { | ||||
| 		Cause() error | ||||
| 	} | ||||
| 
 | ||||
| 	for err != nil { | ||||
| 		cause, ok := err.(causer) | ||||
| 		if !ok { | ||||
| 			break | ||||
| 		} | ||||
| 		err = cause.Cause() | ||||
| 	} | ||||
| 	return err | ||||
| } | ||||
|  | @ -82,7 +82,7 @@ | |||
| //
 | ||||
| //     if err, ok := err.(stackTracer); ok {
 | ||||
| //             for _, f := range err.StackTrace() {
 | ||||
| //                     fmt.Printf("%+s:%d", f)
 | ||||
| //                     fmt.Printf("%+s:%d\n", f, f)
 | ||||
| //             }
 | ||||
| //     }
 | ||||
| //
 | ||||
|  | @ -159,6 +159,9 @@ type withStack struct { | |||
| 
 | ||||
| func (w *withStack) Cause() error { return w.error } | ||||
| 
 | ||||
| // Unwrap provides compatibility for Go 1.13 error chains.
 | ||||
| func (w *withStack) Unwrap() error { return w.error } | ||||
| 
 | ||||
| func (w *withStack) Format(s fmt.State, verb rune) { | ||||
| 	switch verb { | ||||
| 	case 'v': | ||||
|  | @ -241,6 +244,9 @@ type withMessage struct { | |||
| func (w *withMessage) Error() string { return w.msg + ": " + w.cause.Error() } | ||||
| func (w *withMessage) Cause() error  { return w.cause } | ||||
| 
 | ||||
| // Unwrap provides compatibility for Go 1.13 error chains.
 | ||||
| func (w *withMessage) Unwrap() error { return w.cause } | ||||
| 
 | ||||
| func (w *withMessage) Format(s fmt.State, verb rune) { | ||||
| 	switch verb { | ||||
| 	case 'v': | ||||
|  | @ -254,29 +260,3 @@ func (w *withMessage) Format(s fmt.State, verb rune) { | |||
| 		io.WriteString(s, w.Error()) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Cause returns the underlying cause of the error, if possible.
 | ||||
| // An error value has a cause if it implements the following
 | ||||
| // interface:
 | ||||
| //
 | ||||
| //     type causer interface {
 | ||||
| //            Cause() error
 | ||||
| //     }
 | ||||
| //
 | ||||
| // If the error does not implement Cause, the original error will
 | ||||
| // be returned. If the error is nil, nil will be returned without further
 | ||||
| // investigation.
 | ||||
| func Cause(err error) error { | ||||
| 	type causer interface { | ||||
| 		Cause() error | ||||
| 	} | ||||
| 
 | ||||
| 	for err != nil { | ||||
| 		cause, ok := err.(causer) | ||||
| 		if !ok { | ||||
| 			break | ||||
| 		} | ||||
| 		err = cause.Cause() | ||||
| 	} | ||||
| 	return err | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,71 @@ | |||
| // +build go1.13
 | ||||
| 
 | ||||
| package errors | ||||
| 
 | ||||
| import ( | ||||
| 	stderrors "errors" | ||||
| ) | ||||
| 
 | ||||
| // Is reports whether any error in err's chain matches target.
 | ||||
| //
 | ||||
| // The chain consists of err itself followed by the sequence of errors obtained by
 | ||||
| // repeatedly calling Unwrap.
 | ||||
| //
 | ||||
| // An error is considered to match a target if it is equal to that target or if
 | ||||
| // it implements a method Is(error) bool such that Is(target) returns true.
 | ||||
| func Is(err, target error) bool { return stderrors.Is(err, target) } | ||||
| 
 | ||||
| // As finds the first error in err's chain that matches target, and if so, sets
 | ||||
| // target to that error value and returns true.
 | ||||
| //
 | ||||
| // The chain consists of err itself followed by the sequence of errors obtained by
 | ||||
| // repeatedly calling Unwrap.
 | ||||
| //
 | ||||
| // An error matches target if the error's concrete value is assignable to the value
 | ||||
| // pointed to by target, or if the error has a method As(interface{}) bool such that
 | ||||
| // As(target) returns true. In the latter case, the As method is responsible for
 | ||||
| // setting target.
 | ||||
| //
 | ||||
| // As will panic if target is not a non-nil pointer to either a type that implements
 | ||||
| // error, or to any interface type. As returns false if err is nil.
 | ||||
| func As(err error, target interface{}) bool { return stderrors.As(err, target) } | ||||
| 
 | ||||
| // Unwrap returns the result of calling the Unwrap method on err, if err's
 | ||||
| // type contains an Unwrap method returning error.
 | ||||
| // Otherwise, Unwrap returns nil.
 | ||||
| func Unwrap(err error) error { | ||||
| 	return stderrors.Unwrap(err) | ||||
| } | ||||
| 
 | ||||
| // Cause recursively unwraps an error chain and returns the underlying cause of
 | ||||
| // the error, if possible. There are two ways that an error value may provide a
 | ||||
| // cause. First, the error may implement the following interface:
 | ||||
| //
 | ||||
| //     type causer interface {
 | ||||
| //            Cause() error
 | ||||
| //     }
 | ||||
| //
 | ||||
| // Second, the error may return a non-nil value when passed as an argument to
 | ||||
| // the Unwrap function. This makes Cause forwards-compatible with Go 1.13 error
 | ||||
| // chains.
 | ||||
| //
 | ||||
| // If an error value satisfies both methods of unwrapping, Cause will use the
 | ||||
| // causer interface.
 | ||||
| //
 | ||||
| // If the error is nil, nil will be returned without further investigation.
 | ||||
| func Cause(err error) error { | ||||
| 	type causer interface { | ||||
| 		Cause() error | ||||
| 	} | ||||
| 
 | ||||
| 	for err != nil { | ||||
| 		if cause, ok := err.(causer); ok { | ||||
| 			err = cause.Cause() | ||||
| 		} else if unwrapped := Unwrap(err); unwrapped != nil { | ||||
| 			err = unwrapped | ||||
| 		} else { | ||||
| 			break | ||||
| 		} | ||||
| 	} | ||||
| 	return err | ||||
| } | ||||
|  | @ -5,10 +5,13 @@ import ( | |||
| 	"io" | ||||
| 	"path" | ||||
| 	"runtime" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| // Frame represents a program counter inside a stack frame.
 | ||||
| // For historical reasons if Frame is interpreted as a uintptr
 | ||||
| // its value represents the program counter + 1.
 | ||||
| type Frame uintptr | ||||
| 
 | ||||
| // pc returns the program counter for this frame;
 | ||||
|  | @ -37,6 +40,15 @@ func (f Frame) line() int { | |||
| 	return line | ||||
| } | ||||
| 
 | ||||
| // name returns the name of this function, if known.
 | ||||
| func (f Frame) name() string { | ||||
| 	fn := runtime.FuncForPC(f.pc()) | ||||
| 	if fn == nil { | ||||
| 		return "unknown" | ||||
| 	} | ||||
| 	return fn.Name() | ||||
| } | ||||
| 
 | ||||
| // Format formats the frame according to the fmt.Formatter interface.
 | ||||
| //
 | ||||
| //    %s    source file
 | ||||
|  | @ -54,22 +66,16 @@ func (f Frame) Format(s fmt.State, verb rune) { | |||
| 	case 's': | ||||
| 		switch { | ||||
| 		case s.Flag('+'): | ||||
| 			pc := f.pc() | ||||
| 			fn := runtime.FuncForPC(pc) | ||||
| 			if fn == nil { | ||||
| 				io.WriteString(s, "unknown") | ||||
| 			} else { | ||||
| 				file, _ := fn.FileLine(pc) | ||||
| 				fmt.Fprintf(s, "%s\n\t%s", fn.Name(), file) | ||||
| 			} | ||||
| 			io.WriteString(s, f.name()) | ||||
| 			io.WriteString(s, "\n\t") | ||||
| 			io.WriteString(s, f.file()) | ||||
| 		default: | ||||
| 			io.WriteString(s, path.Base(f.file())) | ||||
| 		} | ||||
| 	case 'd': | ||||
| 		fmt.Fprintf(s, "%d", f.line()) | ||||
| 		io.WriteString(s, strconv.Itoa(f.line())) | ||||
| 	case 'n': | ||||
| 		name := runtime.FuncForPC(f.pc()).Name() | ||||
| 		io.WriteString(s, funcname(name)) | ||||
| 		io.WriteString(s, funcname(f.name())) | ||||
| 	case 'v': | ||||
| 		f.Format(s, 's') | ||||
| 		io.WriteString(s, ":") | ||||
|  | @ -77,6 +83,16 @@ func (f Frame) Format(s fmt.State, verb rune) { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // MarshalText formats a stacktrace Frame as a text string. The output is the
 | ||||
| // same as that of fmt.Sprintf("%+v", f), but without newlines or tabs.
 | ||||
| func (f Frame) MarshalText() ([]byte, error) { | ||||
| 	name := f.name() | ||||
| 	if name == "unknown" { | ||||
| 		return []byte(name), nil | ||||
| 	} | ||||
| 	return []byte(fmt.Sprintf("%s %s:%d", name, f.file(), f.line())), nil | ||||
| } | ||||
| 
 | ||||
| // StackTrace is stack of Frames from innermost (newest) to outermost (oldest).
 | ||||
| type StackTrace []Frame | ||||
| 
 | ||||
|  | @ -94,18 +110,32 @@ func (st StackTrace) Format(s fmt.State, verb rune) { | |||
| 		switch { | ||||
| 		case s.Flag('+'): | ||||
| 			for _, f := range st { | ||||
| 				fmt.Fprintf(s, "\n%+v", f) | ||||
| 				io.WriteString(s, "\n") | ||||
| 				f.Format(s, verb) | ||||
| 			} | ||||
| 		case s.Flag('#'): | ||||
| 			fmt.Fprintf(s, "%#v", []Frame(st)) | ||||
| 		default: | ||||
| 			fmt.Fprintf(s, "%v", []Frame(st)) | ||||
| 			st.formatSlice(s, verb) | ||||
| 		} | ||||
| 	case 's': | ||||
| 		fmt.Fprintf(s, "%s", []Frame(st)) | ||||
| 		st.formatSlice(s, verb) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // formatSlice will format this StackTrace into the given buffer as a slice of
 | ||||
| // Frame, only valid when called with '%s' or '%v'.
 | ||||
| func (st StackTrace) formatSlice(s fmt.State, verb rune) { | ||||
| 	io.WriteString(s, "[") | ||||
| 	for i, f := range st { | ||||
| 		if i > 0 { | ||||
| 			io.WriteString(s, " ") | ||||
| 		} | ||||
| 		f.Format(s, verb) | ||||
| 	} | ||||
| 	io.WriteString(s, "]") | ||||
| } | ||||
| 
 | ||||
| // stack represents a stack of program counters.
 | ||||
| type stack []uintptr | ||||
| 
 | ||||
|  |  | |||
|  | @ -52,10 +52,11 @@ import ( | |||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	prefaceTimeout        = 10 * time.Second | ||||
| 	firstSettingsTimeout  = 2 * time.Second // should be in-flight with preface anyway
 | ||||
| 	handlerChunkWriteSize = 4 << 10 | ||||
| 	defaultMaxStreams     = 250 // TODO: make this 100 as the GFE seems to?
 | ||||
| 	prefaceTimeout         = 10 * time.Second | ||||
| 	firstSettingsTimeout   = 2 * time.Second // should be in-flight with preface anyway
 | ||||
| 	handlerChunkWriteSize  = 4 << 10 | ||||
| 	defaultMaxStreams      = 250 // TODO: make this 100 as the GFE seems to?
 | ||||
| 	maxQueuedControlFrames = 10000 | ||||
| ) | ||||
| 
 | ||||
| var ( | ||||
|  | @ -163,6 +164,15 @@ func (s *Server) maxConcurrentStreams() uint32 { | |||
| 	return defaultMaxStreams | ||||
| } | ||||
| 
 | ||||
| // maxQueuedControlFrames is the maximum number of control frames like
 | ||||
| // SETTINGS, PING and RST_STREAM that will be queued for writing before
 | ||||
| // the connection is closed to prevent memory exhaustion attacks.
 | ||||
| func (s *Server) maxQueuedControlFrames() int { | ||||
| 	// TODO: if anybody asks, add a Server field, and remember to define the
 | ||||
| 	// behavior of negative values.
 | ||||
| 	return maxQueuedControlFrames | ||||
| } | ||||
| 
 | ||||
| type serverInternalState struct { | ||||
| 	mu          sync.Mutex | ||||
| 	activeConns map[*serverConn]struct{} | ||||
|  | @ -506,6 +516,7 @@ type serverConn struct { | |||
| 	sawFirstSettings            bool // got the initial SETTINGS frame after the preface
 | ||||
| 	needToSendSettingsAck       bool | ||||
| 	unackedSettings             int    // how many SETTINGS have we sent without ACKs?
 | ||||
| 	queuedControlFrames         int    // control frames in the writeSched queue
 | ||||
| 	clientMaxStreams            uint32 // SETTINGS_MAX_CONCURRENT_STREAMS from client (our PUSH_PROMISE limit)
 | ||||
| 	advMaxStreams               uint32 // our SETTINGS_MAX_CONCURRENT_STREAMS advertised the client
 | ||||
| 	curClientStreams            uint32 // number of open streams initiated by the client
 | ||||
|  | @ -894,6 +905,14 @@ func (sc *serverConn) serve() { | |||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// If the peer is causing us to generate a lot of control frames,
 | ||||
| 		// but not reading them from us, assume they are trying to make us
 | ||||
| 		// run out of memory.
 | ||||
| 		if sc.queuedControlFrames > sc.srv.maxQueuedControlFrames() { | ||||
| 			sc.vlogf("http2: too many control frames in send queue, closing connection") | ||||
| 			return | ||||
| 		} | ||||
| 
 | ||||
| 		// Start the shutdown timer after sending a GOAWAY. When sending GOAWAY
 | ||||
| 		// with no error code (graceful shutdown), don't start the timer until
 | ||||
| 		// all open streams have been completed.
 | ||||
|  | @ -1093,6 +1112,14 @@ func (sc *serverConn) writeFrame(wr FrameWriteRequest) { | |||
| 	} | ||||
| 
 | ||||
| 	if !ignoreWrite { | ||||
| 		if wr.isControl() { | ||||
| 			sc.queuedControlFrames++ | ||||
| 			// For extra safety, detect wraparounds, which should not happen,
 | ||||
| 			// and pull the plug.
 | ||||
| 			if sc.queuedControlFrames < 0 { | ||||
| 				sc.conn.Close() | ||||
| 			} | ||||
| 		} | ||||
| 		sc.writeSched.Push(wr) | ||||
| 	} | ||||
| 	sc.scheduleFrameWrite() | ||||
|  | @ -1210,10 +1237,8 @@ func (sc *serverConn) wroteFrame(res frameWriteResult) { | |||
| // If a frame is already being written, nothing happens. This will be called again
 | ||||
| // when the frame is done being written.
 | ||||
| //
 | ||||
| // If a frame isn't being written we need to send one, the best frame
 | ||||
| // to send is selected, preferring first things that aren't
 | ||||
| // stream-specific (e.g. ACKing settings), and then finding the
 | ||||
| // highest priority stream.
 | ||||
| // If a frame isn't being written and we need to send one, the best frame
 | ||||
| // to send is selected by writeSched.
 | ||||
| //
 | ||||
| // If a frame isn't being written and there's nothing else to send, we
 | ||||
| // flush the write buffer.
 | ||||
|  | @ -1241,6 +1266,9 @@ func (sc *serverConn) scheduleFrameWrite() { | |||
| 		} | ||||
| 		if !sc.inGoAway || sc.goAwayCode == ErrCodeNo { | ||||
| 			if wr, ok := sc.writeSched.Pop(); ok { | ||||
| 				if wr.isControl() { | ||||
| 					sc.queuedControlFrames-- | ||||
| 				} | ||||
| 				sc.startFrameWrite(wr) | ||||
| 				continue | ||||
| 			} | ||||
|  | @ -1533,6 +1561,8 @@ func (sc *serverConn) processSettings(f *SettingsFrame) error { | |||
| 	if err := f.ForeachSetting(sc.processSetting); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	// TODO: judging by RFC 7540, Section 6.5.3 each SETTINGS frame should be
 | ||||
| 	// acknowledged individually, even if multiple are received before the ACK.
 | ||||
| 	sc.needToSendSettingsAck = true | ||||
| 	sc.scheduleFrameWrite() | ||||
| 	return nil | ||||
|  |  | |||
|  | @ -992,7 +992,7 @@ func (cc *ClientConn) roundTrip(req *http.Request) (res *http.Response, gotErrAf | |||
| 		req.Method != "HEAD" { | ||||
| 		// Request gzip only, not deflate. Deflate is ambiguous and
 | ||||
| 		// not as universally supported anyway.
 | ||||
| 		// See: http://www.gzip.org/zlib/zlib_faq.html#faq38
 | ||||
| 		// See: https://zlib.net/zlib_faq.html#faq39
 | ||||
| 		//
 | ||||
| 		// Note that we don't request this for HEAD requests,
 | ||||
| 		// due to a bug in nginx:
 | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ type WriteScheduler interface { | |||
| 
 | ||||
| 	// Pop dequeues the next frame to write. Returns false if no frames can
 | ||||
| 	// be written. Frames with a given wr.StreamID() are Pop'd in the same
 | ||||
| 	// order they are Push'd.
 | ||||
| 	// order they are Push'd. No frames should be discarded except by CloseStream.
 | ||||
| 	Pop() (wr FrameWriteRequest, ok bool) | ||||
| } | ||||
| 
 | ||||
|  | @ -76,6 +76,12 @@ func (wr FrameWriteRequest) StreamID() uint32 { | |||
| 	return wr.stream.id | ||||
| } | ||||
| 
 | ||||
| // isControl reports whether wr is a control frame for MaxQueuedControlFrames
 | ||||
| // purposes. That includes non-stream frames and RST_STREAM frames.
 | ||||
| func (wr FrameWriteRequest) isControl() bool { | ||||
| 	return wr.stream == nil | ||||
| } | ||||
| 
 | ||||
| // DataSize returns the number of flow control bytes that must be consumed
 | ||||
| // to write this entire frame. This is 0 for non-DATA frames.
 | ||||
| func (wr FrameWriteRequest) DataSize() int { | ||||
|  |  | |||
|  | @ -19,7 +19,8 @@ type randomWriteScheduler struct { | |||
| 	zero writeQueue | ||||
| 
 | ||||
| 	// sq contains the stream-specific queues, keyed by stream ID.
 | ||||
| 	// When a stream is idle or closed, it's deleted from the map.
 | ||||
| 	// When a stream is idle, closed, or emptied, it's deleted
 | ||||
| 	// from the map.
 | ||||
| 	sq map[uint32]*writeQueue | ||||
| 
 | ||||
| 	// pool of empty queues for reuse.
 | ||||
|  | @ -63,8 +64,12 @@ func (ws *randomWriteScheduler) Pop() (FrameWriteRequest, bool) { | |||
| 		return ws.zero.shift(), true | ||||
| 	} | ||||
| 	// Iterate over all non-idle streams until finding one that can be consumed.
 | ||||
| 	for _, q := range ws.sq { | ||||
| 	for streamID, q := range ws.sq { | ||||
| 		if wr, ok := q.consume(math.MaxInt32); ok { | ||||
| 			if q.empty() { | ||||
| 				delete(ws.sq, streamID) | ||||
| 				ws.queuePool.put(q) | ||||
| 			} | ||||
| 			return wr, true | ||||
| 		} | ||||
| 	} | ||||
|  |  | |||
|  | @ -0,0 +1,27 @@ | |||
| Copyright (c) 2019 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. | ||||
|  | @ -0,0 +1,2 @@ | |||
| This repository holds the transition packages for the new Go 1.13 error values. | ||||
| See golang.org/design/29934-error-values. | ||||
|  | @ -0,0 +1,193 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"reflect" | ||||
| 	"strconv" | ||||
| ) | ||||
| 
 | ||||
| // FormatError calls the FormatError method of f with an errors.Printer
 | ||||
| // configured according to s and verb, and writes the result to s.
 | ||||
| func FormatError(f Formatter, s fmt.State, verb rune) { | ||||
| 	// Assuming this function is only called from the Format method, and given
 | ||||
| 	// that FormatError takes precedence over Format, it cannot be called from
 | ||||
| 	// any package that supports errors.Formatter. It is therefore safe to
 | ||||
| 	// disregard that State may be a specific printer implementation and use one
 | ||||
| 	// of our choice instead.
 | ||||
| 
 | ||||
| 	// limitations: does not support printing error as Go struct.
 | ||||
| 
 | ||||
| 	var ( | ||||
| 		sep    = " " // separator before next error
 | ||||
| 		p      = &state{State: s} | ||||
| 		direct = true | ||||
| 	) | ||||
| 
 | ||||
| 	var err error = f | ||||
| 
 | ||||
| 	switch verb { | ||||
| 	// Note that this switch must match the preference order
 | ||||
| 	// for ordinary string printing (%#v before %+v, and so on).
 | ||||
| 
 | ||||
| 	case 'v': | ||||
| 		if s.Flag('#') { | ||||
| 			if stringer, ok := err.(fmt.GoStringer); ok { | ||||
| 				io.WriteString(&p.buf, stringer.GoString()) | ||||
| 				goto exit | ||||
| 			} | ||||
| 			// proceed as if it were %v
 | ||||
| 		} else if s.Flag('+') { | ||||
| 			p.printDetail = true | ||||
| 			sep = "\n  - " | ||||
| 		} | ||||
| 	case 's': | ||||
| 	case 'q', 'x', 'X': | ||||
| 		// Use an intermediate buffer in the rare cases that precision,
 | ||||
| 		// truncation, or one of the alternative verbs (q, x, and X) are
 | ||||
| 		// specified.
 | ||||
| 		direct = false | ||||
| 
 | ||||
| 	default: | ||||
| 		p.buf.WriteString("%!") | ||||
| 		p.buf.WriteRune(verb) | ||||
| 		p.buf.WriteByte('(') | ||||
| 		switch { | ||||
| 		case err != nil: | ||||
| 			p.buf.WriteString(reflect.TypeOf(f).String()) | ||||
| 		default: | ||||
| 			p.buf.WriteString("<nil>") | ||||
| 		} | ||||
| 		p.buf.WriteByte(')') | ||||
| 		io.Copy(s, &p.buf) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| loop: | ||||
| 	for { | ||||
| 		switch v := err.(type) { | ||||
| 		case Formatter: | ||||
| 			err = v.FormatError((*printer)(p)) | ||||
| 		case fmt.Formatter: | ||||
| 			v.Format(p, 'v') | ||||
| 			break loop | ||||
| 		default: | ||||
| 			io.WriteString(&p.buf, v.Error()) | ||||
| 			break loop | ||||
| 		} | ||||
| 		if err == nil { | ||||
| 			break | ||||
| 		} | ||||
| 		if p.needColon || !p.printDetail { | ||||
| 			p.buf.WriteByte(':') | ||||
| 			p.needColon = false | ||||
| 		} | ||||
| 		p.buf.WriteString(sep) | ||||
| 		p.inDetail = false | ||||
| 		p.needNewline = false | ||||
| 	} | ||||
| 
 | ||||
| exit: | ||||
| 	width, okW := s.Width() | ||||
| 	prec, okP := s.Precision() | ||||
| 
 | ||||
| 	if !direct || (okW && width > 0) || okP { | ||||
| 		// Construct format string from State s.
 | ||||
| 		format := []byte{'%'} | ||||
| 		if s.Flag('-') { | ||||
| 			format = append(format, '-') | ||||
| 		} | ||||
| 		if s.Flag('+') { | ||||
| 			format = append(format, '+') | ||||
| 		} | ||||
| 		if s.Flag(' ') { | ||||
| 			format = append(format, ' ') | ||||
| 		} | ||||
| 		if okW { | ||||
| 			format = strconv.AppendInt(format, int64(width), 10) | ||||
| 		} | ||||
| 		if okP { | ||||
| 			format = append(format, '.') | ||||
| 			format = strconv.AppendInt(format, int64(prec), 10) | ||||
| 		} | ||||
| 		format = append(format, string(verb)...) | ||||
| 		fmt.Fprintf(s, string(format), p.buf.String()) | ||||
| 	} else { | ||||
| 		io.Copy(s, &p.buf) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| var detailSep = []byte("\n    ") | ||||
| 
 | ||||
| // state tracks error printing state. It implements fmt.State.
 | ||||
| type state struct { | ||||
| 	fmt.State | ||||
| 	buf bytes.Buffer | ||||
| 
 | ||||
| 	printDetail bool | ||||
| 	inDetail    bool | ||||
| 	needColon   bool | ||||
| 	needNewline bool | ||||
| } | ||||
| 
 | ||||
| func (s *state) Write(b []byte) (n int, err error) { | ||||
| 	if s.printDetail { | ||||
| 		if len(b) == 0 { | ||||
| 			return 0, nil | ||||
| 		} | ||||
| 		if s.inDetail && s.needColon { | ||||
| 			s.needNewline = true | ||||
| 			if b[0] == '\n' { | ||||
| 				b = b[1:] | ||||
| 			} | ||||
| 		} | ||||
| 		k := 0 | ||||
| 		for i, c := range b { | ||||
| 			if s.needNewline { | ||||
| 				if s.inDetail && s.needColon { | ||||
| 					s.buf.WriteByte(':') | ||||
| 					s.needColon = false | ||||
| 				} | ||||
| 				s.buf.Write(detailSep) | ||||
| 				s.needNewline = false | ||||
| 			} | ||||
| 			if c == '\n' { | ||||
| 				s.buf.Write(b[k:i]) | ||||
| 				k = i + 1 | ||||
| 				s.needNewline = true | ||||
| 			} | ||||
| 		} | ||||
| 		s.buf.Write(b[k:]) | ||||
| 		if !s.inDetail { | ||||
| 			s.needColon = true | ||||
| 		} | ||||
| 	} else if !s.inDetail { | ||||
| 		s.buf.Write(b) | ||||
| 	} | ||||
| 	return len(b), nil | ||||
| } | ||||
| 
 | ||||
| // printer wraps a state to implement an xerrors.Printer.
 | ||||
| type printer state | ||||
| 
 | ||||
| func (s *printer) Print(args ...interface{}) { | ||||
| 	if !s.inDetail || s.printDetail { | ||||
| 		fmt.Fprint((*state)(s), args...) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (s *printer) Printf(format string, args ...interface{}) { | ||||
| 	if !s.inDetail || s.printDetail { | ||||
| 		fmt.Fprintf((*state)(s), format, args...) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (s *printer) Detail() bool { | ||||
| 	s.inDetail = true | ||||
| 	return s.printDetail | ||||
| } | ||||
|  | @ -0,0 +1 @@ | |||
| issuerepo: golang/go | ||||
|  | @ -0,0 +1,25 @@ | |||
| // Copyright 2019 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| // Package xerrors implements functions to manipulate errors.
 | ||||
| //
 | ||||
| // This package supports transitioning to the Go 2 proposal for error values:
 | ||||
| //   https://golang.org/design/29934-error-values
 | ||||
| //
 | ||||
| // Most of the functions and types in this package will be incorporated into the
 | ||||
| // standard library's errors package in Go 1.13; the behavior of this package's
 | ||||
| // Errorf function will be incorporated into the standard library's fmt.Errorf.
 | ||||
| // Use this package to get equivalent behavior in all supported Go versions. For
 | ||||
| // example, create errors using
 | ||||
| //
 | ||||
| //    xerrors.New("write failed")
 | ||||
| //
 | ||||
| // or
 | ||||
| //
 | ||||
| //    xerrors.Errorf("while reading: %v", err)
 | ||||
| //
 | ||||
| // If you want your error type to participate in the new formatting
 | ||||
| // implementation for %v and %+v, provide it with a Format method that calls
 | ||||
| // xerrors.FormatError, as shown in the example for FormatError.
 | ||||
| package xerrors // import "golang.org/x/xerrors"
 | ||||
|  | @ -0,0 +1,33 @@ | |||
| // Copyright 2011 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| import "fmt" | ||||
| 
 | ||||
| // errorString is a trivial implementation of error.
 | ||||
| type errorString struct { | ||||
| 	s     string | ||||
| 	frame Frame | ||||
| } | ||||
| 
 | ||||
| // New returns an error that formats as the given text.
 | ||||
| //
 | ||||
| // The returned error contains a Frame set to the caller's location and
 | ||||
| // implements Formatter to show this information when printed with details.
 | ||||
| func New(text string) error { | ||||
| 	return &errorString{text, Caller(1)} | ||||
| } | ||||
| 
 | ||||
| func (e *errorString) Error() string { | ||||
| 	return e.s | ||||
| } | ||||
| 
 | ||||
| func (e *errorString) Format(s fmt.State, v rune) { FormatError(e, s, v) } | ||||
| 
 | ||||
| func (e *errorString) FormatError(p Printer) (next error) { | ||||
| 	p.Print(e.s) | ||||
| 	e.frame.Format(p) | ||||
| 	return nil | ||||
| } | ||||
|  | @ -0,0 +1,109 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"golang.org/x/xerrors/internal" | ||||
| ) | ||||
| 
 | ||||
| // Errorf formats according to a format specifier and returns the string as a
 | ||||
| // value that satisfies error.
 | ||||
| //
 | ||||
| // The returned error includes the file and line number of the caller when
 | ||||
| // formatted with additional detail enabled. If the last argument is an error
 | ||||
| // the returned error's Format method will return it if the format string ends
 | ||||
| // with ": %s", ": %v", or ": %w". If the last argument is an error and the
 | ||||
| // format string ends with ": %w", the returned error implements Wrapper
 | ||||
| // with an Unwrap method returning it.
 | ||||
| func Errorf(format string, a ...interface{}) error { | ||||
| 	err, wrap := lastError(format, a) | ||||
| 	format = formatPlusW(format) | ||||
| 	if err == nil { | ||||
| 		return &noWrapError{fmt.Sprintf(format, a...), nil, Caller(1)} | ||||
| 	} | ||||
| 
 | ||||
| 	// TODO: this is not entirely correct. The error value could be
 | ||||
| 	// printed elsewhere in format if it mixes numbered with unnumbered
 | ||||
| 	// substitutions. With relatively small changes to doPrintf we can
 | ||||
| 	// have it optionally ignore extra arguments and pass the argument
 | ||||
| 	// list in its entirety.
 | ||||
| 	msg := fmt.Sprintf(format[:len(format)-len(": %s")], a[:len(a)-1]...) | ||||
| 	frame := Frame{} | ||||
| 	if internal.EnableTrace { | ||||
| 		frame = Caller(1) | ||||
| 	} | ||||
| 	if wrap { | ||||
| 		return &wrapError{msg, err, frame} | ||||
| 	} | ||||
| 	return &noWrapError{msg, err, frame} | ||||
| } | ||||
| 
 | ||||
| // formatPlusW is used to avoid the vet check that will barf at %w.
 | ||||
| func formatPlusW(s string) string { | ||||
| 	return s | ||||
| } | ||||
| 
 | ||||
| func lastError(format string, a []interface{}) (err error, wrap bool) { | ||||
| 	wrap = strings.HasSuffix(format, ": %w") | ||||
| 	if !wrap && | ||||
| 		!strings.HasSuffix(format, ": %s") && | ||||
| 		!strings.HasSuffix(format, ": %v") { | ||||
| 		return nil, false | ||||
| 	} | ||||
| 
 | ||||
| 	if len(a) == 0 { | ||||
| 		return nil, false | ||||
| 	} | ||||
| 
 | ||||
| 	err, ok := a[len(a)-1].(error) | ||||
| 	if !ok { | ||||
| 		return nil, false | ||||
| 	} | ||||
| 
 | ||||
| 	return err, wrap | ||||
| } | ||||
| 
 | ||||
| type noWrapError struct { | ||||
| 	msg   string | ||||
| 	err   error | ||||
| 	frame Frame | ||||
| } | ||||
| 
 | ||||
| func (e *noWrapError) Error() string { | ||||
| 	return fmt.Sprint(e) | ||||
| } | ||||
| 
 | ||||
| func (e *noWrapError) Format(s fmt.State, v rune) { FormatError(e, s, v) } | ||||
| 
 | ||||
| func (e *noWrapError) FormatError(p Printer) (next error) { | ||||
| 	p.Print(e.msg) | ||||
| 	e.frame.Format(p) | ||||
| 	return e.err | ||||
| } | ||||
| 
 | ||||
| type wrapError struct { | ||||
| 	msg   string | ||||
| 	err   error | ||||
| 	frame Frame | ||||
| } | ||||
| 
 | ||||
| func (e *wrapError) Error() string { | ||||
| 	return fmt.Sprint(e) | ||||
| } | ||||
| 
 | ||||
| func (e *wrapError) Format(s fmt.State, v rune) { FormatError(e, s, v) } | ||||
| 
 | ||||
| func (e *wrapError) FormatError(p Printer) (next error) { | ||||
| 	p.Print(e.msg) | ||||
| 	e.frame.Format(p) | ||||
| 	return e.err | ||||
| } | ||||
| 
 | ||||
| func (e *wrapError) Unwrap() error { | ||||
| 	return e.err | ||||
| } | ||||
|  | @ -0,0 +1,34 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| // A Formatter formats error messages.
 | ||||
| type Formatter interface { | ||||
| 	error | ||||
| 
 | ||||
| 	// FormatError prints the receiver's first error and returns the next error in
 | ||||
| 	// the error chain, if any.
 | ||||
| 	FormatError(p Printer) (next error) | ||||
| } | ||||
| 
 | ||||
| // A Printer formats error messages.
 | ||||
| //
 | ||||
| // The most common implementation of Printer is the one provided by package fmt
 | ||||
| // during Printf (as of Go 1.13). Localization packages such as golang.org/x/text/message
 | ||||
| // typically provide their own implementations.
 | ||||
| type Printer interface { | ||||
| 	// Print appends args to the message output.
 | ||||
| 	Print(args ...interface{}) | ||||
| 
 | ||||
| 	// Printf writes a formatted string.
 | ||||
| 	Printf(format string, args ...interface{}) | ||||
| 
 | ||||
| 	// Detail reports whether error detail is requested.
 | ||||
| 	// After the first call to Detail, all text written to the Printer
 | ||||
| 	// is formatted as additional detail, or ignored when
 | ||||
| 	// detail has not been requested.
 | ||||
| 	// If Detail returns false, the caller can avoid printing the detail at all.
 | ||||
| 	Detail() bool | ||||
| } | ||||
|  | @ -0,0 +1,56 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| import ( | ||||
| 	"runtime" | ||||
| ) | ||||
| 
 | ||||
| // A Frame contains part of a call stack.
 | ||||
| type Frame struct { | ||||
| 	// Make room for three PCs: the one we were asked for, what it called,
 | ||||
| 	// and possibly a PC for skipPleaseUseCallersFrames. See:
 | ||||
| 	// https://go.googlesource.com/go/+/032678e0fb/src/runtime/extern.go#169
 | ||||
| 	frames [3]uintptr | ||||
| } | ||||
| 
 | ||||
| // Caller returns a Frame that describes a frame on the caller's stack.
 | ||||
| // The argument skip is the number of frames to skip over.
 | ||||
| // Caller(0) returns the frame for the caller of Caller.
 | ||||
| func Caller(skip int) Frame { | ||||
| 	var s Frame | ||||
| 	runtime.Callers(skip+1, s.frames[:]) | ||||
| 	return s | ||||
| } | ||||
| 
 | ||||
| // location reports the file, line, and function of a frame.
 | ||||
| //
 | ||||
| // The returned function may be "" even if file and line are not.
 | ||||
| func (f Frame) location() (function, file string, line int) { | ||||
| 	frames := runtime.CallersFrames(f.frames[:]) | ||||
| 	if _, ok := frames.Next(); !ok { | ||||
| 		return "", "", 0 | ||||
| 	} | ||||
| 	fr, ok := frames.Next() | ||||
| 	if !ok { | ||||
| 		return "", "", 0 | ||||
| 	} | ||||
| 	return fr.Function, fr.File, fr.Line | ||||
| } | ||||
| 
 | ||||
| // Format prints the stack as error detail.
 | ||||
| // It should be called from an error's Format implementation
 | ||||
| // after printing any other error detail.
 | ||||
| func (f Frame) Format(p Printer) { | ||||
| 	if p.Detail() { | ||||
| 		function, file, line := f.location() | ||||
| 		if function != "" { | ||||
| 			p.Printf("%s\n    ", function) | ||||
| 		} | ||||
| 		if file != "" { | ||||
| 			p.Printf("%s:%d\n", file, line) | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | @ -0,0 +1,3 @@ | |||
| module golang.org/x/xerrors | ||||
| 
 | ||||
| go 1.11 | ||||
|  | @ -0,0 +1,8 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package internal | ||||
| 
 | ||||
| // EnableTrace indicates whether stack information should be recorded in errors.
 | ||||
| var EnableTrace = true | ||||
|  | @ -0,0 +1,106 @@ | |||
| // Copyright 2018 The Go Authors. All rights reserved.
 | ||||
| // Use of this source code is governed by a BSD-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package xerrors | ||||
| 
 | ||||
| import ( | ||||
| 	"reflect" | ||||
| ) | ||||
| 
 | ||||
| // A Wrapper provides context around another error.
 | ||||
| type Wrapper interface { | ||||
| 	// Unwrap returns the next error in the error chain.
 | ||||
| 	// If there is no next error, Unwrap returns nil.
 | ||||
| 	Unwrap() error | ||||
| } | ||||
| 
 | ||||
| // Opaque returns an error with the same error formatting as err
 | ||||
| // but that does not match err and cannot be unwrapped.
 | ||||
| func Opaque(err error) error { | ||||
| 	return noWrapper{err} | ||||
| } | ||||
| 
 | ||||
| type noWrapper struct { | ||||
| 	error | ||||
| } | ||||
| 
 | ||||
| func (e noWrapper) FormatError(p Printer) (next error) { | ||||
| 	if f, ok := e.error.(Formatter); ok { | ||||
| 		return f.FormatError(p) | ||||
| 	} | ||||
| 	p.Print(e.error) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Unwrap returns the result of calling the Unwrap method on err, if err implements
 | ||||
| // Unwrap. Otherwise, Unwrap returns nil.
 | ||||
| func Unwrap(err error) error { | ||||
| 	u, ok := err.(Wrapper) | ||||
| 	if !ok { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return u.Unwrap() | ||||
| } | ||||
| 
 | ||||
| // Is reports whether any error in err's chain matches target.
 | ||||
| //
 | ||||
| // An error is considered to match a target if it is equal to that target or if
 | ||||
| // it implements a method Is(error) bool such that Is(target) returns true.
 | ||||
| func Is(err, target error) bool { | ||||
| 	if target == nil { | ||||
| 		return err == target | ||||
| 	} | ||||
| 
 | ||||
| 	isComparable := reflect.TypeOf(target).Comparable() | ||||
| 	for { | ||||
| 		if isComparable && err == target { | ||||
| 			return true | ||||
| 		} | ||||
| 		if x, ok := err.(interface{ Is(error) bool }); ok && x.Is(target) { | ||||
| 			return true | ||||
| 		} | ||||
| 		// TODO: consider supporing target.Is(err). This would allow
 | ||||
| 		// user-definable predicates, but also may allow for coping with sloppy
 | ||||
| 		// APIs, thereby making it easier to get away with them.
 | ||||
| 		if err = Unwrap(err); err == nil { | ||||
| 			return false | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // As finds the first error in err's chain that matches the type to which target
 | ||||
| // points, and if so, sets the target to its value and returns true. An error
 | ||||
| // matches a type if it is assignable to the target type, or if it has a method
 | ||||
| // As(interface{}) bool such that As(target) returns true. As will panic if target
 | ||||
| // is not a non-nil pointer to a type which implements error or is of interface type.
 | ||||
| //
 | ||||
| // The As method should set the target to its value and return true if err
 | ||||
| // matches the type to which target points.
 | ||||
| func As(err error, target interface{}) bool { | ||||
| 	if target == nil { | ||||
| 		panic("errors: target cannot be nil") | ||||
| 	} | ||||
| 	val := reflect.ValueOf(target) | ||||
| 	typ := val.Type() | ||||
| 	if typ.Kind() != reflect.Ptr || val.IsNil() { | ||||
| 		panic("errors: target must be a non-nil pointer") | ||||
| 	} | ||||
| 	if e := typ.Elem(); e.Kind() != reflect.Interface && !e.Implements(errorType) { | ||||
| 		panic("errors: *target must be interface or implement error") | ||||
| 	} | ||||
| 	targetType := typ.Elem() | ||||
| 	for err != nil { | ||||
| 		if reflect.TypeOf(err).AssignableTo(targetType) { | ||||
| 			val.Elem().Set(reflect.ValueOf(err)) | ||||
| 			return true | ||||
| 		} | ||||
| 		if x, ok := err.(interface{ As(interface{}) bool }); ok && x.As(target) { | ||||
| 			return true | ||||
| 		} | ||||
| 		err = Unwrap(err) | ||||
| 	} | ||||
| 	return false | ||||
| } | ||||
| 
 | ||||
| var errorType = reflect.TypeOf((*error)(nil)).Elem() | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -161,7 +161,7 @@ message AzureFileVolumeSource { | |||
| // Deprecated in 1.7, please use the bindings subresource of pods instead. | ||||
| message Binding { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -426,7 +426,7 @@ message ComponentCondition { | |||
| // ComponentStatus (and ComponentStatusList) holds the cluster validation info. | ||||
| message ComponentStatus { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -440,7 +440,7 @@ message ComponentStatus { | |||
| // Status of all the conditions for the component as a list of ComponentStatus objects. | ||||
| message ComponentStatusList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -451,7 +451,7 @@ message ComponentStatusList { | |||
| // ConfigMap holds configuration data for pods to consume. | ||||
| message ConfigMap { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -503,7 +503,7 @@ message ConfigMapKeySelector { | |||
| 
 | ||||
| // ConfigMapList is a resource containing a list of ConfigMap objects. | ||||
| message ConfigMapList { | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -701,6 +701,17 @@ message Container { | |||
|   // +optional | ||||
|   optional Probe readinessProbe = 11; | ||||
| 
 | ||||
|   // StartupProbe indicates that the Pod has successfully initialized. | ||||
|   // If specified, no other probes are executed until this completes successfully. | ||||
|   // If this probe fails, the Pod will be restarted, just as if the livenessProbe failed. | ||||
|   // This can be used to provide different probe parameters at the beginning of a Pod's lifecycle, | ||||
|   // when it might take a long time to load data or warm a cache, than during steady-state operation. | ||||
|   // This cannot be updated. | ||||
|   // This is an alpha feature enabled by the StartupProbe feature flag. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes | ||||
|   // +optional | ||||
|   optional Probe startupProbe = 22; | ||||
| 
 | ||||
|   // Actions that the management system should take in response to container lifecycle events. | ||||
|   // Cannot be updated. | ||||
|   // +optional | ||||
|  | @ -901,6 +912,13 @@ message ContainerStatus { | |||
|   // Container's ID in the format 'docker://<container_id>'. | ||||
|   // +optional | ||||
|   optional string containerID = 8; | ||||
| 
 | ||||
|   // Specifies whether the container has passed its startup probe. | ||||
|   // Initialized as false, becomes true after startupProbe is considered successful. | ||||
|   // Resets to false when the container is restarted, or if kubelet loses state temporarily. | ||||
|   // Is always true when no startupProbe is defined. | ||||
|   // +optional | ||||
|   optional bool started = 9; | ||||
| } | ||||
| 
 | ||||
| // DaemonEndpoint contains information about a single Daemon endpoint. | ||||
|  | @ -1001,7 +1019,8 @@ message EndpointAddress { | |||
| 
 | ||||
| // EndpointPort is a tuple that describes a single port. | ||||
| message EndpointPort { | ||||
|   // The name of this port (corresponds to ServicePort.Name). | ||||
|   // The name of this port.  This must match the 'name' field in the | ||||
|   // corresponding ServicePort. | ||||
|   // Must be a DNS_LABEL. | ||||
|   // Optional only if one port is defined. | ||||
|   // +optional | ||||
|  | @ -1058,7 +1077,7 @@ message EndpointSubset { | |||
| //  ] | ||||
| message Endpoints { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -1076,7 +1095,7 @@ message Endpoints { | |||
| // EndpointsList is a list of endpoints. | ||||
| message EndpointsList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -1123,7 +1142,7 @@ message EnvVar { | |||
| // EnvVarSource represents a source for the value of an EnvVar. | ||||
| message EnvVarSource { | ||||
|   // Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, | ||||
|   // spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP. | ||||
|   // spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs. | ||||
|   // +optional | ||||
|   optional ObjectFieldSelector fieldRef = 1; | ||||
| 
 | ||||
|  | @ -1141,16 +1160,20 @@ message EnvVarSource { | |||
|   optional SecretKeySelector secretKeyRef = 4; | ||||
| } | ||||
| 
 | ||||
| // An EphemeralContainer is a special type of container which doesn't come with any resource | ||||
| // or scheduling guarantees but can be added to a pod that has already been created. They are | ||||
| // intended for user-initiated activities such as troubleshooting a running pod. | ||||
| // Ephemeral containers will not be restarted when they exit, and they will be killed if the | ||||
| // pod is removed or restarted. If an ephemeral container causes a pod to exceed its resource | ||||
| // An EphemeralContainer is a container that may be added temporarily to an existing pod for | ||||
| // user-initiated activities such as debugging. Ephemeral containers have no resource or | ||||
| // scheduling guarantees, and they will not be restarted when they exit or when a pod is | ||||
| // removed or restarted. If an ephemeral container causes a pod to exceed its resource | ||||
| // allocation, the pod may be evicted. | ||||
| // Ephemeral containers are added via a pod's ephemeralcontainers subresource and will appear | ||||
| // in the pod spec once added. No fields in EphemeralContainer may be changed once added. | ||||
| // Ephemeral containers may not be added by directly updating the pod spec. They must be added | ||||
| // via the pod's ephemeralcontainers subresource, and they will appear in the pod spec | ||||
| // once added. | ||||
| // This is an alpha feature enabled by the EphemeralContainers feature flag. | ||||
| message EphemeralContainer { | ||||
|   // Ephemeral containers have all of the fields of Container, plus additional fields | ||||
|   // specific to ephemeral containers. Fields in common with Container are in the | ||||
|   // following inlined struct so than an EphemeralContainer may easily be converted | ||||
|   // to a Container. | ||||
|   optional EphemeralContainerCommon ephemeralContainerCommon = 1; | ||||
| 
 | ||||
|   // If set, the name of the container from PodSpec that this ephemeral container targets. | ||||
|  | @ -1161,6 +1184,10 @@ message EphemeralContainer { | |||
|   optional string targetContainerName = 2; | ||||
| } | ||||
| 
 | ||||
| // EphemeralContainerCommon is a copy of all fields in Container to be inlined in | ||||
| // EphemeralContainer. This separate type allows easy conversion from EphemeralContainer | ||||
| // to Container and allows separate documentation for the fields of EphemeralContainer. | ||||
| // When a new field is added to Container it must be added here as well. | ||||
| message EphemeralContainerCommon { | ||||
|   // Name of the ephemeral container specified as a DNS_LABEL. | ||||
|   // This name must be unique among all containers, init containers and ephemeral containers. | ||||
|  | @ -1245,6 +1272,10 @@ message EphemeralContainerCommon { | |||
|   // +optional | ||||
|   optional Probe readinessProbe = 11; | ||||
| 
 | ||||
|   // Probes are not allowed for ephemeral containers. | ||||
|   // +optional | ||||
|   optional Probe startupProbe = 22; | ||||
| 
 | ||||
|   // Lifecycle is not allowed for ephemeral containers. | ||||
|   // +optional | ||||
|   optional Lifecycle lifecycle = 12; | ||||
|  | @ -1303,12 +1334,14 @@ message EphemeralContainerCommon { | |||
|   optional bool tty = 18; | ||||
| } | ||||
| 
 | ||||
| // A list of ephemeral containers used in API operations | ||||
| // A list of ephemeral containers used with the Pod ephemeralcontainers subresource. | ||||
| message EphemeralContainers { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // The new set of ephemeral containers to use for a pod. | ||||
|   // A list of ephemeral containers associated with this pod. New ephemeral containers | ||||
|   // may be appended to this list, but existing ephemeral containers may not be removed | ||||
|   // or modified. | ||||
|   // +patchMergeKey=name | ||||
|   // +patchStrategy=merge | ||||
|   repeated EphemeralContainer ephemeralContainers = 2; | ||||
|  | @ -1317,7 +1350,7 @@ message EphemeralContainers { | |||
| // Event is a report of an event somewhere in the cluster. | ||||
| message Event { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // The object that this event is about. | ||||
|  | @ -1382,7 +1415,7 @@ message Event { | |||
| // EventList is a list of events. | ||||
| message EventList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -1851,7 +1884,7 @@ message Lifecycle { | |||
|   optional Handler postStart = 1; | ||||
| 
 | ||||
|   // PreStop is called immediately before a container is terminated due to an | ||||
|   // API request or management event such as liveness probe failure, | ||||
|   // API request or management event such as liveness/startup probe failure, | ||||
|   // preemption, resource contention, etc. The handler is not called if the | ||||
|   // container crashes or exits. The reason for termination is passed to the | ||||
|   // handler. The Pod's termination grace period countdown begins before the | ||||
|  | @ -1867,12 +1900,12 @@ message Lifecycle { | |||
| // LimitRange sets resource usage limits for each kind of resource in a Namespace. | ||||
| message LimitRange { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the limits enforced. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional LimitRangeSpec spec = 2; | ||||
| } | ||||
|  | @ -1907,7 +1940,7 @@ message LimitRangeItem { | |||
| // LimitRangeList is a list of LimitRange items. | ||||
| message LimitRangeList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -1925,7 +1958,7 @@ message LimitRangeSpec { | |||
| // List holds a list of objects, which may not be known by the server. | ||||
| message List { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2002,25 +2035,43 @@ message NFSVolumeSource { | |||
| // Use of multiple namespaces is optional. | ||||
| message Namespace { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the behavior of the Namespace. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional NamespaceSpec spec = 2; | ||||
| 
 | ||||
|   // Status describes the current status of a Namespace. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional NamespaceStatus status = 3; | ||||
| } | ||||
| 
 | ||||
| // NamespaceCondition contains details about state of namespace. | ||||
| message NamespaceCondition { | ||||
|   // Type of namespace controller condition. | ||||
|   optional string type = 1; | ||||
| 
 | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
| 
 | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 4; | ||||
| 
 | ||||
|   // +optional | ||||
|   optional string reason = 5; | ||||
| 
 | ||||
|   // +optional | ||||
|   optional string message = 6; | ||||
| } | ||||
| 
 | ||||
| // NamespaceList is a list of Namespaces. | ||||
| message NamespaceList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2043,25 +2094,31 @@ message NamespaceStatus { | |||
|   // More info: https://kubernetes.io/docs/tasks/administer-cluster/namespaces/ | ||||
|   // +optional | ||||
|   optional string phase = 1; | ||||
| 
 | ||||
|   // Represents the latest available observations of a namespace's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated NamespaceCondition conditions = 2; | ||||
| } | ||||
| 
 | ||||
| // Node is a worker node in Kubernetes. | ||||
| // Each node will have a unique identifier in the cache (i.e. in etcd). | ||||
| message Node { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the behavior of a node. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional NodeSpec spec = 2; | ||||
| 
 | ||||
|   // Most recently observed status of the node. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional NodeStatus status = 3; | ||||
| } | ||||
|  | @ -2189,7 +2246,7 @@ message NodeDaemonEndpoints { | |||
| // NodeList is the whole list of all Nodes which have been registered with master. | ||||
| message NodeList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2401,7 +2458,7 @@ message ObjectFieldSelector { | |||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
| message ObjectReference { | ||||
|   // Kind of the referent. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional string kind = 1; | ||||
| 
 | ||||
|  | @ -2425,7 +2482,7 @@ message ObjectReference { | |||
|   optional string apiVersion = 5; | ||||
| 
 | ||||
|   // Specific resourceVersion to which this reference is made, if any. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency | ||||
|   // +optional | ||||
|   optional string resourceVersion = 6; | ||||
| 
 | ||||
|  | @ -2446,7 +2503,7 @@ message ObjectReference { | |||
| // More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes | ||||
| message PersistentVolume { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2467,7 +2524,7 @@ message PersistentVolume { | |||
| // PersistentVolumeClaim is a user's request for and claim to a persistent volume | ||||
| message PersistentVolumeClaim { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2511,7 +2568,7 @@ message PersistentVolumeClaimCondition { | |||
| // PersistentVolumeClaimList is a list of PersistentVolumeClaim items. | ||||
| message PersistentVolumeClaimList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2605,7 +2662,7 @@ message PersistentVolumeClaimVolumeSource { | |||
| // PersistentVolumeList is a list of PersistentVolume items. | ||||
| message PersistentVolumeList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -2806,12 +2863,12 @@ message PhotonPersistentDiskVolumeSource { | |||
| // by clients and scheduled onto hosts. | ||||
| message Pod { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Specification of the desired behavior of the pod. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional PodSpec spec = 2; | ||||
| 
 | ||||
|  | @ -2819,7 +2876,7 @@ message Pod { | |||
|   // This data may not be up to date. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional PodStatus status = 3; | ||||
| } | ||||
|  | @ -3036,12 +3093,12 @@ message PodIP { | |||
| // PodList is a list of Pods. | ||||
| message PodList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|   // List of pods. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md | ||||
|   repeated Pod items = 2; | ||||
| } | ||||
| 
 | ||||
|  | @ -3088,6 +3145,15 @@ message PodLogOptions { | |||
|   // slightly more or slightly less than the specified limit. | ||||
|   // +optional | ||||
|   optional int64 limitBytes = 8; | ||||
| 
 | ||||
|   // insecureSkipTLSVerifyBackend indicates that the apiserver should not confirm the validity of the | ||||
|   // serving certificate of the backend it is connecting to.  This will make the HTTPS connection between the apiserver | ||||
|   // and the backend insecure. This means the apiserver cannot verify the log data it is receiving came from the real | ||||
|   // kubelet.  If the kubelet is configured to verify the apiserver's TLS credentials, it does not mean the | ||||
|   // connection to the real kubelet is vulnerable to a man in the middle attack (e.g. an attacker could not intercept | ||||
|   // the actual log data coming from the real kubelet). | ||||
|   // +optional | ||||
|   optional bool insecureSkipTLSVerifyBackend = 9; | ||||
| } | ||||
| 
 | ||||
| // PodPortForwardOptions is the query options to a Pod's port forward call | ||||
|  | @ -3205,7 +3271,7 @@ message PodSpec { | |||
|   // init container fails, the pod is considered to have failed and is handled according | ||||
|   // to its restartPolicy. The name for an init container or normal container must be | ||||
|   // unique among all containers. | ||||
|   // Init containers may not have Lifecycle actions, Readiness probes, or Liveness probes. | ||||
|   // Init containers may not have Lifecycle actions, Readiness probes, Liveness probes, or Startup probes. | ||||
|   // The resourceRequirements of an init container are taken into account during scheduling | ||||
|   // by finding the highest request/limit for each resource type, and then using the max of | ||||
|   // of that value or the sum of the normal containers. Limits are applied to init containers | ||||
|  | @ -3225,12 +3291,10 @@ message PodSpec { | |||
|   // +patchStrategy=merge | ||||
|   repeated Container containers = 2; | ||||
| 
 | ||||
|   // EphemeralContainers is the list of ephemeral containers that run in this pod. Ephemeral containers | ||||
|   // are added to an existing pod as a result of a user-initiated action such as troubleshooting. | ||||
|   // This list is read-only in the pod spec. It may not be specified in a create or modified in an | ||||
|   // update of a pod or pod template. | ||||
|   // To add an ephemeral container use the pod's ephemeralcontainers subresource, which allows update | ||||
|   // using the EphemeralContainers kind. | ||||
|   // List of ephemeral containers run in this pod. Ephemeral containers may be run in an existing | ||||
|   // pod to perform user-initiated actions such as debugging. This list cannot be specified when | ||||
|   // creating a pod, and it cannot be modified by updating the pod spec. In order to add an | ||||
|   // ephemeral container to an existing pod, use the pod's ephemeralcontainers subresource. | ||||
|   // This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature. | ||||
|   // +optional | ||||
|   // +patchMergeKey=name | ||||
|  | @ -3320,7 +3384,6 @@ message PodSpec { | |||
|   // in the same pod, and the first process in each container will not be assigned PID 1. | ||||
|   // HostPID and ShareProcessNamespace cannot both be set. | ||||
|   // Optional: Default to false. | ||||
|   // This field is beta-level and may be disabled with the PodShareProcessNamespace feature. | ||||
|   // +k8s:conversion-gen=false | ||||
|   // +optional | ||||
|   optional bool shareProcessNamespace = 27; | ||||
|  | @ -3537,8 +3600,8 @@ message PodStatus { | |||
|   // +optional | ||||
|   optional string qosClass = 9; | ||||
| 
 | ||||
|   // Status for any ephemeral containers that running in this pod. | ||||
|   // This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature. | ||||
|   // Status for any ephemeral containers that have run in this pod. | ||||
|   // This field is alpha-level and is only populated by servers that enable the EphemeralContainers feature. | ||||
|   // +optional | ||||
|   repeated ContainerStatus ephemeralContainerStatuses = 13; | ||||
| } | ||||
|  | @ -3546,7 +3609,7 @@ message PodStatus { | |||
| // PodStatusResult is a wrapper for PodStatus returned by kubelet that can be encode/decoded | ||||
| message PodStatusResult { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -3554,7 +3617,7 @@ message PodStatusResult { | |||
|   // This data may not be up to date. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional PodStatus status = 2; | ||||
| } | ||||
|  | @ -3562,12 +3625,12 @@ message PodStatusResult { | |||
| // PodTemplate describes a template for creating copies of a predefined pod. | ||||
| message PodTemplate { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Template defines the pods that will be created from this pod template. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional PodTemplateSpec template = 2; | ||||
| } | ||||
|  | @ -3575,7 +3638,7 @@ message PodTemplate { | |||
| // PodTemplateList is a list of PodTemplates. | ||||
| message PodTemplateList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -3586,12 +3649,12 @@ message PodTemplateList { | |||
| // PodTemplateSpec describes the data a pod should have when created from a template | ||||
| message PodTemplateSpec { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Specification of the desired behavior of the pod. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional PodSpec spec = 2; | ||||
| } | ||||
|  | @ -3671,7 +3734,7 @@ message Probe { | |||
|   optional int32 periodSeconds = 4; | ||||
| 
 | ||||
|   // Minimum consecutive successes for the probe to be considered successful after having failed. | ||||
|   // Defaults to 1. Must be 1 for liveness. Minimum value is 1. | ||||
|   // Defaults to 1. Must be 1 for liveness and startup. Minimum value is 1. | ||||
|   // +optional | ||||
|   optional int32 successThreshold = 5; | ||||
| 
 | ||||
|  | @ -3832,7 +3895,7 @@ message RBDVolumeSource { | |||
| // RangeAllocation is not a public type. | ||||
| message RangeAllocation { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -3847,12 +3910,12 @@ message RangeAllocation { | |||
| message ReplicationController { | ||||
|   // If the Labels of a ReplicationController are empty, they are defaulted to | ||||
|   // be the same as the Pod(s) that the replication controller manages. | ||||
|   // Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the specification of the desired behavior of the replication controller. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ReplicationControllerSpec spec = 2; | ||||
| 
 | ||||
|  | @ -3860,7 +3923,7 @@ message ReplicationController { | |||
|   // This data may be out of date by some window of time. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ReplicationControllerStatus status = 3; | ||||
| } | ||||
|  | @ -3889,7 +3952,7 @@ message ReplicationControllerCondition { | |||
| // ReplicationControllerList is a collection of replication controllers. | ||||
| message ReplicationControllerList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -3975,17 +4038,17 @@ message ResourceFieldSelector { | |||
| // ResourceQuota sets aggregate quota restrictions enforced per namespace | ||||
| message ResourceQuota { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the desired quota. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ResourceQuotaSpec spec = 2; | ||||
| 
 | ||||
|   // Status defines the actual enforced quota and its current usage. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ResourceQuotaStatus status = 3; | ||||
| } | ||||
|  | @ -3993,7 +4056,7 @@ message ResourceQuota { | |||
| // ResourceQuotaList is a list of ResourceQuota items. | ||||
| message ResourceQuotaList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4189,7 +4252,7 @@ message ScopedResourceSelectorRequirement { | |||
| // the Data field must be less than MaxSecretSize bytes. | ||||
| message Secret { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4243,7 +4306,7 @@ message SecretKeySelector { | |||
| // SecretList is a list of Secret. | ||||
| message SecretList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4407,19 +4470,19 @@ message SerializedReference { | |||
| // will answer requests sent through the proxy. | ||||
| message Service { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|   // Spec defines the behavior of a service. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ServiceSpec spec = 2; | ||||
| 
 | ||||
|   // Most recently observed status of the service. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ServiceStatus status = 3; | ||||
| } | ||||
|  | @ -4430,7 +4493,7 @@ message Service { | |||
| // * a set of secrets | ||||
| message ServiceAccount { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4457,7 +4520,7 @@ message ServiceAccount { | |||
| // ServiceAccountList is a list of ServiceAccount objects | ||||
| message ServiceAccountList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4495,7 +4558,7 @@ message ServiceAccountTokenProjection { | |||
| // ServiceList holds a list of services. | ||||
| message ServiceList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -4506,8 +4569,9 @@ message ServiceList { | |||
| // ServicePort contains information on service's port. | ||||
| message ServicePort { | ||||
|   // The name of this port within the service. This must be a DNS_LABEL. | ||||
|   // All ports within a ServiceSpec must have unique names. This maps to | ||||
|   // the 'Name' field in EndpointPort objects. | ||||
|   // All ports within a ServiceSpec must have unique names. When considering | ||||
|   // the endpoints for a Service, this must match the 'name' field in the | ||||
|   // EndpointPort. | ||||
|   // Optional if only one ServicePort is defined on this service. | ||||
|   // +optional | ||||
|   optional string name = 1; | ||||
|  | @ -4667,6 +4731,31 @@ message ServiceSpec { | |||
|   // sessionAffinityConfig contains the configurations of session affinity. | ||||
|   // +optional | ||||
|   optional SessionAffinityConfig sessionAffinityConfig = 14; | ||||
| 
 | ||||
|   // ipFamily specifies whether this Service has a preference for a particular IP family (e.g. IPv4 vs. | ||||
|   // IPv6).  If a specific IP family is requested, the clusterIP field will be allocated from that family, if it is | ||||
|   // available in the cluster.  If no IP family is requested, the cluster's primary IP family will be used. | ||||
|   // Other IP fields (loadBalancerIP, loadBalancerSourceRanges, externalIPs) and controllers which | ||||
|   // allocate external load-balancers should use the same IP family.  Endpoints for this Service will be of | ||||
|   // this family.  This field is immutable after creation. Assigning a ServiceIPFamily not available in the | ||||
|   // cluster (e.g. IPv6 in IPv4 only cluster) is an error condition and will fail during clusterIP assignment. | ||||
|   // +optional | ||||
|   optional string ipFamily = 15; | ||||
| 
 | ||||
|   // topologyKeys is a preference-order list of topology keys which | ||||
|   // implementations of services should use to preferentially sort endpoints | ||||
|   // when accessing this Service, it can not be used at the same time as | ||||
|   // externalTrafficPolicy=Local. | ||||
|   // Topology keys must be valid label keys and at most 16 keys may be specified. | ||||
|   // Endpoints are chosen based on the first topology key with available backends. | ||||
|   // If this field is specified and all entries have no backends that match | ||||
|   // the topology of the client, the service has no backends for that client | ||||
|   // and connections should fail. | ||||
|   // The special value "*" may be used to mean "any topology". This catch-all | ||||
|   // value, if used, only makes sense as the last value in the list. | ||||
|   // If this is not specified or empty, no topology constraints will be applied. | ||||
|   // +optional | ||||
|   repeated string topologyKeys = 16; | ||||
| } | ||||
| 
 | ||||
| // ServiceStatus represents the current status of a service. | ||||
|  | @ -4966,7 +5055,6 @@ message VolumeMount { | |||
|   // Behaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment. | ||||
|   // Defaults to "" (volume's root). | ||||
|   // SubPathExpr and SubPath are mutually exclusive. | ||||
|   // This field is beta in 1.15. | ||||
|   // +optional | ||||
|   optional string subPathExpr = 6; | ||||
| } | ||||
|  | @ -5183,7 +5271,7 @@ message WindowsSecurityContextOptions { | |||
|   // Defaults to the user specified in image metadata if unspecified. | ||||
|   // May also be set in PodSecurityContext. If set in both SecurityContext and | ||||
|   // PodSecurityContext, the value specified in SecurityContext takes precedence. | ||||
|   // This field is alpha-level and it is only honored by servers that enable the WindowsRunAsUserName feature flag. | ||||
|   // This field is beta-level and may be disabled with the WindowsRunAsUserName feature flag. | ||||
|   // +optional | ||||
|   optional string runAsUserName = 3; | ||||
| } | ||||
|  |  | |||
|  | @ -30,6 +30,8 @@ const ( | |||
| 	NamespaceAll string = "" | ||||
| 	// NamespaceNodeLease is the namespace where we place node lease objects (used for node heartbeats)
 | ||||
| 	NamespaceNodeLease string = "kube-node-lease" | ||||
| 	// TopologyKeyAny is the service topology key that matches any node
 | ||||
| 	TopologyKeyAny string = "*" | ||||
| ) | ||||
| 
 | ||||
| // Volume represents a named volume in a pod that may be accessed by any container in the pod.
 | ||||
|  | @ -275,7 +277,7 @@ const ( | |||
| type PersistentVolume struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -390,7 +392,7 @@ type PersistentVolumeStatus struct { | |||
| type PersistentVolumeList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// List of persistent volumes.
 | ||||
|  | @ -405,7 +407,7 @@ type PersistentVolumeList struct { | |||
| type PersistentVolumeClaim struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -427,7 +429,7 @@ type PersistentVolumeClaim struct { | |||
| type PersistentVolumeClaimList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// A list of persistent volume claims.
 | ||||
|  | @ -1784,7 +1786,6 @@ type VolumeMount struct { | |||
| 	// Behaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment.
 | ||||
| 	// Defaults to "" (volume's root).
 | ||||
| 	// SubPathExpr and SubPath are mutually exclusive.
 | ||||
| 	// This field is beta in 1.15.
 | ||||
| 	// +optional
 | ||||
| 	SubPathExpr string `json:"subPathExpr,omitempty" protobuf:"bytes,6,opt,name=subPathExpr"` | ||||
| } | ||||
|  | @ -1847,7 +1848,7 @@ type EnvVar struct { | |||
| // EnvVarSource represents a source for the value of an EnvVar.
 | ||||
| type EnvVarSource struct { | ||||
| 	// Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations,
 | ||||
| 	// spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP.
 | ||||
| 	// spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs.
 | ||||
| 	// +optional
 | ||||
| 	FieldRef *ObjectFieldSelector `json:"fieldRef,omitempty" protobuf:"bytes,1,opt,name=fieldRef"` | ||||
| 	// Selects a resource of the container: only resources limits and requests
 | ||||
|  | @ -2025,7 +2026,7 @@ type Probe struct { | |||
| 	// +optional
 | ||||
| 	PeriodSeconds int32 `json:"periodSeconds,omitempty" protobuf:"varint,4,opt,name=periodSeconds"` | ||||
| 	// Minimum consecutive successes for the probe to be considered successful after having failed.
 | ||||
| 	// Defaults to 1. Must be 1 for liveness. Minimum value is 1.
 | ||||
| 	// Defaults to 1. Must be 1 for liveness and startup. Minimum value is 1.
 | ||||
| 	// +optional
 | ||||
| 	SuccessThreshold int32 `json:"successThreshold,omitempty" protobuf:"varint,5,opt,name=successThreshold"` | ||||
| 	// Minimum consecutive failures for the probe to be considered failed after having succeeded.
 | ||||
|  | @ -2196,6 +2197,16 @@ type Container struct { | |||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
 | ||||
| 	// +optional
 | ||||
| 	ReadinessProbe *Probe `json:"readinessProbe,omitempty" protobuf:"bytes,11,opt,name=readinessProbe"` | ||||
| 	// StartupProbe indicates that the Pod has successfully initialized.
 | ||||
| 	// If specified, no other probes are executed until this completes successfully.
 | ||||
| 	// If this probe fails, the Pod will be restarted, just as if the livenessProbe failed.
 | ||||
| 	// This can be used to provide different probe parameters at the beginning of a Pod's lifecycle,
 | ||||
| 	// when it might take a long time to load data or warm a cache, than during steady-state operation.
 | ||||
| 	// This cannot be updated.
 | ||||
| 	// This is an alpha feature enabled by the StartupProbe feature flag.
 | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
 | ||||
| 	// +optional
 | ||||
| 	StartupProbe *Probe `json:"startupProbe,omitempty" protobuf:"bytes,22,opt,name=startupProbe"` | ||||
| 	// Actions that the management system should take in response to container lifecycle events.
 | ||||
| 	// Cannot be updated.
 | ||||
| 	// +optional
 | ||||
|  | @ -2282,7 +2293,7 @@ type Lifecycle struct { | |||
| 	// +optional
 | ||||
| 	PostStart *Handler `json:"postStart,omitempty" protobuf:"bytes,1,opt,name=postStart"` | ||||
| 	// PreStop is called immediately before a container is terminated due to an
 | ||||
| 	// API request or management event such as liveness probe failure,
 | ||||
| 	// API request or management event such as liveness/startup probe failure,
 | ||||
| 	// preemption, resource contention, etc. The handler is not called if the
 | ||||
| 	// container crashes or exits. The reason for termination is passed to the
 | ||||
| 	// handler. The Pod's termination grace period countdown begins before the
 | ||||
|  | @ -2390,6 +2401,12 @@ type ContainerStatus struct { | |||
| 	// Container's ID in the format 'docker://<container_id>'.
 | ||||
| 	// +optional
 | ||||
| 	ContainerID string `json:"containerID,omitempty" protobuf:"bytes,8,opt,name=containerID"` | ||||
| 	// Specifies whether the container has passed its startup probe.
 | ||||
| 	// Initialized as false, becomes true after startupProbe is considered successful.
 | ||||
| 	// Resets to false when the container is restarted, or if kubelet loses state temporarily.
 | ||||
| 	// Is always true when no startupProbe is defined.
 | ||||
| 	// +optional
 | ||||
| 	Started *bool `json:"started,omitempty" protobuf:"varint,9,opt,name=started"` | ||||
| } | ||||
| 
 | ||||
| // PodPhase is a label for the condition of a pod at the current time.
 | ||||
|  | @ -2825,7 +2842,7 @@ type PodSpec struct { | |||
| 	// init container fails, the pod is considered to have failed and is handled according
 | ||||
| 	// to its restartPolicy. The name for an init container or normal container must be
 | ||||
| 	// unique among all containers.
 | ||||
| 	// Init containers may not have Lifecycle actions, Readiness probes, or Liveness probes.
 | ||||
| 	// Init containers may not have Lifecycle actions, Readiness probes, Liveness probes, or Startup probes.
 | ||||
| 	// The resourceRequirements of an init container are taken into account during scheduling
 | ||||
| 	// by finding the highest request/limit for each resource type, and then using the max of
 | ||||
| 	// of that value or the sum of the normal containers. Limits are applied to init containers
 | ||||
|  | @ -2843,12 +2860,10 @@ type PodSpec struct { | |||
| 	// +patchMergeKey=name
 | ||||
| 	// +patchStrategy=merge
 | ||||
| 	Containers []Container `json:"containers" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=containers"` | ||||
| 	// EphemeralContainers is the list of ephemeral containers that run in this pod. Ephemeral containers
 | ||||
| 	// are added to an existing pod as a result of a user-initiated action such as troubleshooting.
 | ||||
| 	// This list is read-only in the pod spec. It may not be specified in a create or modified in an
 | ||||
| 	// update of a pod or pod template.
 | ||||
| 	// To add an ephemeral container use the pod's ephemeralcontainers subresource, which allows update
 | ||||
| 	// using the EphemeralContainers kind.
 | ||||
| 	// List of ephemeral containers run in this pod. Ephemeral containers may be run in an existing
 | ||||
| 	// pod to perform user-initiated actions such as debugging. This list cannot be specified when
 | ||||
| 	// creating a pod, and it cannot be modified by updating the pod spec. In order to add an
 | ||||
| 	// ephemeral container to an existing pod, use the pod's ephemeralcontainers subresource.
 | ||||
| 	// This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.
 | ||||
| 	// +optional
 | ||||
| 	// +patchMergeKey=name
 | ||||
|  | @ -2927,7 +2942,6 @@ type PodSpec struct { | |||
| 	// in the same pod, and the first process in each container will not be assigned PID 1.
 | ||||
| 	// HostPID and ShareProcessNamespace cannot both be set.
 | ||||
| 	// Optional: Default to false.
 | ||||
| 	// This field is beta-level and may be disabled with the PodShareProcessNamespace feature.
 | ||||
| 	// +k8s:conversion-gen=false
 | ||||
| 	// +optional
 | ||||
| 	ShareProcessNamespace *bool `json:"shareProcessNamespace,omitempty" protobuf:"varint,27,opt,name=shareProcessNamespace"` | ||||
|  | @ -3220,6 +3234,10 @@ type PodIP struct { | |||
| 	IP string `json:"ip,omitempty" protobuf:"bytes,1,opt,name=ip"` | ||||
| } | ||||
| 
 | ||||
| // EphemeralContainerCommon is a copy of all fields in Container to be inlined in
 | ||||
| // EphemeralContainer. This separate type allows easy conversion from EphemeralContainer
 | ||||
| // to Container and allows separate documentation for the fields of EphemeralContainer.
 | ||||
| // When a new field is added to Container it must be added here as well.
 | ||||
| type EphemeralContainerCommon struct { | ||||
| 	// Name of the ephemeral container specified as a DNS_LABEL.
 | ||||
| 	// This name must be unique among all containers, init containers and ephemeral containers.
 | ||||
|  | @ -3291,6 +3309,9 @@ type EphemeralContainerCommon struct { | |||
| 	// Probes are not allowed for ephemeral containers.
 | ||||
| 	// +optional
 | ||||
| 	ReadinessProbe *Probe `json:"readinessProbe,omitempty" protobuf:"bytes,11,opt,name=readinessProbe"` | ||||
| 	// Probes are not allowed for ephemeral containers.
 | ||||
| 	// +optional
 | ||||
| 	StartupProbe *Probe `json:"startupProbe,omitempty" protobuf:"bytes,22,opt,name=startupProbe"` | ||||
| 	// Lifecycle is not allowed for ephemeral containers.
 | ||||
| 	// +optional
 | ||||
| 	Lifecycle *Lifecycle `json:"lifecycle,omitempty" protobuf:"bytes,12,opt,name=lifecycle"` | ||||
|  | @ -3350,16 +3371,20 @@ type EphemeralContainerCommon struct { | |||
| // these two types.
 | ||||
| var _ = Container(EphemeralContainerCommon{}) | ||||
| 
 | ||||
| // An EphemeralContainer is a special type of container which doesn't come with any resource
 | ||||
| // or scheduling guarantees but can be added to a pod that has already been created. They are
 | ||||
| // intended for user-initiated activities such as troubleshooting a running pod.
 | ||||
| // Ephemeral containers will not be restarted when they exit, and they will be killed if the
 | ||||
| // pod is removed or restarted. If an ephemeral container causes a pod to exceed its resource
 | ||||
| // An EphemeralContainer is a container that may be added temporarily to an existing pod for
 | ||||
| // user-initiated activities such as debugging. Ephemeral containers have no resource or
 | ||||
| // scheduling guarantees, and they will not be restarted when they exit or when a pod is
 | ||||
| // removed or restarted. If an ephemeral container causes a pod to exceed its resource
 | ||||
| // allocation, the pod may be evicted.
 | ||||
| // Ephemeral containers are added via a pod's ephemeralcontainers subresource and will appear
 | ||||
| // in the pod spec once added. No fields in EphemeralContainer may be changed once added.
 | ||||
| // Ephemeral containers may not be added by directly updating the pod spec. They must be added
 | ||||
| // via the pod's ephemeralcontainers subresource, and they will appear in the pod spec
 | ||||
| // once added.
 | ||||
| // This is an alpha feature enabled by the EphemeralContainers feature flag.
 | ||||
| type EphemeralContainer struct { | ||||
| 	// Ephemeral containers have all of the fields of Container, plus additional fields
 | ||||
| 	// specific to ephemeral containers. Fields in common with Container are in the
 | ||||
| 	// following inlined struct so than an EphemeralContainer may easily be converted
 | ||||
| 	// to a Container.
 | ||||
| 	EphemeralContainerCommon `json:",inline" protobuf:"bytes,1,req"` | ||||
| 
 | ||||
| 	// If set, the name of the container from PodSpec that this ephemeral container targets.
 | ||||
|  | @ -3454,8 +3479,8 @@ type PodStatus struct { | |||
| 	// More info: https://git.k8s.io/community/contributors/design-proposals/node/resource-qos.md
 | ||||
| 	// +optional
 | ||||
| 	QOSClass PodQOSClass `json:"qosClass,omitempty" protobuf:"bytes,9,rep,name=qosClass"` | ||||
| 	// Status for any ephemeral containers that running in this pod.
 | ||||
| 	// This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.
 | ||||
| 	// Status for any ephemeral containers that have run in this pod.
 | ||||
| 	// This field is alpha-level and is only populated by servers that enable the EphemeralContainers feature.
 | ||||
| 	// +optional
 | ||||
| 	EphemeralContainerStatuses []ContainerStatus `json:"ephemeralContainerStatuses,omitempty" protobuf:"bytes,13,rep,name=ephemeralContainerStatuses"` | ||||
| } | ||||
|  | @ -3466,14 +3491,14 @@ type PodStatus struct { | |||
| type PodStatusResult struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// Most recently observed status of the pod.
 | ||||
| 	// This data may not be up to date.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status PodStatus `json:"status,omitempty" protobuf:"bytes,2,opt,name=status"` | ||||
| } | ||||
|  | @ -3488,12 +3513,12 @@ type PodStatusResult struct { | |||
| type Pod struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Specification of the desired behavior of the pod.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec PodSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
|  | @ -3501,7 +3526,7 @@ type Pod struct { | |||
| 	// This data may not be up to date.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status PodStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -3512,24 +3537,24 @@ type Pod struct { | |||
| type PodList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// List of pods.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md
 | ||||
| 	Items []Pod `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
| 
 | ||||
| // PodTemplateSpec describes the data a pod should have when created from a template
 | ||||
| type PodTemplateSpec struct { | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Specification of the desired behavior of the pod.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec PodSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| } | ||||
|  | @ -3541,12 +3566,12 @@ type PodTemplateSpec struct { | |||
| type PodTemplate struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Template defines the pods that will be created from this pod template.
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Template PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,2,opt,name=template"` | ||||
| } | ||||
|  | @ -3557,7 +3582,7 @@ type PodTemplate struct { | |||
| type PodTemplateList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -3669,12 +3694,12 @@ type ReplicationController struct { | |||
| 
 | ||||
| 	// If the Labels of a ReplicationController are empty, they are defaulted to
 | ||||
| 	// be the same as the Pod(s) that the replication controller manages.
 | ||||
| 	// Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the specification of the desired behavior of the replication controller.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec ReplicationControllerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
|  | @ -3682,7 +3707,7 @@ type ReplicationController struct { | |||
| 	// This data may be out of date by some window of time.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status ReplicationControllerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -3693,7 +3718,7 @@ type ReplicationController struct { | |||
| type ReplicationControllerList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -3794,6 +3819,19 @@ type LoadBalancerIngress struct { | |||
| 	Hostname string `json:"hostname,omitempty" protobuf:"bytes,2,opt,name=hostname"` | ||||
| } | ||||
| 
 | ||||
| // IPFamily represents the IP Family (IPv4 or IPv6). This type is used
 | ||||
| // to express the family of an IP expressed by a type (i.e. service.Spec.IPFamily)
 | ||||
| type IPFamily string | ||||
| 
 | ||||
| const ( | ||||
| 	// IPv4Protocol indicates that this IP is IPv4 protocol
 | ||||
| 	IPv4Protocol IPFamily = "IPv4" | ||||
| 	// IPv6Protocol indicates that this IP is IPv6 protocol
 | ||||
| 	IPv6Protocol IPFamily = "IPv6" | ||||
| 	// MaxServiceTopologyKeys is the largest number of topology keys allowed on a service
 | ||||
| 	MaxServiceTopologyKeys = 16 | ||||
| ) | ||||
| 
 | ||||
| // ServiceSpec describes the attributes that a user creates on a service.
 | ||||
| type ServiceSpec struct { | ||||
| 	// The list of ports that are exposed by this service.
 | ||||
|  | @ -3906,16 +3944,43 @@ type ServiceSpec struct { | |||
| 	// of peer discovery.
 | ||||
| 	// +optional
 | ||||
| 	PublishNotReadyAddresses bool `json:"publishNotReadyAddresses,omitempty" protobuf:"varint,13,opt,name=publishNotReadyAddresses"` | ||||
| 
 | ||||
| 	// sessionAffinityConfig contains the configurations of session affinity.
 | ||||
| 	// +optional
 | ||||
| 	SessionAffinityConfig *SessionAffinityConfig `json:"sessionAffinityConfig,omitempty" protobuf:"bytes,14,opt,name=sessionAffinityConfig"` | ||||
| 
 | ||||
| 	// ipFamily specifies whether this Service has a preference for a particular IP family (e.g. IPv4 vs.
 | ||||
| 	// IPv6).  If a specific IP family is requested, the clusterIP field will be allocated from that family, if it is
 | ||||
| 	// available in the cluster.  If no IP family is requested, the cluster's primary IP family will be used.
 | ||||
| 	// Other IP fields (loadBalancerIP, loadBalancerSourceRanges, externalIPs) and controllers which
 | ||||
| 	// allocate external load-balancers should use the same IP family.  Endpoints for this Service will be of
 | ||||
| 	// this family.  This field is immutable after creation. Assigning a ServiceIPFamily not available in the
 | ||||
| 	// cluster (e.g. IPv6 in IPv4 only cluster) is an error condition and will fail during clusterIP assignment.
 | ||||
| 	// +optional
 | ||||
| 	IPFamily *IPFamily `json:"ipFamily,omitempty" protobuf:"bytes,15,opt,name=ipFamily,Configcasttype=IPFamily"` | ||||
| 
 | ||||
| 	// topologyKeys is a preference-order list of topology keys which
 | ||||
| 	// implementations of services should use to preferentially sort endpoints
 | ||||
| 	// when accessing this Service, it can not be used at the same time as
 | ||||
| 	// externalTrafficPolicy=Local.
 | ||||
| 	// Topology keys must be valid label keys and at most 16 keys may be specified.
 | ||||
| 	// Endpoints are chosen based on the first topology key with available backends.
 | ||||
| 	// If this field is specified and all entries have no backends that match
 | ||||
| 	// the topology of the client, the service has no backends for that client
 | ||||
| 	// and connections should fail.
 | ||||
| 	// The special value "*" may be used to mean "any topology". This catch-all
 | ||||
| 	// value, if used, only makes sense as the last value in the list.
 | ||||
| 	// If this is not specified or empty, no topology constraints will be applied.
 | ||||
| 	// +optional
 | ||||
| 	TopologyKeys []string `json:"topologyKeys,omitempty" protobuf:"bytes,16,opt,name=topologyKeys"` | ||||
| } | ||||
| 
 | ||||
| // ServicePort contains information on service's port.
 | ||||
| type ServicePort struct { | ||||
| 	// The name of this port within the service. This must be a DNS_LABEL.
 | ||||
| 	// All ports within a ServiceSpec must have unique names. This maps to
 | ||||
| 	// the 'Name' field in EndpointPort objects.
 | ||||
| 	// All ports within a ServiceSpec must have unique names. When considering
 | ||||
| 	// the endpoints for a Service, this must match the 'name' field in the
 | ||||
| 	// EndpointPort.
 | ||||
| 	// Optional if only one ServicePort is defined on this service.
 | ||||
| 	// +optional
 | ||||
| 	Name string `json:"name,omitempty" protobuf:"bytes,1,opt,name=name"` | ||||
|  | @ -3958,19 +4023,19 @@ type ServicePort struct { | |||
| type Service struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the behavior of a service.
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec ServiceSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
| 	// Most recently observed status of the service.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status ServiceStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -3987,7 +4052,7 @@ const ( | |||
| type ServiceList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4005,7 +4070,7 @@ type ServiceList struct { | |||
| type ServiceAccount struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4035,7 +4100,7 @@ type ServiceAccount struct { | |||
| type ServiceAccountList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4062,7 +4127,7 @@ type ServiceAccountList struct { | |||
| type Endpoints struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4124,7 +4189,8 @@ type EndpointAddress struct { | |||
| 
 | ||||
| // EndpointPort is a tuple that describes a single port.
 | ||||
| type EndpointPort struct { | ||||
| 	// The name of this port (corresponds to ServicePort.Name).
 | ||||
| 	// The name of this port.  This must match the 'name' field in the
 | ||||
| 	// corresponding ServicePort.
 | ||||
| 	// Must be a DNS_LABEL.
 | ||||
| 	// Optional only if one port is defined.
 | ||||
| 	// +optional
 | ||||
|  | @ -4146,7 +4212,7 @@ type EndpointPort struct { | |||
| type EndpointsList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4185,7 +4251,7 @@ type NodeSpec struct { | |||
| 	// Deprecated. Not all kubelets will set this field. Remove field after 1.13.
 | ||||
| 	// see: https://issues.k8s.io/61966
 | ||||
| 	// +optional
 | ||||
| 	DoNotUse_ExternalID string `json:"externalID,omitempty" protobuf:"bytes,2,opt,name=externalID"` | ||||
| 	DoNotUseExternalID string `json:"externalID,omitempty" protobuf:"bytes,2,opt,name=externalID"` | ||||
| } | ||||
| 
 | ||||
| // NodeConfigSource specifies a source of node configuration. Exactly one subfield (excluding metadata) must be non-nil.
 | ||||
|  | @ -4540,19 +4606,19 @@ type ResourceList map[ResourceName]resource.Quantity | |||
| type Node struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the behavior of a node.
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec NodeSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
| 	// Most recently observed status of the node.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status NodeStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -4563,7 +4629,7 @@ type Node struct { | |||
| type NodeList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4594,6 +4660,12 @@ type NamespaceStatus struct { | |||
| 	// More info: https://kubernetes.io/docs/tasks/administer-cluster/namespaces/
 | ||||
| 	// +optional
 | ||||
| 	Phase NamespacePhase `json:"phase,omitempty" protobuf:"bytes,1,opt,name=phase,casttype=NamespacePhase"` | ||||
| 
 | ||||
| 	// Represents the latest available observations of a namespace's current state.
 | ||||
| 	// +optional
 | ||||
| 	// +patchMergeKey=type
 | ||||
| 	// +patchStrategy=merge
 | ||||
| 	Conditions []NamespaceCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,2,rep,name=conditions"` | ||||
| } | ||||
| 
 | ||||
| type NamespacePhase string | ||||
|  | @ -4606,6 +4678,42 @@ const ( | |||
| 	NamespaceTerminating NamespacePhase = "Terminating" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	// NamespaceTerminatingCause is returned as a defaults.cause item when a change is
 | ||||
| 	// forbidden due to the namespace being terminated.
 | ||||
| 	NamespaceTerminatingCause metav1.CauseType = "NamespaceTerminating" | ||||
| ) | ||||
| 
 | ||||
| type NamespaceConditionType string | ||||
| 
 | ||||
| // These are valid conditions of a namespace.
 | ||||
| const ( | ||||
| 	// NamespaceDeletionDiscoveryFailure contains information about namespace deleter errors during resource discovery.
 | ||||
| 	NamespaceDeletionDiscoveryFailure NamespaceConditionType = "NamespaceDeletionDiscoveryFailure" | ||||
| 	// NamespaceDeletionContentFailure contains information about namespace deleter errors during deletion of resources.
 | ||||
| 	NamespaceDeletionContentFailure NamespaceConditionType = "NamespaceDeletionContentFailure" | ||||
| 	// NamespaceDeletionGVParsingFailure contains information about namespace deleter errors parsing GV for legacy types.
 | ||||
| 	NamespaceDeletionGVParsingFailure NamespaceConditionType = "NamespaceDeletionGroupVersionParsingFailure" | ||||
| 	// NamespaceContentRemaining contains information about resources remaining in a namespace.
 | ||||
| 	NamespaceContentRemaining NamespaceConditionType = "NamespaceContentRemaining" | ||||
| 	// NamespaceFinalizersRemaining contains information about which finalizers are on resources remaining in a namespace.
 | ||||
| 	NamespaceFinalizersRemaining NamespaceConditionType = "NamespaceFinalizersRemaining" | ||||
| ) | ||||
| 
 | ||||
| // NamespaceCondition contains details about state of namespace.
 | ||||
| type NamespaceCondition struct { | ||||
| 	// Type of namespace controller condition.
 | ||||
| 	Type NamespaceConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=NamespaceConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown.
 | ||||
| 	Status ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=ConditionStatus"` | ||||
| 	// +optional
 | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` | ||||
| 	// +optional
 | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` | ||||
| 	// +optional
 | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` | ||||
| } | ||||
| 
 | ||||
| // +genclient
 | ||||
| // +genclient:nonNamespaced
 | ||||
| // +genclient:skipVerbs=deleteCollection
 | ||||
|  | @ -4616,17 +4724,17 @@ const ( | |||
| type Namespace struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the behavior of the Namespace.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec NamespaceSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
| 	// Status describes the current status of a Namespace.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status NamespaceStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -4637,7 +4745,7 @@ type Namespace struct { | |||
| type NamespaceList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4653,7 +4761,7 @@ type NamespaceList struct { | |||
| type Binding struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -4663,13 +4771,15 @@ type Binding struct { | |||
| 
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // A list of ephemeral containers used in API operations
 | ||||
| // A list of ephemeral containers used with the Pod ephemeralcontainers subresource.
 | ||||
| type EphemeralContainers struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// The new set of ephemeral containers to use for a pod.
 | ||||
| 	// A list of ephemeral containers associated with this pod. New ephemeral containers
 | ||||
| 	// may be appended to this list, but existing ephemeral containers may not be removed
 | ||||
| 	// or modified.
 | ||||
| 	// +patchMergeKey=name
 | ||||
| 	// +patchStrategy=merge
 | ||||
| 	EphemeralContainers []EphemeralContainer `json:"ephemeralContainers" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=ephemeralContainers"` | ||||
|  | @ -4683,6 +4793,7 @@ type Preconditions struct { | |||
| 	UID *types.UID `json:"uid,omitempty" protobuf:"bytes,1,opt,name=uid,casttype=k8s.io/apimachinery/pkg/types.UID"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PodLogOptions is the query options for a Pod's logs REST call.
 | ||||
|  | @ -4723,8 +4834,18 @@ type PodLogOptions struct { | |||
| 	// slightly more or slightly less than the specified limit.
 | ||||
| 	// +optional
 | ||||
| 	LimitBytes *int64 `json:"limitBytes,omitempty" protobuf:"varint,8,opt,name=limitBytes"` | ||||
| 
 | ||||
| 	// insecureSkipTLSVerifyBackend indicates that the apiserver should not confirm the validity of the
 | ||||
| 	// serving certificate of the backend it is connecting to.  This will make the HTTPS connection between the apiserver
 | ||||
| 	// and the backend insecure. This means the apiserver cannot verify the log data it is receiving came from the real
 | ||||
| 	// kubelet.  If the kubelet is configured to verify the apiserver's TLS credentials, it does not mean the
 | ||||
| 	// connection to the real kubelet is vulnerable to a man in the middle attack (e.g. an attacker could not intercept
 | ||||
| 	// the actual log data coming from the real kubelet).
 | ||||
| 	// +optional
 | ||||
| 	InsecureSkipTLSVerifyBackend bool `json:"insecureSkipTLSVerifyBackend,omitempty" protobuf:"varint,9,opt,name=insecureSkipTLSVerifyBackend"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PodAttachOptions is the query options to a Pod's remote attach call.
 | ||||
|  | @ -4762,6 +4883,7 @@ type PodAttachOptions struct { | |||
| 	Container string `json:"container,omitempty" protobuf:"bytes,5,opt,name=container"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PodExecOptions is the query options to a Pod's remote exec call.
 | ||||
|  | @ -4800,6 +4922,7 @@ type PodExecOptions struct { | |||
| 	Command []string `json:"command" protobuf:"bytes,6,rep,name=command"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PodPortForwardOptions is the query options to a Pod's port forward call
 | ||||
|  | @ -4817,6 +4940,7 @@ type PodPortForwardOptions struct { | |||
| 	Ports []int32 `json:"ports,omitempty" protobuf:"varint,1,rep,name=ports"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PodProxyOptions is the query options to a Pod's proxy call.
 | ||||
|  | @ -4828,6 +4952,7 @@ type PodProxyOptions struct { | |||
| 	Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // NodeProxyOptions is the query options to a Node's proxy call.
 | ||||
|  | @ -4839,6 +4964,7 @@ type NodeProxyOptions struct { | |||
| 	Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // ServiceProxyOptions is the query options to a Service's proxy call.
 | ||||
|  | @ -4858,7 +4984,7 @@ type ServiceProxyOptions struct { | |||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| type ObjectReference struct { | ||||
| 	// Kind of the referent.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` | ||||
| 	// Namespace of the referent.
 | ||||
|  | @ -4877,7 +5003,7 @@ type ObjectReference struct { | |||
| 	// +optional
 | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,5,opt,name=apiVersion"` | ||||
| 	// Specific resourceVersion to which this reference is made, if any.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// +optional
 | ||||
| 	ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,6,opt,name=resourceVersion"` | ||||
| 
 | ||||
|  | @ -4952,7 +5078,7 @@ const ( | |||
| type Event struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	metav1.ObjectMeta `json:"metadata" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// The object that this event is about.
 | ||||
|  | @ -5040,7 +5166,7 @@ const ( | |||
| type EventList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5100,12 +5226,12 @@ type LimitRangeSpec struct { | |||
| type LimitRange struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the limits enforced.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec LimitRangeSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| } | ||||
|  | @ -5116,7 +5242,7 @@ type LimitRange struct { | |||
| type LimitRangeList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5256,17 +5382,17 @@ type ResourceQuotaStatus struct { | |||
| type ResourceQuota struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Spec defines the desired quota.
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Spec ResourceQuotaSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| 
 | ||||
| 	// Status defines the actual enforced quota and its current usage.
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status ResourceQuotaStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | @ -5277,7 +5403,7 @@ type ResourceQuota struct { | |||
| type ResourceQuotaList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5294,7 +5420,7 @@ type ResourceQuotaList struct { | |||
| type Secret struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5411,7 +5537,7 @@ const ( | |||
| type SecretList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5427,7 +5553,7 @@ type SecretList struct { | |||
| type ConfigMap struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5456,7 +5582,7 @@ type ConfigMap struct { | |||
| type ConfigMapList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5498,7 +5624,7 @@ type ComponentCondition struct { | |||
| type ComponentStatus struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5515,7 +5641,7 @@ type ComponentStatus struct { | |||
| type ComponentStatusList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -5682,7 +5808,7 @@ type WindowsSecurityContextOptions struct { | |||
| 	// Defaults to the user specified in image metadata if unspecified.
 | ||||
| 	// May also be set in PodSecurityContext. If set in both SecurityContext and
 | ||||
| 	// PodSecurityContext, the value specified in SecurityContext takes precedence.
 | ||||
| 	// This field is alpha-level and it is only honored by servers that enable the WindowsRunAsUserName feature flag.
 | ||||
| 	// This field is beta-level and may be disabled with the WindowsRunAsUserName feature flag.
 | ||||
| 	// +optional
 | ||||
| 	RunAsUserName *string `json:"runAsUserName,omitempty" protobuf:"bytes,3,opt,name=runAsUserName"` | ||||
| } | ||||
|  | @ -5693,7 +5819,7 @@ type WindowsSecurityContextOptions struct { | |||
| type RangeAllocation struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  |  | |||
|  | @ -108,7 +108,7 @@ func (AzureFileVolumeSource) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Binding = map[string]string{ | ||||
| 	"":         "Binding ties one object to another; for example, a pod is bound to a node by a scheduler. Deprecated in 1.7, please use the bindings subresource of pods instead.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"target":   "The target object that you want to bind to the standard object.", | ||||
| } | ||||
| 
 | ||||
|  | @ -231,7 +231,7 @@ func (ComponentCondition) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ComponentStatus = map[string]string{ | ||||
| 	"":           "ComponentStatus (and ComponentStatusList) holds the cluster validation info.", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"conditions": "List of component conditions observed", | ||||
| } | ||||
| 
 | ||||
|  | @ -241,7 +241,7 @@ func (ComponentStatus) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ComponentStatusList = map[string]string{ | ||||
| 	"":         "Status of all the conditions for the component as a list of ComponentStatus objects.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of ComponentStatus objects.", | ||||
| } | ||||
| 
 | ||||
|  | @ -251,7 +251,7 @@ func (ComponentStatusList) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ConfigMap = map[string]string{ | ||||
| 	"":           "ConfigMap holds configuration data for pods to consume.", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"data":       "Data contains the configuration data. Each key must consist of alphanumeric characters, '-', '_' or '.'. Values with non-UTF-8 byte sequences must use the BinaryData field. The keys stored in Data must not overlap with the keys in the BinaryData field, this is enforced during validation process.", | ||||
| 	"binaryData": "BinaryData contains the binary data. Each key must consist of alphanumeric characters, '-', '_' or '.'. BinaryData can contain byte sequences that are not in the UTF-8 range. The keys stored in BinaryData must not overlap with the ones in the Data field, this is enforced during validation process. Using this field will require 1.10+ apiserver and kubelet.", | ||||
| } | ||||
|  | @ -281,7 +281,7 @@ func (ConfigMapKeySelector) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ConfigMapList = map[string]string{ | ||||
| 	"":         "ConfigMapList is a resource containing a list of ConfigMap objects.", | ||||
| 	"metadata": "More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"items":    "Items is the list of ConfigMaps.", | ||||
| } | ||||
| 
 | ||||
|  | @ -338,6 +338,7 @@ var map_Container = map[string]string{ | |||
| 	"volumeDevices":            "volumeDevices is the list of block devices to be used by the container. This is a beta feature.", | ||||
| 	"livenessProbe":            "Periodic probe of container liveness. Container will be restarted if the probe fails. Cannot be updated. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes", | ||||
| 	"readinessProbe":           "Periodic probe of container service readiness. Container will be removed from service endpoints if the probe fails. Cannot be updated. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes", | ||||
| 	"startupProbe":             "StartupProbe indicates that the Pod has successfully initialized. If specified, no other probes are executed until this completes successfully. If this probe fails, the Pod will be restarted, just as if the livenessProbe failed. This can be used to provide different probe parameters at the beginning of a Pod's lifecycle, when it might take a long time to load data or warm a cache, than during steady-state operation. This cannot be updated. This is an alpha feature enabled by the StartupProbe feature flag. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes", | ||||
| 	"lifecycle":                "Actions that the management system should take in response to container lifecycle events. Cannot be updated.", | ||||
| 	"terminationMessagePath":   "Optional: Path at which the file to which the container's termination message will be written is mounted into the container's filesystem. Message written is intended to be brief final status, such as an assertion failure message. Will be truncated by the node if greater than 4096 bytes. The total message length across all containers will be limited to 12kb. Defaults to /dev/termination-log. Cannot be updated.", | ||||
| 	"terminationMessagePolicy": "Indicate how the termination message should be populated. File will use the contents of terminationMessagePath to populate the container status message on both success and failure. FallbackToLogsOnError will use the last chunk of container log output if the termination message file is empty and the container exited with an error. The log output is limited to 2048 bytes or 80 lines, whichever is smaller. Defaults to File. Cannot be updated.", | ||||
|  | @ -430,6 +431,7 @@ var map_ContainerStatus = map[string]string{ | |||
| 	"image":        "The image the container is running. More info: https://kubernetes.io/docs/concepts/containers/images", | ||||
| 	"imageID":      "ImageID of the container's image.", | ||||
| 	"containerID":  "Container's ID in the format 'docker://<container_id>'.", | ||||
| 	"started":      "Specifies whether the container has passed its startup probe. Initialized as false, becomes true after startupProbe is considered successful. Resets to false when the container is restarted, or if kubelet loses state temporarily. Is always true when no startupProbe is defined.", | ||||
| } | ||||
| 
 | ||||
| func (ContainerStatus) SwaggerDoc() map[string]string { | ||||
|  | @ -500,7 +502,7 @@ func (EndpointAddress) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_EndpointPort = map[string]string{ | ||||
| 	"":         "EndpointPort is a tuple that describes a single port.", | ||||
| 	"name":     "The name of this port (corresponds to ServicePort.Name). Must be a DNS_LABEL. Optional only if one port is defined.", | ||||
| 	"name":     "The name of this port.  This must match the 'name' field in the corresponding ServicePort. Must be a DNS_LABEL. Optional only if one port is defined.", | ||||
| 	"port":     "The port number of the endpoint.", | ||||
| 	"protocol": "The IP protocol for this port. Must be UDP, TCP, or SCTP. Default is TCP.", | ||||
| } | ||||
|  | @ -522,7 +524,7 @@ func (EndpointSubset) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Endpoints = map[string]string{ | ||||
| 	"":         "Endpoints is a collection of endpoints that implement the actual service. Example:\n  Name: \"mysvc\",\n  Subsets: [\n    {\n      Addresses: [{\"ip\": \"10.10.1.1\"}, {\"ip\": \"10.10.2.2\"}],\n      Ports: [{\"name\": \"a\", \"port\": 8675}, {\"name\": \"b\", \"port\": 309}]\n    },\n    {\n      Addresses: [{\"ip\": \"10.10.3.3\"}],\n      Ports: [{\"name\": \"a\", \"port\": 93}, {\"name\": \"b\", \"port\": 76}]\n    },\n ]", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"subsets":  "The set of all endpoints is the union of all subsets. Addresses are placed into subsets according to the IPs they share. A single address with multiple ports, some of which are ready and some of which are not (because they come from different containers) will result in the address being displayed in different subsets for the different ports. No address will appear in both Addresses and NotReadyAddresses in the same subset. Sets of addresses and ports that comprise a service.", | ||||
| } | ||||
| 
 | ||||
|  | @ -532,7 +534,7 @@ func (Endpoints) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_EndpointsList = map[string]string{ | ||||
| 	"":         "EndpointsList is a list of endpoints.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of endpoints.", | ||||
| } | ||||
| 
 | ||||
|  | @ -564,7 +566,7 @@ func (EnvVar) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_EnvVarSource = map[string]string{ | ||||
| 	"":                 "EnvVarSource represents a source for the value of an EnvVar.", | ||||
| 	"fieldRef":         "Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP.", | ||||
| 	"fieldRef":         "Selects a field of the pod: supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs.", | ||||
| 	"resourceFieldRef": "Selects a resource of the container: only resources limits and requests (limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported.", | ||||
| 	"configMapKeyRef":  "Selects a key of a ConfigMap.", | ||||
| 	"secretKeyRef":     "Selects a key of a secret in the pod's namespace", | ||||
|  | @ -575,7 +577,7 @@ func (EnvVarSource) SwaggerDoc() map[string]string { | |||
| } | ||||
| 
 | ||||
| var map_EphemeralContainer = map[string]string{ | ||||
| 	"":                    "An EphemeralContainer is a special type of container which doesn't come with any resource or scheduling guarantees but can be added to a pod that has already been created. They are intended for user-initiated activities such as troubleshooting a running pod. Ephemeral containers will not be restarted when they exit, and they will be killed if the pod is removed or restarted. If an ephemeral container causes a pod to exceed its resource allocation, the pod may be evicted. Ephemeral containers are added via a pod's ephemeralcontainers subresource and will appear in the pod spec once added. No fields in EphemeralContainer may be changed once added. This is an alpha feature enabled by the EphemeralContainers feature flag.", | ||||
| 	"":                    "An EphemeralContainer is a container that may be added temporarily to an existing pod for user-initiated activities such as debugging. Ephemeral containers have no resource or scheduling guarantees, and they will not be restarted when they exit or when a pod is removed or restarted. If an ephemeral container causes a pod to exceed its resource allocation, the pod may be evicted. Ephemeral containers may not be added by directly updating the pod spec. They must be added via the pod's ephemeralcontainers subresource, and they will appear in the pod spec once added. This is an alpha feature enabled by the EphemeralContainers feature flag.", | ||||
| 	"targetContainerName": "If set, the name of the container from PodSpec that this ephemeral container targets. The ephemeral container will be run in the namespaces (IPC, PID, etc) of this container. If not set then the ephemeral container is run in whatever namespaces are shared for the pod. Note that the container runtime must support this feature.", | ||||
| } | ||||
| 
 | ||||
|  | @ -584,6 +586,7 @@ func (EphemeralContainer) SwaggerDoc() map[string]string { | |||
| } | ||||
| 
 | ||||
| var map_EphemeralContainerCommon = map[string]string{ | ||||
| 	"":                         "EphemeralContainerCommon is a copy of all fields in Container to be inlined in EphemeralContainer. This separate type allows easy conversion from EphemeralContainer to Container and allows separate documentation for the fields of EphemeralContainer. When a new field is added to Container it must be added here as well.", | ||||
| 	"name":                     "Name of the ephemeral container specified as a DNS_LABEL. This name must be unique among all containers, init containers and ephemeral containers.", | ||||
| 	"image":                    "Docker image name. More info: https://kubernetes.io/docs/concepts/containers/images", | ||||
| 	"command":                  "Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this is not provided. Variable references $(VAR_NAME) are expanded using the container's environment. If a variable cannot be resolved, the reference in the input string will be unchanged. The $(VAR_NAME) syntax can be escaped with a double $$, ie: $$(VAR_NAME). Escaped references will never be expanded, regardless of whether the variable exists or not. Cannot be updated. More info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell", | ||||
|  | @ -597,6 +600,7 @@ var map_EphemeralContainerCommon = map[string]string{ | |||
| 	"volumeDevices":            "volumeDevices is the list of block devices to be used by the container. This is a beta feature.", | ||||
| 	"livenessProbe":            "Probes are not allowed for ephemeral containers.", | ||||
| 	"readinessProbe":           "Probes are not allowed for ephemeral containers.", | ||||
| 	"startupProbe":             "Probes are not allowed for ephemeral containers.", | ||||
| 	"lifecycle":                "Lifecycle is not allowed for ephemeral containers.", | ||||
| 	"terminationMessagePath":   "Optional: Path at which the file to which the container's termination message will be written is mounted into the container's filesystem. Message written is intended to be brief final status, such as an assertion failure message. Will be truncated by the node if greater than 4096 bytes. The total message length across all containers will be limited to 12kb. Defaults to /dev/termination-log. Cannot be updated.", | ||||
| 	"terminationMessagePolicy": "Indicate how the termination message should be populated. File will use the contents of terminationMessagePath to populate the container status message on both success and failure. FallbackToLogsOnError will use the last chunk of container log output if the termination message file is empty and the container exited with an error. The log output is limited to 2048 bytes or 80 lines, whichever is smaller. Defaults to File. Cannot be updated.", | ||||
|  | @ -612,8 +616,8 @@ func (EphemeralContainerCommon) SwaggerDoc() map[string]string { | |||
| } | ||||
| 
 | ||||
| var map_EphemeralContainers = map[string]string{ | ||||
| 	"":                    "A list of ephemeral containers used in API operations", | ||||
| 	"ephemeralContainers": "The new set of ephemeral containers to use for a pod.", | ||||
| 	"":                    "A list of ephemeral containers used with the Pod ephemeralcontainers subresource.", | ||||
| 	"ephemeralContainers": "A list of ephemeral containers associated with this pod. New ephemeral containers may be appended to this list, but existing ephemeral containers may not be removed or modified.", | ||||
| } | ||||
| 
 | ||||
| func (EphemeralContainers) SwaggerDoc() map[string]string { | ||||
|  | @ -622,7 +626,7 @@ func (EphemeralContainers) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Event = map[string]string{ | ||||
| 	"":                   "Event is a report of an event somewhere in the cluster.", | ||||
| 	"metadata":           "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata":           "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"involvedObject":     "The object that this event is about.", | ||||
| 	"reason":             "This should be a short, machine understandable string that gives the reason for the transition into the object's current status.", | ||||
| 	"message":            "A human-readable description of the status of this operation.", | ||||
|  | @ -645,7 +649,7 @@ func (Event) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_EventList = map[string]string{ | ||||
| 	"":         "EventList is a list of events.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of events", | ||||
| } | ||||
| 
 | ||||
|  | @ -884,7 +888,7 @@ func (KeyToPath) SwaggerDoc() map[string]string { | |||
| var map_Lifecycle = map[string]string{ | ||||
| 	"":          "Lifecycle describes actions that the management system should take in response to container lifecycle events. For the PostStart and PreStop lifecycle handlers, management of the container blocks until the action is complete, unless the container process fails, in which case the handler is aborted.", | ||||
| 	"postStart": "PostStart is called immediately after a container is created. If the handler fails, the container is terminated and restarted according to its restart policy. Other management of the container blocks until the hook completes. More info: https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks", | ||||
| 	"preStop":   "PreStop is called immediately before a container is terminated due to an API request or management event such as liveness probe failure, preemption, resource contention, etc. The handler is not called if the container crashes or exits. The reason for termination is passed to the handler. The Pod's termination grace period countdown begins before the PreStop hooked is executed. Regardless of the outcome of the handler, the container will eventually terminate within the Pod's termination grace period. Other management of the container blocks until the hook completes or until the termination grace period is reached. More info: https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks", | ||||
| 	"preStop":   "PreStop is called immediately before a container is terminated due to an API request or management event such as liveness/startup probe failure, preemption, resource contention, etc. The handler is not called if the container crashes or exits. The reason for termination is passed to the handler. The Pod's termination grace period countdown begins before the PreStop hooked is executed. Regardless of the outcome of the handler, the container will eventually terminate within the Pod's termination grace period. Other management of the container blocks until the hook completes or until the termination grace period is reached. More info: https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks", | ||||
| } | ||||
| 
 | ||||
| func (Lifecycle) SwaggerDoc() map[string]string { | ||||
|  | @ -893,8 +897,8 @@ func (Lifecycle) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_LimitRange = map[string]string{ | ||||
| 	"":         "LimitRange sets resource usage limits for each kind of resource in a Namespace.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the limits enforced. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the limits enforced. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (LimitRange) SwaggerDoc() map[string]string { | ||||
|  | @ -917,7 +921,7 @@ func (LimitRangeItem) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_LimitRangeList = map[string]string{ | ||||
| 	"":         "LimitRangeList is a list of LimitRange items.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "Items is a list of LimitRange objects. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/", | ||||
| } | ||||
| 
 | ||||
|  | @ -985,18 +989,28 @@ func (NFSVolumeSource) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Namespace = map[string]string{ | ||||
| 	"":         "Namespace provides a scope for Names. Use of multiple namespaces is optional.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of the Namespace. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status describes the current status of a Namespace. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of the Namespace. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status describes the current status of a Namespace. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (Namespace) SwaggerDoc() map[string]string { | ||||
| 	return map_Namespace | ||||
| } | ||||
| 
 | ||||
| var map_NamespaceCondition = map[string]string{ | ||||
| 	"":       "NamespaceCondition contains details about state of namespace.", | ||||
| 	"type":   "Type of namespace controller condition.", | ||||
| 	"status": "Status of the condition, one of True, False, Unknown.", | ||||
| } | ||||
| 
 | ||||
| func (NamespaceCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_NamespaceCondition | ||||
| } | ||||
| 
 | ||||
| var map_NamespaceList = map[string]string{ | ||||
| 	"":         "NamespaceList is a list of Namespaces.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "Items is the list of Namespace objects in the list. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/", | ||||
| } | ||||
| 
 | ||||
|  | @ -1014,8 +1028,9 @@ func (NamespaceSpec) SwaggerDoc() map[string]string { | |||
| } | ||||
| 
 | ||||
| var map_NamespaceStatus = map[string]string{ | ||||
| 	"":      "NamespaceStatus is information about the current status of a Namespace.", | ||||
| 	"phase": "Phase is the current lifecycle phase of the namespace. More info: https://kubernetes.io/docs/tasks/administer-cluster/namespaces/", | ||||
| 	"":           "NamespaceStatus is information about the current status of a Namespace.", | ||||
| 	"phase":      "Phase is the current lifecycle phase of the namespace. More info: https://kubernetes.io/docs/tasks/administer-cluster/namespaces/", | ||||
| 	"conditions": "Represents the latest available observations of a namespace's current state.", | ||||
| } | ||||
| 
 | ||||
| func (NamespaceStatus) SwaggerDoc() map[string]string { | ||||
|  | @ -1024,9 +1039,9 @@ func (NamespaceStatus) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Node = map[string]string{ | ||||
| 	"":         "Node is a worker node in Kubernetes. Each node will have a unique identifier in the cache (i.e. in etcd).", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of a node. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the node. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of a node. https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the node. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (Node) SwaggerDoc() map[string]string { | ||||
|  | @ -1099,7 +1114,7 @@ func (NodeDaemonEndpoints) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_NodeList = map[string]string{ | ||||
| 	"":         "NodeList is the whole list of all Nodes which have been registered with master.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of nodes", | ||||
| } | ||||
| 
 | ||||
|  | @ -1219,12 +1234,12 @@ func (ObjectFieldSelector) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ObjectReference = map[string]string{ | ||||
| 	"":                "ObjectReference contains enough information to let you inspect or modify the referred object.", | ||||
| 	"kind":            "Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"kind":            "Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"namespace":       "Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/", | ||||
| 	"name":            "Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names", | ||||
| 	"uid":             "UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids", | ||||
| 	"apiVersion":      "API version of the referent.", | ||||
| 	"resourceVersion": "Specific resourceVersion to which this reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"resourceVersion": "Specific resourceVersion to which this reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"fieldPath":       "If referring to a piece of an object instead of an entire object, this string should contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2]. For example, if the object reference is to a container within a pod, this would take on a value like: \"spec.containers{name}\" (where \"name\" refers to the name of the container that triggered the event) or if no container name is specified \"spec.containers[2]\" (container with index 2 in this pod). This syntax is chosen only to have some well-defined way of referencing a part of an object.", | ||||
| } | ||||
| 
 | ||||
|  | @ -1234,7 +1249,7 @@ func (ObjectReference) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PersistentVolume = map[string]string{ | ||||
| 	"":         "PersistentVolume (PV) is a storage resource provisioned by an administrator. It is analogous to a node. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines a specification of a persistent volume owned by the cluster. Provisioned by an administrator. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistent-volumes", | ||||
| 	"status":   "Status represents the current information/status for the persistent volume. Populated by the system. Read-only. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistent-volumes", | ||||
| } | ||||
|  | @ -1245,7 +1260,7 @@ func (PersistentVolume) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PersistentVolumeClaim = map[string]string{ | ||||
| 	"":         "PersistentVolumeClaim is a user's request for and claim to a persistent volume", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the desired characteristics of a volume requested by a pod author. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistentvolumeclaims", | ||||
| 	"status":   "Status represents the current information/status of a persistent volume claim. Read-only. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistentvolumeclaims", | ||||
| } | ||||
|  | @ -1268,7 +1283,7 @@ func (PersistentVolumeClaimCondition) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PersistentVolumeClaimList = map[string]string{ | ||||
| 	"":         "PersistentVolumeClaimList is a list of PersistentVolumeClaim items.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "A list of persistent volume claims. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes#persistentvolumeclaims", | ||||
| } | ||||
| 
 | ||||
|  | @ -1315,7 +1330,7 @@ func (PersistentVolumeClaimVolumeSource) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PersistentVolumeList = map[string]string{ | ||||
| 	"":         "PersistentVolumeList is a list of PersistentVolume items.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of persistent volumes. More info: https://kubernetes.io/docs/concepts/storage/persistent-volumes", | ||||
| } | ||||
| 
 | ||||
|  | @ -1392,9 +1407,9 @@ func (PhotonPersistentDiskVolumeSource) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Pod = map[string]string{ | ||||
| 	"":         "Pod is a collection of containers that can run on a host. This resource is created by clients and scheduled onto hosts.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Specification of the desired behavior of the pod. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the pod. This data may not be up to date. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Specification of the desired behavior of the pod. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the pod. This data may not be up to date. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (Pod) SwaggerDoc() map[string]string { | ||||
|  | @ -1504,8 +1519,8 @@ func (PodIP) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PodList = map[string]string{ | ||||
| 	"":         "PodList is a list of Pods.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of pods. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of pods. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md", | ||||
| } | ||||
| 
 | ||||
| func (PodList) SwaggerDoc() map[string]string { | ||||
|  | @ -1513,15 +1528,16 @@ func (PodList) SwaggerDoc() map[string]string { | |||
| } | ||||
| 
 | ||||
| var map_PodLogOptions = map[string]string{ | ||||
| 	"":             "PodLogOptions is the query options for a Pod's logs REST call.", | ||||
| 	"container":    "The container for which to stream logs. Defaults to only container if there is one container in the pod.", | ||||
| 	"follow":       "Follow the log stream of the pod. Defaults to false.", | ||||
| 	"previous":     "Return previous terminated container logs. Defaults to false.", | ||||
| 	"sinceSeconds": "A relative time in seconds before the current time from which to show logs. If this value precedes the time a pod was started, only logs since the pod start will be returned. If this value is in the future, no logs will be returned. Only one of sinceSeconds or sinceTime may be specified.", | ||||
| 	"sinceTime":    "An RFC3339 timestamp from which to show logs. If this value precedes the time a pod was started, only logs since the pod start will be returned. If this value is in the future, no logs will be returned. Only one of sinceSeconds or sinceTime may be specified.", | ||||
| 	"timestamps":   "If true, add an RFC3339 or RFC3339Nano timestamp at the beginning of every line of log output. Defaults to false.", | ||||
| 	"tailLines":    "If set, the number of lines from the end of the logs to show. If not specified, logs are shown from the creation of the container or sinceSeconds or sinceTime", | ||||
| 	"limitBytes":   "If set, the number of bytes to read from the server before terminating the log output. This may not display a complete final line of logging, and may return slightly more or slightly less than the specified limit.", | ||||
| 	"":                             "PodLogOptions is the query options for a Pod's logs REST call.", | ||||
| 	"container":                    "The container for which to stream logs. Defaults to only container if there is one container in the pod.", | ||||
| 	"follow":                       "Follow the log stream of the pod. Defaults to false.", | ||||
| 	"previous":                     "Return previous terminated container logs. Defaults to false.", | ||||
| 	"sinceSeconds":                 "A relative time in seconds before the current time from which to show logs. If this value precedes the time a pod was started, only logs since the pod start will be returned. If this value is in the future, no logs will be returned. Only one of sinceSeconds or sinceTime may be specified.", | ||||
| 	"sinceTime":                    "An RFC3339 timestamp from which to show logs. If this value precedes the time a pod was started, only logs since the pod start will be returned. If this value is in the future, no logs will be returned. Only one of sinceSeconds or sinceTime may be specified.", | ||||
| 	"timestamps":                   "If true, add an RFC3339 or RFC3339Nano timestamp at the beginning of every line of log output. Defaults to false.", | ||||
| 	"tailLines":                    "If set, the number of lines from the end of the logs to show. If not specified, logs are shown from the creation of the container or sinceSeconds or sinceTime", | ||||
| 	"limitBytes":                   "If set, the number of bytes to read from the server before terminating the log output. This may not display a complete final line of logging, and may return slightly more or slightly less than the specified limit.", | ||||
| 	"insecureSkipTLSVerifyBackend": "insecureSkipTLSVerifyBackend indicates that the apiserver should not confirm the validity of the serving certificate of the backend it is connecting to.  This will make the HTTPS connection between the apiserver and the backend insecure. This means the apiserver cannot verify the log data it is receiving came from the real kubelet.  If the kubelet is configured to verify the apiserver's TLS credentials, it does not mean the connection to the real kubelet is vulnerable to a man in the middle attack (e.g. an attacker could not intercept the actual log data coming from the real kubelet).", | ||||
| } | ||||
| 
 | ||||
| func (PodLogOptions) SwaggerDoc() map[string]string { | ||||
|  | @ -1583,9 +1599,9 @@ func (PodSignature) SwaggerDoc() map[string]string { | |||
| var map_PodSpec = map[string]string{ | ||||
| 	"":                              "PodSpec is a description of a pod.", | ||||
| 	"volumes":                       "List of volumes that can be mounted by containers belonging to the pod. More info: https://kubernetes.io/docs/concepts/storage/volumes", | ||||
| 	"initContainers":                "List of initialization containers belonging to the pod. Init containers are executed in order prior to containers being started. If any init container fails, the pod is considered to have failed and is handled according to its restartPolicy. The name for an init container or normal container must be unique among all containers. Init containers may not have Lifecycle actions, Readiness probes, or Liveness probes. The resourceRequirements of an init container are taken into account during scheduling by finding the highest request/limit for each resource type, and then using the max of of that value or the sum of the normal containers. Limits are applied to init containers in a similar fashion. Init containers cannot currently be added or removed. Cannot be updated. More info: https://kubernetes.io/docs/concepts/workloads/pods/init-containers/", | ||||
| 	"initContainers":                "List of initialization containers belonging to the pod. Init containers are executed in order prior to containers being started. If any init container fails, the pod is considered to have failed and is handled according to its restartPolicy. The name for an init container or normal container must be unique among all containers. Init containers may not have Lifecycle actions, Readiness probes, Liveness probes, or Startup probes. The resourceRequirements of an init container are taken into account during scheduling by finding the highest request/limit for each resource type, and then using the max of of that value or the sum of the normal containers. Limits are applied to init containers in a similar fashion. Init containers cannot currently be added or removed. Cannot be updated. More info: https://kubernetes.io/docs/concepts/workloads/pods/init-containers/", | ||||
| 	"containers":                    "List of containers belonging to the pod. Containers cannot currently be added or removed. There must be at least one container in a Pod. Cannot be updated.", | ||||
| 	"ephemeralContainers":           "EphemeralContainers is the list of ephemeral containers that run in this pod. Ephemeral containers are added to an existing pod as a result of a user-initiated action such as troubleshooting. This list is read-only in the pod spec. It may not be specified in a create or modified in an update of a pod or pod template. To add an ephemeral container use the pod's ephemeralcontainers subresource, which allows update using the EphemeralContainers kind. This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.", | ||||
| 	"ephemeralContainers":           "List of ephemeral containers run in this pod. Ephemeral containers may be run in an existing pod to perform user-initiated actions such as debugging. This list cannot be specified when creating a pod, and it cannot be modified by updating the pod spec. In order to add an ephemeral container to an existing pod, use the pod's ephemeralcontainers subresource. This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.", | ||||
| 	"restartPolicy":                 "Restart policy for all containers within the pod. One of Always, OnFailure, Never. Default to Always. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#restart-policy", | ||||
| 	"terminationGracePeriodSeconds": "Optional duration in seconds the pod needs to terminate gracefully. May be decreased in delete request. Value must be non-negative integer. The value zero indicates delete immediately. If this value is nil, the default grace period will be used instead. The grace period is the duration in seconds after the processes running in the pod are sent a termination signal and the time when the processes are forcibly halted with a kill signal. Set this value longer than the expected cleanup time for your process. Defaults to 30 seconds.", | ||||
| 	"activeDeadlineSeconds":         "Optional duration in seconds the pod may be active on the node relative to StartTime before the system will actively try to mark it failed and kill associated containers. Value must be a positive integer.", | ||||
|  | @ -1598,7 +1614,7 @@ var map_PodSpec = map[string]string{ | |||
| 	"hostNetwork":                   "Host networking requested for this pod. Use the host's network namespace. If this option is set, the ports that will be used must be specified. Default to false.", | ||||
| 	"hostPID":                       "Use the host's pid namespace. Optional: Default to false.", | ||||
| 	"hostIPC":                       "Use the host's ipc namespace. Optional: Default to false.", | ||||
| 	"shareProcessNamespace":         "Share a single process namespace between all of the containers in a pod. When this is set containers will be able to view and signal processes from other containers in the same pod, and the first process in each container will not be assigned PID 1. HostPID and ShareProcessNamespace cannot both be set. Optional: Default to false. This field is beta-level and may be disabled with the PodShareProcessNamespace feature.", | ||||
| 	"shareProcessNamespace":         "Share a single process namespace between all of the containers in a pod. When this is set containers will be able to view and signal processes from other containers in the same pod, and the first process in each container will not be assigned PID 1. HostPID and ShareProcessNamespace cannot both be set. Optional: Default to false.", | ||||
| 	"securityContext":               "SecurityContext holds pod-level security attributes and common container settings. Optional: Defaults to empty.  See type description for default values of each field.", | ||||
| 	"imagePullSecrets":              "ImagePullSecrets is an optional list of references to secrets in the same namespace to use for pulling any of the images used by this PodSpec. If specified, these secrets will be passed to individual puller implementations for them to use. For example, in the case of docker, only DockerConfig type secrets are honored. More info: https://kubernetes.io/docs/concepts/containers/images#specifying-imagepullsecrets-on-a-pod", | ||||
| 	"hostname":                      "Specifies the hostname of the Pod If not specified, the pod's hostname will be set to a system-defined value.", | ||||
|  | @ -1636,7 +1652,7 @@ var map_PodStatus = map[string]string{ | |||
| 	"initContainerStatuses":      "The list has one entry per init container in the manifest. The most recent successful init container will have ready = true, the most recently started container will have startTime set. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status", | ||||
| 	"containerStatuses":          "The list has one entry per container in the manifest. Each entry is currently the output of `docker inspect`. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#pod-and-container-status", | ||||
| 	"qosClass":                   "The Quality of Service (QOS) classification assigned to the pod based on resource requirements See PodQOSClass type for available QOS classes More info: https://git.k8s.io/community/contributors/design-proposals/node/resource-qos.md", | ||||
| 	"ephemeralContainerStatuses": "Status for any ephemeral containers that running in this pod. This field is alpha-level and is only honored by servers that enable the EphemeralContainers feature.", | ||||
| 	"ephemeralContainerStatuses": "Status for any ephemeral containers that have run in this pod. This field is alpha-level and is only populated by servers that enable the EphemeralContainers feature.", | ||||
| } | ||||
| 
 | ||||
| func (PodStatus) SwaggerDoc() map[string]string { | ||||
|  | @ -1645,8 +1661,8 @@ func (PodStatus) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PodStatusResult = map[string]string{ | ||||
| 	"":         "PodStatusResult is a wrapper for PodStatus returned by kubelet that can be encode/decoded", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"status":   "Most recently observed status of the pod. This data may not be up to date. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"status":   "Most recently observed status of the pod. This data may not be up to date. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (PodStatusResult) SwaggerDoc() map[string]string { | ||||
|  | @ -1655,8 +1671,8 @@ func (PodStatusResult) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PodTemplate = map[string]string{ | ||||
| 	"":         "PodTemplate describes a template for creating copies of a predefined pod.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"template": "Template defines the pods that will be created from this pod template. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"template": "Template defines the pods that will be created from this pod template. https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (PodTemplate) SwaggerDoc() map[string]string { | ||||
|  | @ -1665,7 +1681,7 @@ func (PodTemplate) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PodTemplateList = map[string]string{ | ||||
| 	"":         "PodTemplateList is a list of PodTemplates.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of pod templates", | ||||
| } | ||||
| 
 | ||||
|  | @ -1675,8 +1691,8 @@ func (PodTemplateList) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PodTemplateSpec = map[string]string{ | ||||
| 	"":         "PodTemplateSpec describes the data a pod should have when created from a template", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Specification of the desired behavior of the pod. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Specification of the desired behavior of the pod. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (PodTemplateSpec) SwaggerDoc() map[string]string { | ||||
|  | @ -1730,7 +1746,7 @@ var map_Probe = map[string]string{ | |||
| 	"initialDelaySeconds": "Number of seconds after the container has started before liveness probes are initiated. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes", | ||||
| 	"timeoutSeconds":      "Number of seconds after which the probe times out. Defaults to 1 second. Minimum value is 1. More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes", | ||||
| 	"periodSeconds":       "How often (in seconds) to perform the probe. Default to 10 seconds. Minimum value is 1.", | ||||
| 	"successThreshold":    "Minimum consecutive successes for the probe to be considered successful after having failed. Defaults to 1. Must be 1 for liveness. Minimum value is 1.", | ||||
| 	"successThreshold":    "Minimum consecutive successes for the probe to be considered successful after having failed. Defaults to 1. Must be 1 for liveness and startup. Minimum value is 1.", | ||||
| 	"failureThreshold":    "Minimum consecutive failures for the probe to be considered failed after having succeeded. Defaults to 3. Minimum value is 1.", | ||||
| } | ||||
| 
 | ||||
|  | @ -1796,7 +1812,7 @@ func (RBDVolumeSource) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_RangeAllocation = map[string]string{ | ||||
| 	"":         "RangeAllocation is not a public type.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"range":    "Range is string that identifies the range represented by 'data'.", | ||||
| 	"data":     "Data is a bit array containing all allocated addresses in the previous segment.", | ||||
| } | ||||
|  | @ -1807,9 +1823,9 @@ func (RangeAllocation) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ReplicationController = map[string]string{ | ||||
| 	"":         "ReplicationController represents the configuration of a replication controller.", | ||||
| 	"metadata": "If the Labels of a ReplicationController are empty, they are defaulted to be the same as the Pod(s) that the replication controller manages. Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the specification of the desired behavior of the replication controller. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status is the most recently observed status of the replication controller. This data may be out of date by some window of time. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "If the Labels of a ReplicationController are empty, they are defaulted to be the same as the Pod(s) that the replication controller manages. Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the specification of the desired behavior of the replication controller. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status is the most recently observed status of the replication controller. This data may be out of date by some window of time. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (ReplicationController) SwaggerDoc() map[string]string { | ||||
|  | @ -1831,7 +1847,7 @@ func (ReplicationControllerCondition) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ReplicationControllerList = map[string]string{ | ||||
| 	"":         "ReplicationControllerList is a collection of replication controllers.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of replication controllers. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller", | ||||
| } | ||||
| 
 | ||||
|  | @ -1878,9 +1894,9 @@ func (ResourceFieldSelector) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ResourceQuota = map[string]string{ | ||||
| 	"":         "ResourceQuota sets aggregate quota restrictions enforced per namespace", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the desired quota. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status defines the actual enforced quota and its current usage. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the desired quota. https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Status defines the actual enforced quota and its current usage. https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (ResourceQuota) SwaggerDoc() map[string]string { | ||||
|  | @ -1889,7 +1905,7 @@ func (ResourceQuota) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ResourceQuotaList = map[string]string{ | ||||
| 	"":         "ResourceQuotaList is a list of ResourceQuota items.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "Items is a list of ResourceQuota objects. More info: https://kubernetes.io/docs/concepts/policy/resource-quotas/", | ||||
| } | ||||
| 
 | ||||
|  | @ -1998,7 +2014,7 @@ func (ScopedResourceSelectorRequirement) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Secret = map[string]string{ | ||||
| 	"":           "Secret holds secret data of a certain type. The total bytes of the values in the Data field must be less than MaxSecretSize bytes.", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata":   "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"data":       "Data contains the secret data. Each key must consist of alphanumeric characters, '-', '_' or '.'. The serialized form of the secret data is a base64 encoded string, representing the arbitrary (possibly non-string) data value here. Described in https://tools.ietf.org/html/rfc4648#section-4", | ||||
| 	"stringData": "stringData allows specifying non-binary secret data in string form. It is provided as a write-only convenience method. All keys and values are merged into the data field on write, overwriting any existing values. It is never output when reading from the API.", | ||||
| 	"type":       "Used to facilitate programmatic handling of secret data.", | ||||
|  | @ -2029,7 +2045,7 @@ func (SecretKeySelector) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_SecretList = map[string]string{ | ||||
| 	"":         "SecretList is a list of Secret.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "Items is a list of secret objects. More info: https://kubernetes.io/docs/concepts/configuration/secret", | ||||
| } | ||||
| 
 | ||||
|  | @ -2098,9 +2114,9 @@ func (SerializedReference) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Service = map[string]string{ | ||||
| 	"":         "Service is a named abstraction of software service (for example, mysql) consisting of local port (for example 3306) that the proxy listens on, and the selector that determines which pods will answer requests sent through the proxy.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of a service. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the service. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "Spec defines the behavior of a service. https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Most recently observed status of the service. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| } | ||||
| 
 | ||||
| func (Service) SwaggerDoc() map[string]string { | ||||
|  | @ -2109,7 +2125,7 @@ func (Service) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ServiceAccount = map[string]string{ | ||||
| 	"":                             "ServiceAccount binds together: * a name, understood by users, and perhaps by peripheral systems, for an identity * a principal that can be authenticated and authorized * a set of secrets", | ||||
| 	"metadata":                     "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata":                     "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"secrets":                      "Secrets is the list of secrets allowed to be used by pods running using this ServiceAccount. More info: https://kubernetes.io/docs/concepts/configuration/secret", | ||||
| 	"imagePullSecrets":             "ImagePullSecrets is a list of references to secrets in the same namespace to use for pulling any images in pods that reference this ServiceAccount. ImagePullSecrets are distinct from Secrets because Secrets can be mounted in the pod, but ImagePullSecrets are only accessed by the kubelet. More info: https://kubernetes.io/docs/concepts/containers/images/#specifying-imagepullsecrets-on-a-pod", | ||||
| 	"automountServiceAccountToken": "AutomountServiceAccountToken indicates whether pods running as this service account should have an API token automatically mounted. Can be overridden at the pod level.", | ||||
|  | @ -2121,7 +2137,7 @@ func (ServiceAccount) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ServiceAccountList = map[string]string{ | ||||
| 	"":         "ServiceAccountList is a list of ServiceAccount objects", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of ServiceAccounts. More info: https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/", | ||||
| } | ||||
| 
 | ||||
|  | @ -2142,7 +2158,7 @@ func (ServiceAccountTokenProjection) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ServiceList = map[string]string{ | ||||
| 	"":         "ServiceList holds a list of services.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of services", | ||||
| } | ||||
| 
 | ||||
|  | @ -2152,7 +2168,7 @@ func (ServiceList) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_ServicePort = map[string]string{ | ||||
| 	"":           "ServicePort contains information on service's port.", | ||||
| 	"name":       "The name of this port within the service. This must be a DNS_LABEL. All ports within a ServiceSpec must have unique names. This maps to the 'Name' field in EndpointPort objects. Optional if only one ServicePort is defined on this service.", | ||||
| 	"name":       "The name of this port within the service. This must be a DNS_LABEL. All ports within a ServiceSpec must have unique names. When considering the endpoints for a Service, this must match the 'name' field in the EndpointPort. Optional if only one ServicePort is defined on this service.", | ||||
| 	"protocol":   "The IP protocol for this port. Supports \"TCP\", \"UDP\", and \"SCTP\". Default is TCP.", | ||||
| 	"port":       "The port that will be exposed by this service.", | ||||
| 	"targetPort": "Number or name of the port to access on the pods targeted by the service. Number must be in the range 1 to 65535. Name must be an IANA_SVC_NAME. If this is a string, it will be looked up as a named port in the target Pod's container ports. If this is not specified, the value of the 'port' field is used (an identity map). This field is ignored for services with clusterIP=None, and should be omitted or set equal to the 'port' field. More info: https://kubernetes.io/docs/concepts/services-networking/service/#defining-a-service", | ||||
|  | @ -2187,6 +2203,8 @@ var map_ServiceSpec = map[string]string{ | |||
| 	"healthCheckNodePort":      "healthCheckNodePort specifies the healthcheck nodePort for the service. If not specified, HealthCheckNodePort is created by the service api backend with the allocated nodePort. Will use user-specified nodePort value if specified by the client. Only effects when Type is set to LoadBalancer and ExternalTrafficPolicy is set to Local.", | ||||
| 	"publishNotReadyAddresses": "publishNotReadyAddresses, when set to true, indicates that DNS implementations must publish the notReadyAddresses of subsets for the Endpoints associated with the Service. The default value is false. The primary use case for setting this field is to use a StatefulSet's Headless Service to propagate SRV records for its Pods without respect to their readiness for purpose of peer discovery.", | ||||
| 	"sessionAffinityConfig":    "sessionAffinityConfig contains the configurations of session affinity.", | ||||
| 	"ipFamily":                 "ipFamily specifies whether this Service has a preference for a particular IP family (e.g. IPv4 vs. IPv6).  If a specific IP family is requested, the clusterIP field will be allocated from that family, if it is available in the cluster.  If no IP family is requested, the cluster's primary IP family will be used. Other IP fields (loadBalancerIP, loadBalancerSourceRanges, externalIPs) and controllers which allocate external load-balancers should use the same IP family.  Endpoints for this Service will be of this family.  This field is immutable after creation. Assigning a ServiceIPFamily not available in the cluster (e.g. IPv6 in IPv4 only cluster) is an error condition and will fail during clusterIP assignment.", | ||||
| 	"topologyKeys":             "topologyKeys is a preference-order list of topology keys which implementations of services should use to preferentially sort endpoints when accessing this Service, it can not be used at the same time as externalTrafficPolicy=Local. Topology keys must be valid label keys and at most 16 keys may be specified. Endpoints are chosen based on the first topology key with available backends. If this field is specified and all entries have no backends that match the topology of the client, the service has no backends for that client and connections should fail. The special value \"*\" may be used to mean \"any topology\". This catch-all value, if used, only makes sense as the last value in the list. If this is not specified or empty, no topology constraints will be applied.", | ||||
| } | ||||
| 
 | ||||
| func (ServiceSpec) SwaggerDoc() map[string]string { | ||||
|  | @ -2350,7 +2368,7 @@ var map_VolumeMount = map[string]string{ | |||
| 	"mountPath":        "Path within the container at which the volume should be mounted.  Must not contain ':'.", | ||||
| 	"subPath":          "Path within the volume from which the container's volume should be mounted. Defaults to \"\" (volume's root).", | ||||
| 	"mountPropagation": "mountPropagation determines how mounts are propagated from the host to container and the other way around. When not set, MountPropagationNone is used. This field is beta in 1.10.", | ||||
| 	"subPathExpr":      "Expanded path within the volume from which the container's volume should be mounted. Behaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment. Defaults to \"\" (volume's root). SubPathExpr and SubPath are mutually exclusive. This field is beta in 1.15.", | ||||
| 	"subPathExpr":      "Expanded path within the volume from which the container's volume should be mounted. Behaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment. Defaults to \"\" (volume's root). SubPathExpr and SubPath are mutually exclusive.", | ||||
| } | ||||
| 
 | ||||
| func (VolumeMount) SwaggerDoc() map[string]string { | ||||
|  | @ -2440,7 +2458,7 @@ var map_WindowsSecurityContextOptions = map[string]string{ | |||
| 	"":                       "WindowsSecurityContextOptions contain Windows-specific options and credentials.", | ||||
| 	"gmsaCredentialSpecName": "GMSACredentialSpecName is the name of the GMSA credential spec to use. This field is alpha-level and is only honored by servers that enable the WindowsGMSA feature flag.", | ||||
| 	"gmsaCredentialSpec":     "GMSACredentialSpec is where the GMSA admission webhook (https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the GMSA credential spec named by the GMSACredentialSpecName field. This field is alpha-level and is only honored by servers that enable the WindowsGMSA feature flag.", | ||||
| 	"runAsUserName":          "The UserName in Windows to run the entrypoint of the container process. Defaults to the user specified in image metadata if unspecified. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. This field is alpha-level and it is only honored by servers that enable the WindowsRunAsUserName feature flag.", | ||||
| 	"runAsUserName":          "The UserName in Windows to run the entrypoint of the container process. Defaults to the user specified in image metadata if unspecified. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. This field is beta-level and may be disabled with the WindowsRunAsUserName feature flag.", | ||||
| } | ||||
| 
 | ||||
| func (WindowsSecurityContextOptions) SwaggerDoc() map[string]string { | ||||
|  |  | |||
|  | @ -17,15 +17,23 @@ limitations under the License. | |||
| package v1 | ||||
| 
 | ||||
| const ( | ||||
| 	LabelHostname          = "kubernetes.io/hostname" | ||||
| 	LabelZoneFailureDomain = "failure-domain.beta.kubernetes.io/zone" | ||||
| 	LabelZoneRegion        = "failure-domain.beta.kubernetes.io/region" | ||||
| 	LabelHostname = "kubernetes.io/hostname" | ||||
| 
 | ||||
| 	LabelInstanceType = "beta.kubernetes.io/instance-type" | ||||
| 	LabelZoneFailureDomain       = "failure-domain.beta.kubernetes.io/zone" | ||||
| 	LabelZoneRegion              = "failure-domain.beta.kubernetes.io/region" | ||||
| 	LabelZoneFailureDomainStable = "topology.kubernetes.io/zone" | ||||
| 	LabelZoneRegionStable        = "topology.kubernetes.io/region" | ||||
| 
 | ||||
| 	LabelInstanceType       = "beta.kubernetes.io/instance-type" | ||||
| 	LabelInstanceTypeStable = "node.kubernetes.io/instance-type" | ||||
| 
 | ||||
| 	LabelOSStable   = "kubernetes.io/os" | ||||
| 	LabelArchStable = "kubernetes.io/arch" | ||||
| 
 | ||||
| 	// LabelWindowsBuild is used on Windows nodes to specify the Windows build number starting with v1.17.0.
 | ||||
| 	// It's in the format MajorVersion.MinorVersion.BuildNumber (for ex: 10.0.17763)
 | ||||
| 	LabelWindowsBuild = "node.kubernetes.io/windows-build" | ||||
| 
 | ||||
| 	// LabelNamespaceSuffixKubelet is an allowed label namespace suffix kubelets can self-set ([*.]kubelet.kubernetes.io/*)
 | ||||
| 	LabelNamespaceSuffixKubelet = "kubelet.kubernetes.io" | ||||
| 	// LabelNamespaceSuffixNode is an allowed label namespace suffix kubelets can self-set ([*.]node.kubernetes.io/*)
 | ||||
|  | @ -33,4 +41,10 @@ const ( | |||
| 
 | ||||
| 	// LabelNamespaceNodeRestriction is a forbidden label namespace that kubelets may not self-set when the NodeRestriction admission plugin is enabled
 | ||||
| 	LabelNamespaceNodeRestriction = "node-restriction.kubernetes.io" | ||||
| 
 | ||||
| 	// IsHeadlessService is added by Controller to an Endpoint denoting if its parent
 | ||||
| 	// Service is Headless. The existence of this label can be used further by other
 | ||||
| 	// controllers and kube-proxy to check if the Endpoint objects should be replicated when
 | ||||
| 	// using Headless Services
 | ||||
| 	IsHeadlessService = "service.kubernetes.io/headless" | ||||
| ) | ||||
|  |  | |||
|  | @ -0,0 +1,55 @@ | |||
| /* | ||||
| Copyright 2019 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 v1 | ||||
| 
 | ||||
| const ( | ||||
| 	// TaintNodeNotReady will be added when node is not ready
 | ||||
| 	// and feature-gate for TaintBasedEvictions flag is enabled,
 | ||||
| 	// and removed when node becomes ready.
 | ||||
| 	TaintNodeNotReady = "node.kubernetes.io/not-ready" | ||||
| 
 | ||||
| 	// TaintNodeUnreachable will be added when node becomes unreachable
 | ||||
| 	// (corresponding to NodeReady status ConditionUnknown)
 | ||||
| 	// and feature-gate for TaintBasedEvictions flag is enabled,
 | ||||
| 	// and removed when node becomes reachable (NodeReady status ConditionTrue).
 | ||||
| 	TaintNodeUnreachable = "node.kubernetes.io/unreachable" | ||||
| 
 | ||||
| 	// TaintNodeUnschedulable will be added when node becomes unschedulable
 | ||||
| 	// and feature-gate for TaintNodesByCondition flag is enabled,
 | ||||
| 	// and removed when node becomes scheduable.
 | ||||
| 	TaintNodeUnschedulable = "node.kubernetes.io/unschedulable" | ||||
| 
 | ||||
| 	// TaintNodeMemoryPressure will be added when node has memory pressure
 | ||||
| 	// and feature-gate for TaintNodesByCondition flag is enabled,
 | ||||
| 	// and removed when node has enough memory.
 | ||||
| 	TaintNodeMemoryPressure = "node.kubernetes.io/memory-pressure" | ||||
| 
 | ||||
| 	// TaintNodeDiskPressure will be added when node has disk pressure
 | ||||
| 	// and feature-gate for TaintNodesByCondition flag is enabled,
 | ||||
| 	// and removed when node has enough disk.
 | ||||
| 	TaintNodeDiskPressure = "node.kubernetes.io/disk-pressure" | ||||
| 
 | ||||
| 	// TaintNodeNetworkUnavailable will be added when node's network is unavailable
 | ||||
| 	// and feature-gate for TaintNodesByCondition flag is enabled,
 | ||||
| 	// and removed when network becomes ready.
 | ||||
| 	TaintNodeNetworkUnavailable = "node.kubernetes.io/network-unavailable" | ||||
| 
 | ||||
| 	// TaintNodePIDPressure will be added when node has pid pressure
 | ||||
| 	// and feature-gate for TaintNodesByCondition flag is enabled,
 | ||||
| 	// and removed when node has enough disk.
 | ||||
| 	TaintNodePIDPressure = "node.kubernetes.io/pid-pressure" | ||||
| ) | ||||
|  | @ -773,6 +773,11 @@ func (in *Container) DeepCopyInto(out *Container) { | |||
| 		*out = new(Probe) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.StartupProbe != nil { | ||||
| 		in, out := &in.StartupProbe, &out.StartupProbe | ||||
| 		*out = new(Probe) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Lifecycle != nil { | ||||
| 		in, out := &in.Lifecycle, &out.Lifecycle | ||||
| 		*out = new(Lifecycle) | ||||
|  | @ -920,6 +925,11 @@ func (in *ContainerStatus) DeepCopyInto(out *ContainerStatus) { | |||
| 	*out = *in | ||||
| 	in.State.DeepCopyInto(&out.State) | ||||
| 	in.LastTerminationState.DeepCopyInto(&out.LastTerminationState) | ||||
| 	if in.Started != nil { | ||||
| 		in, out := &in.Started, &out.Started | ||||
| 		*out = new(bool) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
|  | @ -1350,6 +1360,11 @@ func (in *EphemeralContainerCommon) DeepCopyInto(out *EphemeralContainerCommon) | |||
| 		*out = new(Probe) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.StartupProbe != nil { | ||||
| 		in, out := &in.StartupProbe, &out.StartupProbe | ||||
| 		*out = new(Probe) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Lifecycle != nil { | ||||
| 		in, out := &in.Lifecycle, &out.Lifecycle | ||||
| 		*out = new(Lifecycle) | ||||
|  | @ -2189,7 +2204,7 @@ func (in *Namespace) DeepCopyInto(out *Namespace) { | |||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
|  | @ -2211,6 +2226,23 @@ func (in *Namespace) DeepCopyObject() runtime.Object { | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *NamespaceCondition) DeepCopyInto(out *NamespaceCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new NamespaceCondition.
 | ||||
| func (in *NamespaceCondition) DeepCopy() *NamespaceCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(NamespaceCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
| 
 | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *NamespaceList) DeepCopyInto(out *NamespaceList) { | ||||
| 	*out = *in | ||||
|  | @ -2268,6 +2300,13 @@ func (in *NamespaceSpec) DeepCopy() *NamespaceSpec { | |||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *NamespaceStatus) DeepCopyInto(out *NamespaceStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]NamespaceCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
|  | @ -5142,6 +5181,16 @@ func (in *ServiceSpec) DeepCopyInto(out *ServiceSpec) { | |||
| 		*out = new(SessionAffinityConfig) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.IPFamily != nil { | ||||
| 		in, out := &in.IPFamily, &out.IPFamily | ||||
| 		*out = new(IPFamily) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.TopologyKeys != nil { | ||||
| 		in, out := &in.TopologyKeys, &out.TopologyKeys | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,4 +23,3 @@ reviewers: | |||
| - krousey | ||||
| - cjcullen | ||||
| - david-mcmahon | ||||
| - goltermann | ||||
|  |  | |||
|  | @ -32,7 +32,9 @@ import ( | |||
| const ( | ||||
| 	// StatusTooManyRequests means the server experienced too many requests within a
 | ||||
| 	// given window and that the client must wait to perform the action again.
 | ||||
| 	StatusTooManyRequests = 429 | ||||
| 	// DEPRECATED: please use http.StatusTooManyRequests, this will be removed in
 | ||||
| 	// the future version.
 | ||||
| 	StatusTooManyRequests = http.StatusTooManyRequests | ||||
| ) | ||||
| 
 | ||||
| // StatusError is an error intended for consumption by a REST API server; it can also be
 | ||||
|  | @ -68,6 +70,28 @@ func (e *StatusError) DebugError() (string, []interface{}) { | |||
| 	return "server response object: %#v", []interface{}{e.ErrStatus} | ||||
| } | ||||
| 
 | ||||
| // HasStatusCause returns true if the provided error has a details cause
 | ||||
| // with the provided type name.
 | ||||
| func HasStatusCause(err error, name metav1.CauseType) bool { | ||||
| 	_, ok := StatusCause(err, name) | ||||
| 	return ok | ||||
| } | ||||
| 
 | ||||
| // StatusCause returns the named cause from the provided error if it exists and
 | ||||
| // the error is of the type APIStatus. Otherwise it returns false.
 | ||||
| func StatusCause(err error, name metav1.CauseType) (metav1.StatusCause, bool) { | ||||
| 	apierr, ok := err.(APIStatus) | ||||
| 	if !ok || apierr == nil || apierr.Status().Details == nil { | ||||
| 		return metav1.StatusCause{}, false | ||||
| 	} | ||||
| 	for _, cause := range apierr.Status().Details.Causes { | ||||
| 		if cause.Type == name { | ||||
| 			return cause, true | ||||
| 		} | ||||
| 	} | ||||
| 	return metav1.StatusCause{}, false | ||||
| } | ||||
| 
 | ||||
| // UnexpectedObjectError can be returned by FromObject if it's passed a non-status object.
 | ||||
| type UnexpectedObjectError struct { | ||||
| 	Object runtime.Object | ||||
|  | @ -199,6 +223,7 @@ func NewApplyConflict(causes []metav1.StatusCause, message string) *StatusError | |||
| } | ||||
| 
 | ||||
| // NewGone returns an error indicating the item no longer available at the server and no forwarding address is known.
 | ||||
| // DEPRECATED: Please use NewResourceExpired instead.
 | ||||
| func NewGone(message string) *StatusError { | ||||
| 	return &StatusError{metav1.Status{ | ||||
| 		Status:  metav1.StatusFailure, | ||||
|  | @ -349,7 +374,7 @@ func NewTimeoutError(message string, retryAfterSeconds int) *StatusError { | |||
| func NewTooManyRequestsError(message string) *StatusError { | ||||
| 	return &StatusError{metav1.Status{ | ||||
| 		Status:  metav1.StatusFailure, | ||||
| 		Code:    StatusTooManyRequests, | ||||
| 		Code:    http.StatusTooManyRequests, | ||||
| 		Reason:  metav1.StatusReasonTooManyRequests, | ||||
| 		Message: fmt.Sprintf("Too many requests: %s", message), | ||||
| 	}} | ||||
|  |  | |||
|  | @ -11,8 +11,6 @@ reviewers: | |||
| - janetkuo | ||||
| - tallclair | ||||
| - eparis | ||||
| - jbeda | ||||
| - xiang90 | ||||
| - mbohlool | ||||
| - david-mcmahon | ||||
| - goltermann | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ option go_package = "resource"; | |||
| 
 | ||||
| // Quantity is a fixed-point representation of a number. | ||||
| // It provides convenient marshaling/unmarshaling in JSON and YAML, | ||||
| // in addition to String() and Int64() accessors. | ||||
| // in addition to String() and AsInt64() accessors. | ||||
| // | ||||
| // The serialization format is: | ||||
| // | ||||
|  |  | |||
|  | @ -29,7 +29,7 @@ import ( | |||
| 
 | ||||
| // Quantity is a fixed-point representation of a number.
 | ||||
| // It provides convenient marshaling/unmarshaling in JSON and YAML,
 | ||||
| // in addition to String() and Int64() accessors.
 | ||||
| // in addition to String() and AsInt64() accessors.
 | ||||
| //
 | ||||
| // The serialization format is:
 | ||||
| //
 | ||||
|  | @ -726,21 +726,3 @@ func (q *Quantity) SetScaled(value int64, scale Scale) { | |||
| 	q.d.Dec = nil | ||||
| 	q.i = int64Amount{value: value, scale: scale} | ||||
| } | ||||
| 
 | ||||
| // Copy is a convenience function that makes a deep copy for you. Non-deep
 | ||||
| // copies of quantities share pointers and you will regret that.
 | ||||
| func (q *Quantity) Copy() *Quantity { | ||||
| 	if q.d.Dec == nil { | ||||
| 		return &Quantity{ | ||||
| 			s:      q.s, | ||||
| 			i:      q.i, | ||||
| 			Format: q.Format, | ||||
| 		} | ||||
| 	} | ||||
| 	tmp := &inf.Dec{} | ||||
| 	return &Quantity{ | ||||
| 		s:      q.s, | ||||
| 		d:      infDecAmount{tmp.Set(q.d.Dec)}, | ||||
| 		Format: q.Format, | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -30,4 +30,3 @@ reviewers: | |||
| - mqliang | ||||
| - kevin-wangzefeng | ||||
| - jianhuiz | ||||
| - feihujiang | ||||
|  |  | |||
|  | @ -22,7 +22,7 @@ import ( | |||
| 
 | ||||
| // IsControlledBy checks if the  object has a controllerRef set to the given owner
 | ||||
| func IsControlledBy(obj Object, owner Object) bool { | ||||
| 	ref := GetControllerOf(obj) | ||||
| 	ref := GetControllerOfNoCopy(obj) | ||||
| 	if ref == nil { | ||||
| 		return false | ||||
| 	} | ||||
|  | @ -31,9 +31,20 @@ func IsControlledBy(obj Object, owner Object) bool { | |||
| 
 | ||||
| // GetControllerOf returns a pointer to a copy of the controllerRef if controllee has a controller
 | ||||
| func GetControllerOf(controllee Object) *OwnerReference { | ||||
| 	for _, ref := range controllee.GetOwnerReferences() { | ||||
| 		if ref.Controller != nil && *ref.Controller { | ||||
| 			return &ref | ||||
| 	ref := GetControllerOfNoCopy(controllee) | ||||
| 	if ref == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	cp := *ref | ||||
| 	return &cp | ||||
| } | ||||
| 
 | ||||
| // GetControllerOf returns a pointer to the controllerRef if controllee has a controller
 | ||||
| func GetControllerOfNoCopy(controllee Object) *OwnerReference { | ||||
| 	refs := controllee.GetOwnerReferences() | ||||
| 	for i := range refs { | ||||
| 		if refs[i].Controller != nil && *refs[i].Controller { | ||||
| 			return &refs[i] | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ package v1 | |||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"net/url" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 
 | ||||
|  | @ -26,6 +27,7 @@ import ( | |||
| 	"k8s.io/apimachinery/pkg/fields" | ||||
| 	"k8s.io/apimachinery/pkg/labels" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/types" | ||||
| 	"k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
| 
 | ||||
|  | @ -35,12 +37,17 @@ func AddConversionFuncs(scheme *runtime.Scheme) error { | |||
| 
 | ||||
| 		Convert_v1_ListMeta_To_v1_ListMeta, | ||||
| 
 | ||||
| 		Convert_v1_DeleteOptions_To_v1_DeleteOptions, | ||||
| 
 | ||||
| 		Convert_intstr_IntOrString_To_intstr_IntOrString, | ||||
| 		Convert_Pointer_intstr_IntOrString_To_intstr_IntOrString, | ||||
| 		Convert_intstr_IntOrString_To_Pointer_intstr_IntOrString, | ||||
| 
 | ||||
| 		Convert_Pointer_v1_Duration_To_v1_Duration, | ||||
| 		Convert_v1_Duration_To_Pointer_v1_Duration, | ||||
| 
 | ||||
| 		Convert_Slice_string_To_v1_Time, | ||||
| 		Convert_Slice_string_To_Pointer_v1_Time, | ||||
| 
 | ||||
| 		Convert_v1_Time_To_v1_Time, | ||||
| 		Convert_v1_MicroTime_To_v1_MicroTime, | ||||
|  | @ -76,7 +83,7 @@ func AddConversionFuncs(scheme *runtime.Scheme) error { | |||
| 
 | ||||
| 		Convert_Slice_string_To_Slice_int32, | ||||
| 
 | ||||
| 		Convert_Slice_string_To_v1_DeletionPropagation, | ||||
| 		Convert_Slice_string_To_Pointer_v1_DeletionPropagation, | ||||
| 
 | ||||
| 		Convert_Slice_string_To_v1_IncludeObjectPolicy, | ||||
| 	) | ||||
|  | @ -194,12 +201,33 @@ func Convert_v1_ListMeta_To_v1_ListMeta(in, out *ListMeta, s conversion.Scope) e | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-fn=copy-only
 | ||||
| func Convert_v1_DeleteOptions_To_v1_DeleteOptions(in, out *DeleteOptions, s conversion.Scope) error { | ||||
| 	*out = *in | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-fn=copy-only
 | ||||
| func Convert_intstr_IntOrString_To_intstr_IntOrString(in, out *intstr.IntOrString, s conversion.Scope) error { | ||||
| 	*out = *in | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_Pointer_intstr_IntOrString_To_intstr_IntOrString(in **intstr.IntOrString, out *intstr.IntOrString, s conversion.Scope) error { | ||||
| 	if *in == nil { | ||||
| 		*out = intstr.IntOrString{} // zero value
 | ||||
| 		return nil | ||||
| 	} | ||||
| 	*out = **in // copy
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_intstr_IntOrString_To_Pointer_intstr_IntOrString(in *intstr.IntOrString, out **intstr.IntOrString, s conversion.Scope) error { | ||||
| 	temp := *in // copy
 | ||||
| 	*out = &temp | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-fn=copy-only
 | ||||
| func Convert_v1_Time_To_v1_Time(in *Time, out *Time, s conversion.Scope) error { | ||||
| 	// Cannot deep copy these, because time.Time has unexported fields.
 | ||||
|  | @ -230,14 +258,30 @@ func Convert_v1_Duration_To_Pointer_v1_Duration(in *Duration, out **Duration, s | |||
| } | ||||
| 
 | ||||
| // Convert_Slice_string_To_v1_Time allows converting a URL query parameter value
 | ||||
| func Convert_Slice_string_To_v1_Time(input *[]string, out *Time, s conversion.Scope) error { | ||||
| func Convert_Slice_string_To_v1_Time(in *[]string, out *Time, s conversion.Scope) error { | ||||
| 	str := "" | ||||
| 	if len(*input) > 0 { | ||||
| 		str = (*input)[0] | ||||
| 	if len(*in) > 0 { | ||||
| 		str = (*in)[0] | ||||
| 	} | ||||
| 	return out.UnmarshalQueryParameter(str) | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_Pointer_v1_Time(in *[]string, out **Time, s conversion.Scope) error { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	str := "" | ||||
| 	if len(*in) > 0 { | ||||
| 		str = (*in)[0] | ||||
| 	} | ||||
| 	temp := Time{} | ||||
| 	if err := temp.UnmarshalQueryParameter(str); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*out = &temp | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_string_To_labels_Selector(in *string, out *labels.Selector, s conversion.Scope) error { | ||||
| 	selector, err := labels.Parse(*in) | ||||
| 	if err != nil { | ||||
|  | @ -310,20 +354,53 @@ func Convert_Slice_string_To_Slice_int32(in *[]string, out *[]int32, s conversio | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_Slice_string_To_v1_DeletionPropagation allows converting a URL query parameter propagationPolicy
 | ||||
| func Convert_Slice_string_To_v1_DeletionPropagation(input *[]string, out *DeletionPropagation, s conversion.Scope) error { | ||||
| 	if len(*input) > 0 { | ||||
| 		*out = DeletionPropagation((*input)[0]) | ||||
| // Convert_Slice_string_To_Pointer_v1_DeletionPropagation allows converting a URL query parameter propagationPolicy
 | ||||
| func Convert_Slice_string_To_Pointer_v1_DeletionPropagation(in *[]string, out **DeletionPropagation, s conversion.Scope) error { | ||||
| 	var str string | ||||
| 	if len(*in) > 0 { | ||||
| 		str = (*in)[0] | ||||
| 	} else { | ||||
| 		*out = "" | ||||
| 		str = "" | ||||
| 	} | ||||
| 	temp := DeletionPropagation(str) | ||||
| 	*out = &temp | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_Slice_string_To_v1_IncludeObjectPolicy allows converting a URL query parameter value
 | ||||
| func Convert_Slice_string_To_v1_IncludeObjectPolicy(input *[]string, out *IncludeObjectPolicy, s conversion.Scope) error { | ||||
| 	if len(*input) > 0 { | ||||
| 		*out = IncludeObjectPolicy((*input)[0]) | ||||
| func Convert_Slice_string_To_v1_IncludeObjectPolicy(in *[]string, out *IncludeObjectPolicy, s conversion.Scope) error { | ||||
| 	if len(*in) > 0 { | ||||
| 		*out = IncludeObjectPolicy((*in)[0]) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_DeleteOptions allows converting a URL to DeleteOptions.
 | ||||
| func Convert_url_Values_To_v1_DeleteOptions(in *url.Values, out *DeleteOptions, s conversion.Scope) error { | ||||
| 	if err := autoConvert_url_Values_To_v1_DeleteOptions(in, out, s); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	uid := types.UID("") | ||||
| 	if values, ok := (*in)["uid"]; ok && len(values) > 0 { | ||||
| 		uid = types.UID(values[0]) | ||||
| 	} | ||||
| 
 | ||||
| 	resourceVersion := "" | ||||
| 	if values, ok := (*in)["resourceVersion"]; ok && len(values) > 0 { | ||||
| 		resourceVersion = values[0] | ||||
| 	} | ||||
| 
 | ||||
| 	if len(uid) > 0 || len(resourceVersion) > 0 { | ||||
| 		if out.Preconditions == nil { | ||||
| 			out.Preconditions = &Preconditions{} | ||||
| 		} | ||||
| 		if len(uid) > 0 { | ||||
| 			out.Preconditions.UID = &uid | ||||
| 		} | ||||
| 		if len(resourceVersion) > 0 { | ||||
| 			out.Preconditions.ResourceVersion = &resourceVersion | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ See the License for the specific language governing permissions and | |||
| limitations under the License. | ||||
| */ | ||||
| 
 | ||||
| // +k8s:conversion-gen=false
 | ||||
| // +k8s:deepcopy-gen=package
 | ||||
| // +k8s:openapi-gen=true
 | ||||
| // +k8s:defaulter-gen=TypeMeta
 | ||||
|  |  | |||
|  | @ -1,88 +0,0 @@ | |||
| /* | ||||
| Copyright 2019 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 v1 | ||||
| 
 | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| ) | ||||
| 
 | ||||
| // Fields is declared in types.go
 | ||||
| 
 | ||||
| // ProtoFields is a struct that is equivalent to Fields, but intended for
 | ||||
| // protobuf marshalling/unmarshalling. It is generated into a serialization
 | ||||
| // that matches Fields. Do not use in Go structs.
 | ||||
| type ProtoFields struct { | ||||
| 	// Map is the representation used in the alpha version of this API
 | ||||
| 	Map map[string]Fields `json:"-" protobuf:"bytes,1,rep,name=map"` | ||||
| 
 | ||||
| 	// Raw is the underlying serialization of this object.
 | ||||
| 	Raw []byte `json:"-" protobuf:"bytes,2,opt,name=raw"` | ||||
| } | ||||
| 
 | ||||
| // ProtoFields returns the Fields as a new ProtoFields value.
 | ||||
| func (m *Fields) ProtoFields() *ProtoFields { | ||||
| 	if m == nil { | ||||
| 		return &ProtoFields{} | ||||
| 	} | ||||
| 	return &ProtoFields{ | ||||
| 		Raw: m.Raw, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Size implements the protobuf marshalling interface.
 | ||||
| func (m *Fields) Size() (n int) { | ||||
| 	return m.ProtoFields().Size() | ||||
| } | ||||
| 
 | ||||
| // Unmarshal implements the protobuf marshalling interface.
 | ||||
| func (m *Fields) Unmarshal(data []byte) error { | ||||
| 	if len(data) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	p := ProtoFields{} | ||||
| 	if err := p.Unmarshal(data); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if len(p.Map) == 0 { | ||||
| 		return json.Unmarshal(p.Raw, &m) | ||||
| 	} | ||||
| 	b, err := json.Marshal(&p.Map) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return json.Unmarshal(b, &m) | ||||
| } | ||||
| 
 | ||||
| // Marshal implements the protobuf marshaling interface.
 | ||||
| func (m *Fields) Marshal() (data []byte, err error) { | ||||
| 	return m.ProtoFields().Marshal() | ||||
| } | ||||
| 
 | ||||
| // MarshalTo implements the protobuf marshaling interface.
 | ||||
| func (m *Fields) MarshalTo(data []byte) (int, error) { | ||||
| 	return m.ProtoFields().MarshalTo(data) | ||||
| } | ||||
| 
 | ||||
| // MarshalToSizedBuffer implements the protobuf reverse marshaling interface.
 | ||||
| func (m *Fields) MarshalToSizedBuffer(data []byte) (int, error) { | ||||
| 	return m.ProtoFields().MarshalToSizedBuffer(data) | ||||
| } | ||||
| 
 | ||||
| // String implements the protobuf goproto_stringer interface.
 | ||||
| func (m *Fields) String() string { | ||||
| 	return m.ProtoFields().String() | ||||
| } | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -163,6 +163,7 @@ message DeleteOptions { | |||
| 
 | ||||
|   // Must be fulfilled before a deletion is carried out. If not possible, a 409 Conflict status will be | ||||
|   // returned. | ||||
|   // +k8s:conversion-gen=false | ||||
|   // +optional | ||||
|   optional Preconditions preconditions = 2; | ||||
| 
 | ||||
|  | @ -212,7 +213,7 @@ message ExportOptions { | |||
|   optional bool exact = 2; | ||||
| } | ||||
| 
 | ||||
| // Fields stores a set of fields in a data structure like a Trie. | ||||
| // FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format. | ||||
| // | ||||
| // Each key is either a '.' representing the field itself, and will always map to an empty set, | ||||
| // or a string representing a sub-field or item. The string will follow one of these four formats: | ||||
|  | @ -223,15 +224,9 @@ message ExportOptions { | |||
| // If a key maps to an empty Fields value, the field that key represents is part of the set. | ||||
| // | ||||
| // The exact format is defined in sigs.k8s.io/structured-merge-diff | ||||
| // +protobuf.options.marshal=false | ||||
| // +protobuf.as=ProtoFields | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| message Fields { | ||||
|   // Map is the representation used in the alpha version of this API | ||||
|   map<string, Fields> map = 1; | ||||
| 
 | ||||
| message FieldsV1 { | ||||
|   // Raw is the underlying serialization of this object. | ||||
|   optional bytes raw = 2; | ||||
|   optional bytes Raw = 1; | ||||
| } | ||||
| 
 | ||||
| // GetOptions is the standard query options to the standard REST get call. | ||||
|  | @ -345,7 +340,7 @@ message LabelSelectorRequirement { | |||
| // List holds a list of objects, which may not be known by the server. | ||||
| message List { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -371,7 +366,7 @@ message ListMeta { | |||
|   // Value must be treated as opaque by clients and passed unmodified back to the server. | ||||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency | ||||
|   // +optional | ||||
|   optional string resourceVersion = 2; | ||||
| 
 | ||||
|  | @ -393,9 +388,6 @@ message ListMeta { | |||
|   // Servers older than v1.15 do not set this field. | ||||
|   // The intended use of the remainingItemCount is *estimating* the size of a collection. Clients | ||||
|   // should not rely on the remainingItemCount to be set or to be exact. | ||||
|   // | ||||
|   // This field is alpha and can be changed or removed without notice. | ||||
|   // | ||||
|   // +optional | ||||
|   optional int64 remainingItemCount = 4; | ||||
| } | ||||
|  | @ -425,9 +417,6 @@ message ListOptions { | |||
|   // If this is not a watch, this field is ignored. | ||||
|   // If the feature gate WatchBookmarks is not enabled in apiserver, | ||||
|   // this field is ignored. | ||||
|   // | ||||
|   // This field is beta. | ||||
|   // | ||||
|   // +optional | ||||
|   optional bool allowWatchBookmarks = 9; | ||||
| 
 | ||||
|  | @ -500,9 +489,13 @@ message ManagedFieldsEntry { | |||
|   // +optional | ||||
|   optional Time time = 4; | ||||
| 
 | ||||
|   // Fields identifies a set of fields. | ||||
|   // FieldsType is the discriminator for the different fields format and version. | ||||
|   // There is currently only one possible value: "FieldsV1" | ||||
|   optional string fieldsType = 6; | ||||
| 
 | ||||
|   // FieldsV1 holds the first JSON version format as described in the "FieldsV1" type. | ||||
|   // +optional | ||||
|   optional Fields fields = 5; | ||||
|   optional FieldsV1 fieldsV1 = 7; | ||||
| } | ||||
| 
 | ||||
| // MicroTime is version of Time with microsecond level precision. | ||||
|  | @ -549,7 +542,7 @@ message ObjectMeta { | |||
|   // should retry (optionally after the time indicated in the Retry-After header). | ||||
|   // | ||||
|   // Applied only if Name is not specified. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#idempotency | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency | ||||
|   // +optional | ||||
|   optional string generateName = 2; | ||||
| 
 | ||||
|  | @ -593,7 +586,7 @@ message ObjectMeta { | |||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // Value must be treated as opaque by clients and . | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency | ||||
|   // +optional | ||||
|   optional string resourceVersion = 6; | ||||
| 
 | ||||
|  | @ -609,7 +602,7 @@ message ObjectMeta { | |||
|   // Populated by the system. | ||||
|   // Read-only. | ||||
|   // Null for lists. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional Time creationTimestamp = 8; | ||||
| 
 | ||||
|  | @ -630,7 +623,7 @@ message ObjectMeta { | |||
|   // | ||||
|   // Populated by the system when a graceful deletion is requested. | ||||
|   // Read-only. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional Time deletionTimestamp = 9; | ||||
| 
 | ||||
|  | @ -668,6 +661,15 @@ message ObjectMeta { | |||
|   // is an identifier for the responsible component that will remove the entry | ||||
|   // from the list. If the deletionTimestamp of the object is non-nil, entries | ||||
|   // in this list can only be removed. | ||||
|   // Finalizers may be processed and removed in any order.  Order is NOT enforced | ||||
|   // because it introduces significant risk of stuck finalizers. | ||||
|   // finalizers is a shared field, any actor with permission can reorder it. | ||||
|   // If the finalizer list is processed in order, then this can lead to a situation | ||||
|   // in which the component responsible for the first finalizer in the list is | ||||
|   // waiting for a signal (field value, external system, or other) produced by a | ||||
|   // component responsible for a finalizer later in the list, resulting in a deadlock. | ||||
|   // Without enforced ordering finalizers are free to order amongst themselves and | ||||
|   // are not vulnerable to ordering changes in the list. | ||||
|   // +optional | ||||
|   // +patchStrategy=merge | ||||
|   repeated string finalizers = 14; | ||||
|  | @ -686,8 +688,6 @@ message ObjectMeta { | |||
|   // "ci-cd". The set of fields is always in the version that the | ||||
|   // workflow used when modifying the object. | ||||
|   // | ||||
|   // This field is alpha and can be changed or removed without notice. | ||||
|   // | ||||
|   // +optional | ||||
|   repeated ManagedFieldsEntry managedFields = 17; | ||||
| } | ||||
|  | @ -700,7 +700,7 @@ message OwnerReference { | |||
|   optional string apiVersion = 5; | ||||
| 
 | ||||
|   // Kind of the referent. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   optional string kind = 1; | ||||
| 
 | ||||
|   // Name of the referent. | ||||
|  | @ -730,7 +730,7 @@ message OwnerReference { | |||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
| message PartialObjectMetadata { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional ObjectMeta metadata = 1; | ||||
| } | ||||
|  | @ -739,7 +739,7 @@ message PartialObjectMetadata { | |||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
| message PartialObjectMetadataList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional ListMeta metadata = 1; | ||||
| 
 | ||||
|  | @ -790,17 +790,6 @@ message Preconditions { | |||
|   optional string resourceVersion = 2; | ||||
| } | ||||
| 
 | ||||
| // ProtoFields is a struct that is equivalent to Fields, but intended for | ||||
| // protobuf marshalling/unmarshalling. It is generated into a serialization | ||||
| // that matches Fields. Do not use in Go structs. | ||||
| message ProtoFields { | ||||
|   // Map is the representation used in the alpha version of this API | ||||
|   map<string, Fields> map = 1; | ||||
| 
 | ||||
|   // Raw is the underlying serialization of this object. | ||||
|   optional bytes raw = 2; | ||||
| } | ||||
| 
 | ||||
| // RootPaths lists the paths available at root. | ||||
| // For example: "/healthz", "/apis". | ||||
| message RootPaths { | ||||
|  | @ -821,13 +810,13 @@ message ServerAddressByClientCIDR { | |||
| // Status is a return value for calls that don't return other objects. | ||||
| message Status { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional ListMeta metadata = 1; | ||||
| 
 | ||||
|   // Status of the operation. | ||||
|   // One of: "Success" or "Failure". | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional string status = 2; | ||||
| 
 | ||||
|  | @ -898,7 +887,7 @@ message StatusDetails { | |||
| 
 | ||||
|   // The kind attribute of the resource associated with the status StatusReason. | ||||
|   // On some operations may differ from the requested resource Kind. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional string kind = 3; | ||||
| 
 | ||||
|  | @ -976,14 +965,14 @@ message TypeMeta { | |||
|   // Servers may infer this from the endpoint the client submits requests to. | ||||
|   // Cannot be updated. | ||||
|   // In CamelCase. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional string kind = 1; | ||||
| 
 | ||||
|   // APIVersion defines the versioned schema of this representation of an object. | ||||
|   // Servers should convert recognized schemas to the latest internal value, and | ||||
|   // may reject unrecognized values. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources | ||||
|   // +optional | ||||
|   optional string apiVersion = 2; | ||||
| } | ||||
|  |  | |||
|  | @ -258,7 +258,7 @@ func ResetObjectMetaForStatus(meta, existingMeta Object) { | |||
| // MarshalJSON implements json.Marshaler
 | ||||
| // MarshalJSON may get called on pointers or values, so implement MarshalJSON on value.
 | ||||
| // http://stackoverflow.com/questions/21390979/custom-marshaljson-never-gets-called-in-go
 | ||||
| func (f Fields) MarshalJSON() ([]byte, error) { | ||||
| func (f FieldsV1) MarshalJSON() ([]byte, error) { | ||||
| 	if f.Raw == nil { | ||||
| 		return []byte("null"), nil | ||||
| 	} | ||||
|  | @ -266,7 +266,7 @@ func (f Fields) MarshalJSON() ([]byte, error) { | |||
| } | ||||
| 
 | ||||
| // UnmarshalJSON implements json.Unmarshaler
 | ||||
| func (f *Fields) UnmarshalJSON(b []byte) error { | ||||
| func (f *FieldsV1) UnmarshalJSON(b []byte) error { | ||||
| 	if f == nil { | ||||
| 		return errors.New("metav1.Fields: UnmarshalJSON on nil pointer") | ||||
| 	} | ||||
|  | @ -276,5 +276,5 @@ func (f *Fields) UnmarshalJSON(b []byte) error { | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| var _ json.Marshaler = Fields{} | ||||
| var _ json.Unmarshaler = &Fields{} | ||||
| var _ json.Marshaler = FieldsV1{} | ||||
| var _ json.Unmarshaler = &FieldsV1{} | ||||
|  |  | |||
|  | @ -25,6 +25,13 @@ import ( | |||
| // GroupName is the group name for this API.
 | ||||
| const GroupName = "meta.k8s.io" | ||||
| 
 | ||||
| var ( | ||||
| 	// localSchemeBuilder is used to make compiler happy for autogenerated
 | ||||
| 	// conversions. However, it's not used.
 | ||||
| 	schemeBuilder      runtime.SchemeBuilder | ||||
| 	localSchemeBuilder = &schemeBuilder | ||||
| ) | ||||
| 
 | ||||
| // SchemeGroupVersion is group version used to register these objects
 | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
| 
 | ||||
|  | @ -40,6 +47,31 @@ func Kind(kind string) schema.GroupKind { | |||
| 	return SchemeGroupVersion.WithKind(kind).GroupKind() | ||||
| } | ||||
| 
 | ||||
| // scheme is the registry for the common types that adhere to the meta v1 API spec.
 | ||||
| var scheme = runtime.NewScheme() | ||||
| 
 | ||||
| // ParameterCodec knows about query parameters used with the meta v1 API spec.
 | ||||
| var ParameterCodec = runtime.NewParameterCodec(scheme) | ||||
| 
 | ||||
| func addEventConversionFuncs(scheme *runtime.Scheme) error { | ||||
| 	return scheme.AddConversionFuncs( | ||||
| 		Convert_v1_WatchEvent_To_watch_Event, | ||||
| 		Convert_v1_InternalEvent_To_v1_WatchEvent, | ||||
| 		Convert_watch_Event_To_v1_WatchEvent, | ||||
| 		Convert_v1_WatchEvent_To_v1_InternalEvent, | ||||
| 	) | ||||
| } | ||||
| 
 | ||||
| var optionsTypes = []runtime.Object{ | ||||
| 	&ListOptions{}, | ||||
| 	&ExportOptions{}, | ||||
| 	&GetOptions{}, | ||||
| 	&DeleteOptions{}, | ||||
| 	&CreateOptions{}, | ||||
| 	&UpdateOptions{}, | ||||
| 	&PatchOptions{}, | ||||
| } | ||||
| 
 | ||||
| // AddToGroupVersion registers common meta types into schemas.
 | ||||
| func AddToGroupVersion(scheme *runtime.Scheme, groupVersion schema.GroupVersion) { | ||||
| 	scheme.AddKnownTypeWithName(groupVersion.WithKind(WatchEventKind), &WatchEvent{}) | ||||
|  | @ -48,21 +80,7 @@ func AddToGroupVersion(scheme *runtime.Scheme, groupVersion schema.GroupVersion) | |||
| 		&InternalEvent{}, | ||||
| 	) | ||||
| 	// Supports legacy code paths, most callers should use metav1.ParameterCodec for now
 | ||||
| 	scheme.AddKnownTypes(groupVersion, | ||||
| 		&ListOptions{}, | ||||
| 		&ExportOptions{}, | ||||
| 		&GetOptions{}, | ||||
| 		&DeleteOptions{}, | ||||
| 		&CreateOptions{}, | ||||
| 		&UpdateOptions{}, | ||||
| 		&PatchOptions{}, | ||||
| 	) | ||||
| 	utilruntime.Must(scheme.AddConversionFuncs( | ||||
| 		Convert_v1_WatchEvent_To_watch_Event, | ||||
| 		Convert_v1_InternalEvent_To_v1_WatchEvent, | ||||
| 		Convert_watch_Event_To_v1_WatchEvent, | ||||
| 		Convert_v1_WatchEvent_To_v1_InternalEvent, | ||||
| 	)) | ||||
| 	scheme.AddKnownTypes(groupVersion, optionsTypes...) | ||||
| 	// Register Unversioned types under their own special group
 | ||||
| 	scheme.AddUnversionedTypes(Unversioned, | ||||
| 		&Status{}, | ||||
|  | @ -72,36 +90,14 @@ func AddToGroupVersion(scheme *runtime.Scheme, groupVersion schema.GroupVersion) | |||
| 		&APIResourceList{}, | ||||
| 	) | ||||
| 
 | ||||
| 	utilruntime.Must(addEventConversionFuncs(scheme)) | ||||
| 
 | ||||
| 	// register manually. This usually goes through the SchemeBuilder, which we cannot use here.
 | ||||
| 	utilruntime.Must(AddConversionFuncs(scheme)) | ||||
| 	utilruntime.Must(RegisterDefaults(scheme)) | ||||
| } | ||||
| 
 | ||||
| // scheme is the registry for the common types that adhere to the meta v1 API spec.
 | ||||
| var scheme = runtime.NewScheme() | ||||
| 
 | ||||
| // ParameterCodec knows about query parameters used with the meta v1 API spec.
 | ||||
| var ParameterCodec = runtime.NewParameterCodec(scheme) | ||||
| 
 | ||||
| func init() { | ||||
| 	scheme.AddUnversionedTypes(SchemeGroupVersion, | ||||
| 		&ListOptions{}, | ||||
| 		&ExportOptions{}, | ||||
| 		&GetOptions{}, | ||||
| 		&DeleteOptions{}, | ||||
| 		&CreateOptions{}, | ||||
| 		&UpdateOptions{}, | ||||
| 		&PatchOptions{}, | ||||
| 	) | ||||
| 
 | ||||
| 	if err := AddMetaToScheme(scheme); err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 
 | ||||
| 	// register manually. This usually goes through the SchemeBuilder, which we cannot use here.
 | ||||
| 	utilruntime.Must(RegisterDefaults(scheme)) | ||||
| } | ||||
| 
 | ||||
| // AddMetaToScheme registers base meta types into schemas.
 | ||||
| func AddMetaToScheme(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Table{}, | ||||
|  | @ -114,3 +110,12 @@ func AddMetaToScheme(scheme *runtime.Scheme) error { | |||
| 		Convert_Slice_string_To_v1_IncludeObjectPolicy, | ||||
| 	) | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	scheme.AddUnversionedTypes(SchemeGroupVersion, optionsTypes...) | ||||
| 
 | ||||
| 	utilruntime.Must(AddMetaToScheme(scheme)) | ||||
| 
 | ||||
| 	// register manually. This usually goes through the SchemeBuilder, which we cannot use here.
 | ||||
| 	utilruntime.Must(RegisterDefaults(scheme)) | ||||
| } | ||||
|  |  | |||
|  | @ -43,14 +43,14 @@ type TypeMeta struct { | |||
| 	// Servers may infer this from the endpoint the client submits requests to.
 | ||||
| 	// Cannot be updated.
 | ||||
| 	// In CamelCase.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` | ||||
| 
 | ||||
| 	// APIVersion defines the versioned schema of this representation of an object.
 | ||||
| 	// Servers should convert recognized schemas to the latest internal value, and
 | ||||
| 	// may reject unrecognized values.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
 | ||||
| 	// +optional
 | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt,name=apiVersion"` | ||||
| } | ||||
|  | @ -73,7 +73,7 @@ type ListMeta struct { | |||
| 	// Value must be treated as opaque by clients and passed unmodified back to the server.
 | ||||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// +optional
 | ||||
| 	ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,2,opt,name=resourceVersion"` | ||||
| 
 | ||||
|  | @ -95,9 +95,6 @@ type ListMeta struct { | |||
| 	// Servers older than v1.15 do not set this field.
 | ||||
| 	// The intended use of the remainingItemCount is *estimating* the size of a collection. Clients
 | ||||
| 	// should not rely on the remainingItemCount to be set or to be exact.
 | ||||
| 	//
 | ||||
| 	// This field is alpha and can be changed or removed without notice.
 | ||||
| 	//
 | ||||
| 	// +optional
 | ||||
| 	RemainingItemCount *int64 `json:"remainingItemCount,omitempty" protobuf:"bytes,4,opt,name=remainingItemCount"` | ||||
| } | ||||
|  | @ -134,7 +131,7 @@ type ObjectMeta struct { | |||
| 	// should retry (optionally after the time indicated in the Retry-After header).
 | ||||
| 	//
 | ||||
| 	// Applied only if Name is not specified.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#idempotency
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency
 | ||||
| 	// +optional
 | ||||
| 	GenerateName string `json:"generateName,omitempty" protobuf:"bytes,2,opt,name=generateName"` | ||||
| 
 | ||||
|  | @ -178,7 +175,7 @@ type ObjectMeta struct { | |||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// Value must be treated as opaque by clients and .
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency
 | ||||
| 	// +optional
 | ||||
| 	ResourceVersion string `json:"resourceVersion,omitempty" protobuf:"bytes,6,opt,name=resourceVersion"` | ||||
| 
 | ||||
|  | @ -194,7 +191,7 @@ type ObjectMeta struct { | |||
| 	// Populated by the system.
 | ||||
| 	// Read-only.
 | ||||
| 	// Null for lists.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	CreationTimestamp Time `json:"creationTimestamp,omitempty" protobuf:"bytes,8,opt,name=creationTimestamp"` | ||||
| 
 | ||||
|  | @ -215,7 +212,7 @@ type ObjectMeta struct { | |||
| 	//
 | ||||
| 	// Populated by the system when a graceful deletion is requested.
 | ||||
| 	// Read-only.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	DeletionTimestamp *Time `json:"deletionTimestamp,omitempty" protobuf:"bytes,9,opt,name=deletionTimestamp"` | ||||
| 
 | ||||
|  | @ -253,6 +250,15 @@ type ObjectMeta struct { | |||
| 	// is an identifier for the responsible component that will remove the entry
 | ||||
| 	// from the list. If the deletionTimestamp of the object is non-nil, entries
 | ||||
| 	// in this list can only be removed.
 | ||||
| 	// Finalizers may be processed and removed in any order.  Order is NOT enforced
 | ||||
| 	// because it introduces significant risk of stuck finalizers.
 | ||||
| 	// finalizers is a shared field, any actor with permission can reorder it.
 | ||||
| 	// If the finalizer list is processed in order, then this can lead to a situation
 | ||||
| 	// in which the component responsible for the first finalizer in the list is
 | ||||
| 	// waiting for a signal (field value, external system, or other) produced by a
 | ||||
| 	// component responsible for a finalizer later in the list, resulting in a deadlock.
 | ||||
| 	// Without enforced ordering finalizers are free to order amongst themselves and
 | ||||
| 	// are not vulnerable to ordering changes in the list.
 | ||||
| 	// +optional
 | ||||
| 	// +patchStrategy=merge
 | ||||
| 	Finalizers []string `json:"finalizers,omitempty" patchStrategy:"merge" protobuf:"bytes,14,rep,name=finalizers"` | ||||
|  | @ -271,8 +277,6 @@ type ObjectMeta struct { | |||
| 	// "ci-cd". The set of fields is always in the version that the
 | ||||
| 	// workflow used when modifying the object.
 | ||||
| 	//
 | ||||
| 	// This field is alpha and can be changed or removed without notice.
 | ||||
| 	//
 | ||||
| 	// +optional
 | ||||
| 	ManagedFields []ManagedFieldsEntry `json:"managedFields,omitempty" protobuf:"bytes,17,rep,name=managedFields"` | ||||
| } | ||||
|  | @ -297,7 +301,7 @@ type OwnerReference struct { | |||
| 	// API version of the referent.
 | ||||
| 	APIVersion string `json:"apiVersion" protobuf:"bytes,5,opt,name=apiVersion"` | ||||
| 	// Kind of the referent.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	Kind string `json:"kind" protobuf:"bytes,1,opt,name=kind"` | ||||
| 	// Name of the referent.
 | ||||
| 	// More info: http://kubernetes.io/docs/user-guide/identifiers#names
 | ||||
|  | @ -318,6 +322,7 @@ type OwnerReference struct { | |||
| 	BlockOwnerDeletion *bool `json:"blockOwnerDeletion,omitempty" protobuf:"varint,7,opt,name=blockOwnerDeletion"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // ListOptions is the query options to a standard REST list call.
 | ||||
|  | @ -347,9 +352,6 @@ type ListOptions struct { | |||
| 	// If this is not a watch, this field is ignored.
 | ||||
| 	// If the feature gate WatchBookmarks is not enabled in apiserver,
 | ||||
| 	// this field is ignored.
 | ||||
| 	//
 | ||||
| 	// This field is beta.
 | ||||
| 	//
 | ||||
| 	// +optional
 | ||||
| 	AllowWatchBookmarks bool `json:"allowWatchBookmarks,omitempty" protobuf:"varint,9,opt,name=allowWatchBookmarks"` | ||||
| 
 | ||||
|  | @ -400,6 +402,7 @@ type ListOptions struct { | |||
| 	Continue string `json:"continue,omitempty" protobuf:"bytes,8,opt,name=continue"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // ExportOptions is the query options to the standard REST get call.
 | ||||
|  | @ -414,6 +417,7 @@ type ExportOptions struct { | |||
| 	Exact bool `json:"exact" protobuf:"varint,2,opt,name=exact"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // GetOptions is the standard query options to the standard REST get call.
 | ||||
|  | @ -451,6 +455,7 @@ const ( | |||
| 	DryRunAll = "All" | ||||
| ) | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // DeleteOptions may be provided when deleting an API object.
 | ||||
|  | @ -466,6 +471,7 @@ type DeleteOptions struct { | |||
| 
 | ||||
| 	// Must be fulfilled before a deletion is carried out. If not possible, a 409 Conflict status will be
 | ||||
| 	// returned.
 | ||||
| 	// +k8s:conversion-gen=false
 | ||||
| 	// +optional
 | ||||
| 	Preconditions *Preconditions `json:"preconditions,omitempty" protobuf:"bytes,2,opt,name=preconditions"` | ||||
| 
 | ||||
|  | @ -496,6 +502,7 @@ type DeleteOptions struct { | |||
| 	DryRun []string `json:"dryRun,omitempty" protobuf:"bytes,5,rep,name=dryRun"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // CreateOptions may be provided when creating an API object.
 | ||||
|  | @ -519,6 +526,7 @@ type CreateOptions struct { | |||
| 	FieldManager string `json:"fieldManager,omitempty" protobuf:"bytes,3,name=fieldManager"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // PatchOptions may be provided when patching an API object.
 | ||||
|  | @ -551,6 +559,7 @@ type PatchOptions struct { | |||
| 	FieldManager string `json:"fieldManager,omitempty" protobuf:"bytes,3,name=fieldManager"` | ||||
| } | ||||
| 
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| 
 | ||||
| // UpdateOptions may be provided when updating an API object.
 | ||||
|  | @ -590,13 +599,13 @@ type Preconditions struct { | |||
| type Status struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
| 	// Status of the operation.
 | ||||
| 	// One of: "Success" or "Failure".
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
 | ||||
| 	// +optional
 | ||||
| 	Status string `json:"status,omitempty" protobuf:"bytes,2,opt,name=status"` | ||||
| 	// A human-readable description of the status of this operation.
 | ||||
|  | @ -635,7 +644,7 @@ type StatusDetails struct { | |||
| 	Group string `json:"group,omitempty" protobuf:"bytes,2,opt,name=group"` | ||||
| 	// The kind attribute of the resource associated with the status StatusReason.
 | ||||
| 	// On some operations may differ from the requested resource Kind.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	Kind string `json:"kind,omitempty" protobuf:"bytes,3,opt,name=kind"` | ||||
| 	// UID of the resource.
 | ||||
|  | @ -767,11 +776,13 @@ const ( | |||
| 	// doesn't make any sense, for example deleting a read-only object.  This is different than
 | ||||
| 	// StatusReasonInvalid above which indicates that the API call could possibly succeed, but the
 | ||||
| 	// data was invalid.  API calls that return BadRequest can never succeed.
 | ||||
| 	// Status code 400
 | ||||
| 	StatusReasonBadRequest StatusReason = "BadRequest" | ||||
| 
 | ||||
| 	// StatusReasonMethodNotAllowed means that the action the client attempted to perform on the
 | ||||
| 	// resource was not supported by the code - for instance, attempting to delete a resource that
 | ||||
| 	// can only be created. API calls that return MethodNotAllowed can never succeed.
 | ||||
| 	// Status code 405
 | ||||
| 	StatusReasonMethodNotAllowed StatusReason = "MethodNotAllowed" | ||||
| 
 | ||||
| 	// StatusReasonNotAcceptable means that the accept types indicated by the client were not acceptable
 | ||||
|  | @ -870,7 +881,7 @@ const ( | |||
| type List struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  | @ -1103,9 +1114,16 @@ type ManagedFieldsEntry struct { | |||
| 	// Time is timestamp of when these fields were set. It should always be empty if Operation is 'Apply'
 | ||||
| 	// +optional
 | ||||
| 	Time *Time `json:"time,omitempty" protobuf:"bytes,4,opt,name=time"` | ||||
| 	// Fields identifies a set of fields.
 | ||||
| 
 | ||||
| 	// Fields is tombstoned to show why 5 is a reserved protobuf tag.
 | ||||
| 	//Fields *Fields `json:"fields,omitempty" protobuf:"bytes,5,opt,name=fields,casttype=Fields"`
 | ||||
| 
 | ||||
| 	// FieldsType is the discriminator for the different fields format and version.
 | ||||
| 	// There is currently only one possible value: "FieldsV1"
 | ||||
| 	FieldsType string `json:"fieldsType,omitempty" protobuf:"bytes,6,opt,name=fieldsType"` | ||||
| 	// FieldsV1 holds the first JSON version format as described in the "FieldsV1" type.
 | ||||
| 	// +optional
 | ||||
| 	Fields *Fields `json:"fields,omitempty" protobuf:"bytes,5,opt,name=fields,casttype=Fields"` | ||||
| 	FieldsV1 *FieldsV1 `json:"fieldsV1,omitempty" protobuf:"bytes,7,opt,name=fieldsV1"` | ||||
| } | ||||
| 
 | ||||
| // ManagedFieldsOperationType is the type of operation which lead to a ManagedFieldsEntry being created.
 | ||||
|  | @ -1116,7 +1134,7 @@ const ( | |||
| 	ManagedFieldsOperationUpdate ManagedFieldsOperationType = "Update" | ||||
| ) | ||||
| 
 | ||||
| // Fields stores a set of fields in a data structure like a Trie.
 | ||||
| // FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format.
 | ||||
| //
 | ||||
| // Each key is either a '.' representing the field itself, and will always map to an empty set,
 | ||||
| // or a string representing a sub-field or item. The string will follow one of these four formats:
 | ||||
|  | @ -1127,12 +1145,9 @@ const ( | |||
| // If a key maps to an empty Fields value, the field that key represents is part of the set.
 | ||||
| //
 | ||||
| // The exact format is defined in sigs.k8s.io/structured-merge-diff
 | ||||
| // +protobuf.options.marshal=false
 | ||||
| // +protobuf.as=ProtoFields
 | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false
 | ||||
| type Fields struct { | ||||
| type FieldsV1 struct { | ||||
| 	// Raw is the underlying serialization of this object.
 | ||||
| 	Raw []byte `json:"-" protobuf:"-"` | ||||
| 	Raw []byte `json:"-" protobuf:"bytes,1,opt,name=Raw"` | ||||
| } | ||||
| 
 | ||||
| // TODO: Table does not generate to protobuf because of the interface{} - fix protobuf
 | ||||
|  | @ -1147,7 +1162,7 @@ type Fields struct { | |||
| type Table struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	ListMeta `json:"metadata,omitempty"` | ||||
| 
 | ||||
|  | @ -1257,6 +1272,7 @@ const ( | |||
| ) | ||||
| 
 | ||||
| // TableOptions are used when a Table is requested by the caller.
 | ||||
| // +k8s:conversion-gen:explicit-from=net/url.Values
 | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
 | ||||
| type TableOptions struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
|  | @ -1278,7 +1294,7 @@ type TableOptions struct { | |||
| type PartialObjectMetadata struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
 | ||||
| 	// +optional
 | ||||
| 	ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| } | ||||
|  | @ -1288,7 +1304,7 @@ type PartialObjectMetadata struct { | |||
| type PartialObjectMetadataList struct { | ||||
| 	TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata.
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
 | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
 | ||||
| 	// +optional
 | ||||
| 	ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 
 | ||||
|  |  | |||
|  | @ -119,12 +119,12 @@ func (ExportOptions) SwaggerDoc() map[string]string { | |||
| 	return map_ExportOptions | ||||
| } | ||||
| 
 | ||||
| var map_Fields = map[string]string{ | ||||
| 	"": "Fields stores a set of fields in a data structure like a Trie.\n\nEach key is either a '.' representing the field itself, and will always map to an empty set, or a string representing a sub-field or item. The string will follow one of these four formats: 'f:<name>', where <name> is the name of a field in a struct, or key in a map 'v:<value>', where <value> is the exact json formatted value of a list item 'i:<index>', where <index> is position of a item in a list 'k:<keys>', where <keys> is a map of  a list item's key fields to their unique values If a key maps to an empty Fields value, the field that key represents is part of the set.\n\nThe exact format is defined in sigs.k8s.io/structured-merge-diff", | ||||
| var map_FieldsV1 = map[string]string{ | ||||
| 	"": "FieldsV1 stores a set of fields in a data structure like a Trie, in JSON format.\n\nEach key is either a '.' representing the field itself, and will always map to an empty set, or a string representing a sub-field or item. The string will follow one of these four formats: 'f:<name>', where <name> is the name of a field in a struct, or key in a map 'v:<value>', where <value> is the exact json formatted value of a list item 'i:<index>', where <index> is position of a item in a list 'k:<keys>', where <keys> is a map of  a list item's key fields to their unique values If a key maps to an empty Fields value, the field that key represents is part of the set.\n\nThe exact format is defined in sigs.k8s.io/structured-merge-diff", | ||||
| } | ||||
| 
 | ||||
| func (Fields) SwaggerDoc() map[string]string { | ||||
| 	return map_Fields | ||||
| func (FieldsV1) SwaggerDoc() map[string]string { | ||||
| 	return map_FieldsV1 | ||||
| } | ||||
| 
 | ||||
| var map_GetOptions = map[string]string{ | ||||
|  | @ -169,7 +169,7 @@ func (LabelSelectorRequirement) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_List = map[string]string{ | ||||
| 	"":         "List holds a list of objects, which may not be known by the server.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of objects", | ||||
| } | ||||
| 
 | ||||
|  | @ -180,9 +180,9 @@ func (List) SwaggerDoc() map[string]string { | |||
| var map_ListMeta = map[string]string{ | ||||
| 	"":                   "ListMeta describes metadata that synthetic resources must have, including lists and various status objects. A resource may have only one of {ObjectMeta, ListMeta}.", | ||||
| 	"selfLink":           "selfLink is a URL representing this object. Populated by the system. Read-only.\n\nDEPRECATED Kubernetes will stop propagating this field in 1.20 release and the field is planned to be removed in 1.21 release.", | ||||
| 	"resourceVersion":    "String that identifies the server's internal version of this object that can be used by clients to determine when objects have changed. Value must be treated as opaque by clients and passed unmodified back to the server. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"resourceVersion":    "String that identifies the server's internal version of this object that can be used by clients to determine when objects have changed. Value must be treated as opaque by clients and passed unmodified back to the server. Populated by the system. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"continue":           "continue may be set if the user set a limit on the number of items returned, and indicates that the server has more data available. The value is opaque and may be used to issue another request to the endpoint that served this list to retrieve the next set of available objects. Continuing a consistent list may not be possible if the server configuration has changed or more than a few minutes have passed. The resourceVersion field returned when using this continue value will be identical to the value in the first response, unless you have received this token from an error message.", | ||||
| 	"remainingItemCount": "remainingItemCount is the number of subsequent items in the list which are not included in this list response. If the list request contained label or field selectors, then the number of remaining items is unknown and the field will be left unset and omitted during serialization. If the list is complete (either because it is not chunking or because this is the last chunk), then there are no more remaining items and this field will be left unset and omitted during serialization. Servers older than v1.15 do not set this field. The intended use of the remainingItemCount is *estimating* the size of a collection. Clients should not rely on the remainingItemCount to be set or to be exact.\n\nThis field is alpha and can be changed or removed without notice.", | ||||
| 	"remainingItemCount": "remainingItemCount is the number of subsequent items in the list which are not included in this list response. If the list request contained label or field selectors, then the number of remaining items is unknown and the field will be left unset and omitted during serialization. If the list is complete (either because it is not chunking or because this is the last chunk), then there are no more remaining items and this field will be left unset and omitted during serialization. Servers older than v1.15 do not set this field. The intended use of the remainingItemCount is *estimating* the size of a collection. Clients should not rely on the remainingItemCount to be set or to be exact.", | ||||
| } | ||||
| 
 | ||||
| func (ListMeta) SwaggerDoc() map[string]string { | ||||
|  | @ -194,7 +194,7 @@ var map_ListOptions = map[string]string{ | |||
| 	"labelSelector":       "A selector to restrict the list of returned objects by their labels. Defaults to everything.", | ||||
| 	"fieldSelector":       "A selector to restrict the list of returned objects by their fields. Defaults to everything.", | ||||
| 	"watch":               "Watch for changes to the described resources and return them as a stream of add, update, and remove notifications. Specify resourceVersion.", | ||||
| 	"allowWatchBookmarks": "allowWatchBookmarks requests watch events with type \"BOOKMARK\". Servers that do not implement bookmarks may ignore this flag and bookmarks are sent at the server's discretion. Clients should not assume bookmarks are returned at any specific interval, nor may they assume the server will send any BOOKMARK event during a session. If this is not a watch, this field is ignored. If the feature gate WatchBookmarks is not enabled in apiserver, this field is ignored.\n\nThis field is beta.", | ||||
| 	"allowWatchBookmarks": "allowWatchBookmarks requests watch events with type \"BOOKMARK\". Servers that do not implement bookmarks may ignore this flag and bookmarks are sent at the server's discretion. Clients should not assume bookmarks are returned at any specific interval, nor may they assume the server will send any BOOKMARK event during a session. If this is not a watch, this field is ignored. If the feature gate WatchBookmarks is not enabled in apiserver, this field is ignored.", | ||||
| 	"resourceVersion":     "When specified with a watch call, shows changes that occur after that particular version of a resource. Defaults to changes from the beginning of history. When specified for list: - if unset, then the result is returned from remote storage based on quorum-read flag; - if it's 0, then we simply return what we currently have in cache, no guarantee; - if set to non zero, then the result is at least as fresh as given rv.", | ||||
| 	"timeoutSeconds":      "Timeout for the list/watch call. This limits the duration of the call, regardless of any activity or inactivity.", | ||||
| 	"limit":               "limit is a maximum number of responses to return for a list call. If more items exist, the server will set the `continue` field on the list metadata to a value that can be used with the same initial query to retrieve the next set of results. Setting a limit may return fewer than the requested amount of items (up to zero items) in the event all requested objects are filtered out and clients should only use the presence of the continue field to determine whether more results are available. Servers may choose not to support the limit argument and will return all of the available results. If limit is specified and the continue field is empty, clients may assume that no more results are available. This field is not supported if watch is true.\n\nThe server guarantees that the objects returned when using continue will be identical to issuing a single list call without a limit - that is, no objects created, modified, or deleted after the first request is issued will be included in any subsequent continued requests. This is sometimes referred to as a consistent snapshot, and ensures that a client that is using limit to receive smaller chunks of a very large result can ensure they see all possible objects. If objects are updated during a chunked list the version of the object that was present at the time the first list result was calculated is returned.", | ||||
|  | @ -211,7 +211,8 @@ var map_ManagedFieldsEntry = map[string]string{ | |||
| 	"operation":  "Operation is the type of operation which lead to this ManagedFieldsEntry being created. The only valid values for this field are 'Apply' and 'Update'.", | ||||
| 	"apiVersion": "APIVersion defines the version of this resource that this field set applies to. The format is \"group/version\" just like the top-level APIVersion field. It is necessary to track the version of a field set because it cannot be automatically converted.", | ||||
| 	"time":       "Time is timestamp of when these fields were set. It should always be empty if Operation is 'Apply'", | ||||
| 	"fields":     "Fields identifies a set of fields.", | ||||
| 	"fieldsType": "FieldsType is the discriminator for the different fields format and version. There is currently only one possible value: \"FieldsV1\"", | ||||
| 	"fieldsV1":   "FieldsV1 holds the first JSON version format as described in the \"FieldsV1\" type.", | ||||
| } | ||||
| 
 | ||||
| func (ManagedFieldsEntry) SwaggerDoc() map[string]string { | ||||
|  | @ -221,21 +222,21 @@ func (ManagedFieldsEntry) SwaggerDoc() map[string]string { | |||
| var map_ObjectMeta = map[string]string{ | ||||
| 	"":                           "ObjectMeta is metadata that all persisted resources must have, which includes all objects users must create.", | ||||
| 	"name":                       "Name must be unique within a namespace. Is required when creating resources, although some resources may allow a client to request the generation of an appropriate name automatically. Name is primarily intended for creation idempotence and configuration definition. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/identifiers#names", | ||||
| 	"generateName":               "GenerateName is an optional prefix, used by the server, to generate a unique name ONLY IF the Name field has not been provided. If this field is used, the name returned to the client will be different than the name passed. This value will also be combined with a unique suffix. The provided value has the same validation rules as the Name field, and may be truncated by the length of the suffix required to make the value unique on the server.\n\nIf this field is specified and the generated name exists, the server will NOT return a 409 - instead, it will either return 201 Created or 500 with Reason ServerTimeout indicating a unique name could not be found in the time allotted, and the client should retry (optionally after the time indicated in the Retry-After header).\n\nApplied only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#idempotency", | ||||
| 	"generateName":               "GenerateName is an optional prefix, used by the server, to generate a unique name ONLY IF the Name field has not been provided. If this field is used, the name returned to the client will be different than the name passed. This value will also be combined with a unique suffix. The provided value has the same validation rules as the Name field, and may be truncated by the length of the suffix required to make the value unique on the server.\n\nIf this field is specified and the generated name exists, the server will NOT return a 409 - instead, it will either return 201 Created or 500 with Reason ServerTimeout indicating a unique name could not be found in the time allotted, and the client should retry (optionally after the time indicated in the Retry-After header).\n\nApplied only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency", | ||||
| 	"namespace":                  "Namespace defines the space within each name must be unique. An empty namespace is equivalent to the \"default\" namespace, but \"default\" is the canonical representation. Not all objects are required to be scoped to a namespace - the value of this field for those objects will be empty.\n\nMust be a DNS_LABEL. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/namespaces", | ||||
| 	"selfLink":                   "SelfLink is a URL representing this object. Populated by the system. Read-only.\n\nDEPRECATED Kubernetes will stop propagating this field in 1.20 release and the field is planned to be removed in 1.21 release.", | ||||
| 	"uid":                        "UID is the unique in time and space value for this object. It is typically generated by the server on successful creation of a resource and is not allowed to change on PUT operations.\n\nPopulated by the system. Read-only. More info: http://kubernetes.io/docs/user-guide/identifiers#uids", | ||||
| 	"resourceVersion":            "An opaque value that represents the internal version of this object that can be used by clients to determine when objects have changed. May be used for optimistic concurrency, change detection, and the watch operation on a resource or set of resources. Clients must treat these values as opaque and passed unmodified back to the server. They may only be valid for a particular resource or set of resources.\n\nPopulated by the system. Read-only. Value must be treated as opaque by clients and . More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"resourceVersion":            "An opaque value that represents the internal version of this object that can be used by clients to determine when objects have changed. May be used for optimistic concurrency, change detection, and the watch operation on a resource or set of resources. Clients must treat these values as opaque and passed unmodified back to the server. They may only be valid for a particular resource or set of resources.\n\nPopulated by the system. Read-only. Value must be treated as opaque by clients and . More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency", | ||||
| 	"generation":                 "A sequence number representing a specific generation of the desired state. Populated by the system. Read-only.", | ||||
| 	"creationTimestamp":          "CreationTimestamp is a timestamp representing the server time when this object was created. It is not guaranteed to be set in happens-before order across separate operations. Clients may not set this value. It is represented in RFC3339 form and is in UTC.\n\nPopulated by the system. Read-only. Null for lists. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"deletionTimestamp":          "DeletionTimestamp is RFC 3339 date and time at which this resource will be deleted. This field is set by the server when a graceful deletion is requested by the user, and is not directly settable by a client. The resource is expected to be deleted (no longer visible from resource lists, and not reachable by name) after the time in this field, once the finalizers list is empty. As long as the finalizers list contains items, deletion is blocked. Once the deletionTimestamp is set, this value may not be unset or be set further into the future, although it may be shortened or the resource may be deleted prior to this time. For example, a user may request that a pod is deleted in 30 seconds. The Kubelet will react by sending a graceful termination signal to the containers in the pod. After that 30 seconds, the Kubelet will send a hard termination signal (SIGKILL) to the container and after cleanup, remove the pod from the API. In the presence of network partitions, this object may still exist after this timestamp, until an administrator or automated process can determine the resource is fully terminated. If not set, graceful deletion of the object has not been requested.\n\nPopulated by the system when a graceful deletion is requested. Read-only. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"creationTimestamp":          "CreationTimestamp is a timestamp representing the server time when this object was created. It is not guaranteed to be set in happens-before order across separate operations. Clients may not set this value. It is represented in RFC3339 form and is in UTC.\n\nPopulated by the system. Read-only. Null for lists. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"deletionTimestamp":          "DeletionTimestamp is RFC 3339 date and time at which this resource will be deleted. This field is set by the server when a graceful deletion is requested by the user, and is not directly settable by a client. The resource is expected to be deleted (no longer visible from resource lists, and not reachable by name) after the time in this field, once the finalizers list is empty. As long as the finalizers list contains items, deletion is blocked. Once the deletionTimestamp is set, this value may not be unset or be set further into the future, although it may be shortened or the resource may be deleted prior to this time. For example, a user may request that a pod is deleted in 30 seconds. The Kubelet will react by sending a graceful termination signal to the containers in the pod. After that 30 seconds, the Kubelet will send a hard termination signal (SIGKILL) to the container and after cleanup, remove the pod from the API. In the presence of network partitions, this object may still exist after this timestamp, until an administrator or automated process can determine the resource is fully terminated. If not set, graceful deletion of the object has not been requested.\n\nPopulated by the system when a graceful deletion is requested. Read-only. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"deletionGracePeriodSeconds": "Number of seconds allowed for this object to gracefully terminate before it will be removed from the system. Only set when deletionTimestamp is also set. May only be shortened. Read-only.", | ||||
| 	"labels":                     "Map of string keys and values that can be used to organize and categorize (scope and select) objects. May match selectors of replication controllers and services. More info: http://kubernetes.io/docs/user-guide/labels", | ||||
| 	"annotations":                "Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects. More info: http://kubernetes.io/docs/user-guide/annotations", | ||||
| 	"ownerReferences":            "List of objects depended by this object. If ALL objects in the list have been deleted, this object will be garbage collected. If this object is managed by a controller, then an entry in this list will point to this controller, with the controller field set to true. There cannot be more than one managing controller.", | ||||
| 	"finalizers":                 "Must be empty before the object is deleted from the registry. Each entry is an identifier for the responsible component that will remove the entry from the list. If the deletionTimestamp of the object is non-nil, entries in this list can only be removed.", | ||||
| 	"finalizers":                 "Must be empty before the object is deleted from the registry. Each entry is an identifier for the responsible component that will remove the entry from the list. If the deletionTimestamp of the object is non-nil, entries in this list can only be removed. Finalizers may be processed and removed in any order.  Order is NOT enforced because it introduces significant risk of stuck finalizers. finalizers is a shared field, any actor with permission can reorder it. If the finalizer list is processed in order, then this can lead to a situation in which the component responsible for the first finalizer in the list is waiting for a signal (field value, external system, or other) produced by a component responsible for a finalizer later in the list, resulting in a deadlock. Without enforced ordering finalizers are free to order amongst themselves and are not vulnerable to ordering changes in the list.", | ||||
| 	"clusterName":                "The name of the cluster which the object belongs to. This is used to distinguish resources with same name and namespace in different clusters. This field is not set anywhere right now and apiserver is going to ignore it if set in create or update request.", | ||||
| 	"managedFields":              "ManagedFields maps workflow-id and version to the set of fields that are managed by that workflow. This is mostly for internal housekeeping, and users typically shouldn't need to set or understand this field. A workflow can be the user's name, a controller's name, or the name of a specific apply path like \"ci-cd\". The set of fields is always in the version that the workflow used when modifying the object.\n\nThis field is alpha and can be changed or removed without notice.", | ||||
| 	"managedFields":              "ManagedFields maps workflow-id and version to the set of fields that are managed by that workflow. This is mostly for internal housekeeping, and users typically shouldn't need to set or understand this field. A workflow can be the user's name, a controller's name, or the name of a specific apply path like \"ci-cd\". The set of fields is always in the version that the workflow used when modifying the object.", | ||||
| } | ||||
| 
 | ||||
| func (ObjectMeta) SwaggerDoc() map[string]string { | ||||
|  | @ -245,7 +246,7 @@ func (ObjectMeta) SwaggerDoc() map[string]string { | |||
| var map_OwnerReference = map[string]string{ | ||||
| 	"":                   "OwnerReference contains enough information to let you identify an owning object. An owning object must be in the same namespace as the dependent, or be cluster-scoped, so there is no namespace field.", | ||||
| 	"apiVersion":         "API version of the referent.", | ||||
| 	"kind":               "Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"kind":               "Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"name":               "Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names", | ||||
| 	"uid":                "UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids", | ||||
| 	"controller":         "If true, this reference points to the managing controller.", | ||||
|  | @ -258,7 +259,7 @@ func (OwnerReference) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PartialObjectMetadata = map[string]string{ | ||||
| 	"":         "PartialObjectMetadata is a generic representation of any object with ObjectMeta. It allows clients to get access to a particular ObjectMeta schema without knowing the details of the version.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| } | ||||
| 
 | ||||
| func (PartialObjectMetadata) SwaggerDoc() map[string]string { | ||||
|  | @ -267,7 +268,7 @@ func (PartialObjectMetadata) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_PartialObjectMetadataList = map[string]string{ | ||||
| 	"":         "PartialObjectMetadataList contains a list of objects containing only their metadata", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "items contains each of the included items.", | ||||
| } | ||||
| 
 | ||||
|  | @ -325,8 +326,8 @@ func (ServerAddressByClientCIDR) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Status = map[string]string{ | ||||
| 	"":         "Status is a return value for calls that don't return other objects.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"status":   "Status of the operation. One of: \"Success\" or \"Failure\". More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"status":   "Status of the operation. One of: \"Success\" or \"Failure\". More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"message":  "A human-readable description of the status of this operation.", | ||||
| 	"reason":   "A machine-readable description of why this operation is in the \"Failure\" status. If this value is empty there is no information available. A Reason clarifies an HTTP status code but does not override it.", | ||||
| 	"details":  "Extended data associated with the reason.  Each reason may define its own extended details. This field is optional and the data returned is not guaranteed to conform to any schema except that defined by the reason type.", | ||||
|  | @ -352,7 +353,7 @@ var map_StatusDetails = map[string]string{ | |||
| 	"":                  "StatusDetails is a set of additional properties that MAY be set by the server to provide additional information about a response. The Reason field of a Status object defines what attributes will be set. Clients must ignore fields that do not match the defined type of each attribute, and should assume that any attribute may be empty, invalid, or under defined.", | ||||
| 	"name":              "The name attribute of the resource associated with the status StatusReason (when there is a single name which can be described).", | ||||
| 	"group":             "The group attribute of the resource associated with the status StatusReason.", | ||||
| 	"kind":              "The kind attribute of the resource associated with the status StatusReason. On some operations may differ from the requested resource Kind. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"kind":              "The kind attribute of the resource associated with the status StatusReason. On some operations may differ from the requested resource Kind. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"uid":               "UID of the resource. (when there is a single resource which can be described). More info: http://kubernetes.io/docs/user-guide/identifiers#uids", | ||||
| 	"causes":            "The Causes array includes more details associated with the StatusReason failure. Not all StatusReasons may provide detailed causes.", | ||||
| 	"retryAfterSeconds": "If specified, the time in seconds before the operation should be retried. Some errors may indicate the client must take an alternate action - for those errors this field may indicate how long to wait before taking the alternate action.", | ||||
|  | @ -364,7 +365,7 @@ func (StatusDetails) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_Table = map[string]string{ | ||||
| 	"":                  "Table is a tabular representation of a set of API resources. The server transforms the object into a set of preferred columns for quickly reviewing the objects.", | ||||
| 	"metadata":          "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"metadata":          "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"columnDefinitions": "columnDefinitions describes each column in the returned items array. The number of cells per row will always match the number of column definitions.", | ||||
| 	"rows":              "rows is the list of items in the table.", | ||||
| } | ||||
|  | @ -420,8 +421,8 @@ func (TableRowCondition) SwaggerDoc() map[string]string { | |||
| 
 | ||||
| var map_TypeMeta = map[string]string{ | ||||
| 	"":           "TypeMeta describes an individual object in an API response or request with strings representing the type of the object and its API schema version. Structures that are versioned or persisted should inline TypeMeta.", | ||||
| 	"kind":       "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"apiVersion": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources", | ||||
| 	"kind":       "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"apiVersion": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", | ||||
| } | ||||
| 
 | ||||
| func (TypeMeta) SwaggerDoc() map[string]string { | ||||
|  |  | |||
|  | @ -27,11 +27,15 @@ import ( | |||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| 	"k8s.io/apimachinery/pkg/types" | ||||
| 	"k8s.io/apimachinery/pkg/util/json" | ||||
| 	"k8s.io/klog" | ||||
| ) | ||||
| 
 | ||||
| // NestedFieldCopy returns a deep copy of the value of a nested field.
 | ||||
| // Returns false if the value is missing.
 | ||||
| // No error is returned for a nil field.
 | ||||
| //
 | ||||
| // Note: fields passed to this function are treated as keys within the passed
 | ||||
| // object; no array/slice syntax is supported.
 | ||||
| func NestedFieldCopy(obj map[string]interface{}, fields ...string) (interface{}, bool, error) { | ||||
| 	val, found, err := NestedFieldNoCopy(obj, fields...) | ||||
| 	if !found || err != nil { | ||||
|  | @ -43,6 +47,9 @@ func NestedFieldCopy(obj map[string]interface{}, fields ...string) (interface{}, | |||
| // NestedFieldNoCopy returns a reference to a nested field.
 | ||||
| // Returns false if value is not found and an error if unable
 | ||||
| // to traverse obj.
 | ||||
| //
 | ||||
| // Note: fields passed to this function are treated as keys within the passed
 | ||||
| // object; no array/slice syntax is supported.
 | ||||
| func NestedFieldNoCopy(obj map[string]interface{}, fields ...string) (interface{}, bool, error) { | ||||
| 	var val interface{} = obj | ||||
| 
 | ||||
|  | @ -323,6 +330,8 @@ var UnstructuredJSONScheme runtime.Codec = unstructuredJSONScheme{} | |||
| 
 | ||||
| type unstructuredJSONScheme struct{} | ||||
| 
 | ||||
| const unstructuredJSONSchemeIdentifier runtime.Identifier = "unstructuredJSON" | ||||
| 
 | ||||
| func (s unstructuredJSONScheme) Decode(data []byte, _ *schema.GroupVersionKind, obj runtime.Object) (runtime.Object, *schema.GroupVersionKind, error) { | ||||
| 	var err error | ||||
| 	if obj != nil { | ||||
|  | @ -343,7 +352,14 @@ func (s unstructuredJSONScheme) Decode(data []byte, _ *schema.GroupVersionKind, | |||
| 	return obj, &gvk, nil | ||||
| } | ||||
| 
 | ||||
| func (unstructuredJSONScheme) Encode(obj runtime.Object, w io.Writer) error { | ||||
| func (s unstructuredJSONScheme) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	if co, ok := obj.(runtime.CacheableObject); ok { | ||||
| 		return co.CacheEncode(s.Identifier(), s.doEncode, w) | ||||
| 	} | ||||
| 	return s.doEncode(obj, w) | ||||
| } | ||||
| 
 | ||||
| func (unstructuredJSONScheme) doEncode(obj runtime.Object, w io.Writer) error { | ||||
| 	switch t := obj.(type) { | ||||
| 	case *Unstructured: | ||||
| 		return json.NewEncoder(w).Encode(t.Object) | ||||
|  | @ -367,6 +383,11 @@ func (unstructuredJSONScheme) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (unstructuredJSONScheme) Identifier() runtime.Identifier { | ||||
| 	return unstructuredJSONSchemeIdentifier | ||||
| } | ||||
| 
 | ||||
| func (s unstructuredJSONScheme) decode(data []byte) (runtime.Object, error) { | ||||
| 	type detector struct { | ||||
| 		Items gojson.RawMessage | ||||
|  | @ -394,12 +415,6 @@ func (s unstructuredJSONScheme) decodeInto(data []byte, obj runtime.Object) erro | |||
| 		return s.decodeToUnstructured(data, x) | ||||
| 	case *UnstructuredList: | ||||
| 		return s.decodeToList(data, x) | ||||
| 	case *runtime.VersionedObjects: | ||||
| 		o, err := s.decode(data) | ||||
| 		if err == nil { | ||||
| 			x.Objects = []runtime.Object{o} | ||||
| 		} | ||||
| 		return err | ||||
| 	default: | ||||
| 		return json.Unmarshal(data, x) | ||||
| 	} | ||||
|  | @ -454,12 +469,30 @@ func (s unstructuredJSONScheme) decodeToList(data []byte, list *UnstructuredList | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| type JSONFallbackEncoder struct { | ||||
| 	runtime.Encoder | ||||
| type jsonFallbackEncoder struct { | ||||
| 	encoder    runtime.Encoder | ||||
| 	identifier runtime.Identifier | ||||
| } | ||||
| 
 | ||||
| func (c JSONFallbackEncoder) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	err := c.Encoder.Encode(obj, w) | ||||
| func NewJSONFallbackEncoder(encoder runtime.Encoder) runtime.Encoder { | ||||
| 	result := map[string]string{ | ||||
| 		"name": "fallback", | ||||
| 		"base": string(encoder.Identifier()), | ||||
| 	} | ||||
| 	identifier, err := gojson.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		klog.Fatalf("Failed marshaling identifier for jsonFallbackEncoder: %v", err) | ||||
| 	} | ||||
| 	return &jsonFallbackEncoder{ | ||||
| 		encoder:    encoder, | ||||
| 		identifier: runtime.Identifier(identifier), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (c *jsonFallbackEncoder) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	// There is no need to handle runtime.CacheableObject, as we only
 | ||||
| 	// fallback to other encoders here.
 | ||||
| 	err := c.encoder.Encode(obj, w) | ||||
| 	if runtime.IsNotRegisteredError(err) { | ||||
| 		switch obj.(type) { | ||||
| 		case *Unstructured, *UnstructuredList: | ||||
|  | @ -468,3 +501,8 @@ func (c JSONFallbackEncoder) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	} | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (c *jsonFallbackEncoder) Identifier() runtime.Identifier { | ||||
| 	return c.identifier | ||||
| } | ||||
|  |  | |||
							
								
								
									
										523
									
								
								vendor/k8s.io/apimachinery/pkg/apis/meta/v1/zz_generated.conversion.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										523
									
								
								vendor/k8s.io/apimachinery/pkg/apis/meta/v1/zz_generated.conversion.go
								
								
									generated
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,523 @@ | |||
| // +build !ignore_autogenerated
 | ||||
| 
 | ||||
| /* | ||||
| Copyright 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. | ||||
| */ | ||||
| 
 | ||||
| // Code generated by conversion-gen. DO NOT EDIT.
 | ||||
| 
 | ||||
| package v1 | ||||
| 
 | ||||
| import ( | ||||
| 	url "net/url" | ||||
| 	unsafe "unsafe" | ||||
| 
 | ||||
| 	resource "k8s.io/apimachinery/pkg/api/resource" | ||||
| 	conversion "k8s.io/apimachinery/pkg/conversion" | ||||
| 	fields "k8s.io/apimachinery/pkg/fields" | ||||
| 	labels "k8s.io/apimachinery/pkg/labels" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||
| 	watch "k8s.io/apimachinery/pkg/watch" | ||||
| ) | ||||
| 
 | ||||
| func init() { | ||||
| 	localSchemeBuilder.Register(RegisterConversions) | ||||
| } | ||||
| 
 | ||||
| // RegisterConversions adds conversion functions to the given scheme.
 | ||||
| // Public to allow building arbitrary schemes.
 | ||||
| func RegisterConversions(s *runtime.Scheme) error { | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*CreateOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_CreateOptions(a.(*url.Values), b.(*CreateOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*DeleteOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_DeleteOptions(a.(*url.Values), b.(*DeleteOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*ExportOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_ExportOptions(a.(*url.Values), b.(*ExportOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*GetOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_GetOptions(a.(*url.Values), b.(*GetOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*ListOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_ListOptions(a.(*url.Values), b.(*ListOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*PatchOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_PatchOptions(a.(*url.Values), b.(*PatchOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*TableOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_TableOptions(a.(*url.Values), b.(*TableOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddGeneratedConversionFunc((*url.Values)(nil), (*UpdateOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_UpdateOptions(a.(*url.Values), b.(*UpdateOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*map[string]string)(nil), (*LabelSelector)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Map_string_To_string_To_v1_LabelSelector(a.(*map[string]string), b.(*LabelSelector), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**bool)(nil), (*bool)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_bool_To_bool(a.(**bool), b.(*bool), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**float64)(nil), (*float64)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_float64_To_float64(a.(**float64), b.(*float64), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**int32)(nil), (*int32)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_int32_To_int32(a.(**int32), b.(*int32), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**int64)(nil), (*int)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_int64_To_int(a.(**int64), b.(*int), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**int64)(nil), (*int64)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_int64_To_int64(a.(**int64), b.(*int64), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**intstr.IntOrString)(nil), (*intstr.IntOrString)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_intstr_IntOrString_To_intstr_IntOrString(a.(**intstr.IntOrString), b.(*intstr.IntOrString), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**string)(nil), (*string)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_string_To_string(a.(**string), b.(*string), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((**Duration)(nil), (*Duration)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Pointer_v1_Duration_To_v1_Duration(a.(**Duration), b.(*Duration), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*[]string)(nil), (**DeletionPropagation)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Slice_string_To_Pointer_v1_DeletionPropagation(a.(*[]string), b.(**DeletionPropagation), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*[]string)(nil), (**Time)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Slice_string_To_Pointer_v1_Time(a.(*[]string), b.(**Time), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*[]string)(nil), (*[]int32)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Slice_string_To_Slice_int32(a.(*[]string), b.(*[]int32), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*[]string)(nil), (*IncludeObjectPolicy)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Slice_string_To_v1_IncludeObjectPolicy(a.(*[]string), b.(*IncludeObjectPolicy), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*[]string)(nil), (*Time)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_Slice_string_To_v1_Time(a.(*[]string), b.(*Time), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*bool)(nil), (**bool)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_bool_To_Pointer_bool(a.(*bool), b.(**bool), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*fields.Selector)(nil), (*string)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_fields_Selector_To_string(a.(*fields.Selector), b.(*string), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*float64)(nil), (**float64)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_float64_To_Pointer_float64(a.(*float64), b.(**float64), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*int32)(nil), (**int32)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_int32_To_Pointer_int32(a.(*int32), b.(**int32), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*int64)(nil), (**int64)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_int64_To_Pointer_int64(a.(*int64), b.(**int64), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*int)(nil), (**int64)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_int_To_Pointer_int64(a.(*int), b.(**int64), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*intstr.IntOrString)(nil), (**intstr.IntOrString)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_intstr_IntOrString_To_Pointer_intstr_IntOrString(a.(*intstr.IntOrString), b.(**intstr.IntOrString), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*intstr.IntOrString)(nil), (*intstr.IntOrString)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_intstr_IntOrString_To_intstr_IntOrString(a.(*intstr.IntOrString), b.(*intstr.IntOrString), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*labels.Selector)(nil), (*string)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_labels_Selector_To_string(a.(*labels.Selector), b.(*string), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*resource.Quantity)(nil), (*resource.Quantity)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_resource_Quantity_To_resource_Quantity(a.(*resource.Quantity), b.(*resource.Quantity), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*string)(nil), (**string)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_string_To_Pointer_string(a.(*string), b.(**string), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*string)(nil), (*fields.Selector)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_string_To_fields_Selector(a.(*string), b.(*fields.Selector), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*string)(nil), (*labels.Selector)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_string_To_labels_Selector(a.(*string), b.(*labels.Selector), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*url.Values)(nil), (*DeleteOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_url_Values_To_v1_DeleteOptions(a.(*url.Values), b.(*DeleteOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*DeleteOptions)(nil), (*DeleteOptions)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_DeleteOptions_To_v1_DeleteOptions(a.(*DeleteOptions), b.(*DeleteOptions), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*Duration)(nil), (**Duration)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_Duration_To_Pointer_v1_Duration(a.(*Duration), b.(**Duration), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*InternalEvent)(nil), (*WatchEvent)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_InternalEvent_To_v1_WatchEvent(a.(*InternalEvent), b.(*WatchEvent), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*LabelSelector)(nil), (*map[string]string)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_LabelSelector_To_Map_string_To_string(a.(*LabelSelector), b.(*map[string]string), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*ListMeta)(nil), (*ListMeta)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_ListMeta_To_v1_ListMeta(a.(*ListMeta), b.(*ListMeta), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*MicroTime)(nil), (*MicroTime)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_MicroTime_To_v1_MicroTime(a.(*MicroTime), b.(*MicroTime), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*Time)(nil), (*Time)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_Time_To_v1_Time(a.(*Time), b.(*Time), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*TypeMeta)(nil), (*TypeMeta)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_TypeMeta_To_v1_TypeMeta(a.(*TypeMeta), b.(*TypeMeta), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*WatchEvent)(nil), (*InternalEvent)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_WatchEvent_To_v1_InternalEvent(a.(*WatchEvent), b.(*InternalEvent), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*WatchEvent)(nil), (*watch.Event)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_v1_WatchEvent_To_watch_Event(a.(*WatchEvent), b.(*watch.Event), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := s.AddConversionFunc((*watch.Event)(nil), (*WatchEvent)(nil), func(a, b interface{}, scope conversion.Scope) error { | ||||
| 		return Convert_watch_Event_To_v1_WatchEvent(a.(*watch.Event), b.(*WatchEvent), scope) | ||||
| 	}); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_CreateOptions(in *url.Values, out *CreateOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["dryRun"]; ok && len(values) > 0 { | ||||
| 		out.DryRun = *(*[]string)(unsafe.Pointer(&values)) | ||||
| 	} else { | ||||
| 		out.DryRun = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["fieldManager"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.FieldManager, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.FieldManager = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_CreateOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_CreateOptions(in *url.Values, out *CreateOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_CreateOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_DeleteOptions(in *url.Values, out *DeleteOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["gracePeriodSeconds"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_Pointer_int64(&values, &out.GracePeriodSeconds, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.GracePeriodSeconds = nil | ||||
| 	} | ||||
| 	// INFO: in.Preconditions opted out of conversion generation
 | ||||
| 	if values, ok := map[string][]string(*in)["orphanDependents"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_Pointer_bool(&values, &out.OrphanDependents, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.OrphanDependents = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["propagationPolicy"]; ok && len(values) > 0 { | ||||
| 		if err := Convert_Slice_string_To_Pointer_v1_DeletionPropagation(&values, &out.PropagationPolicy, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.PropagationPolicy = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["dryRun"]; ok && len(values) > 0 { | ||||
| 		out.DryRun = *(*[]string)(unsafe.Pointer(&values)) | ||||
| 	} else { | ||||
| 		out.DryRun = nil | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_ExportOptions(in *url.Values, out *ExportOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["export"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_bool(&values, &out.Export, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Export = false | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["exact"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_bool(&values, &out.Exact, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Exact = false | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_ExportOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_ExportOptions(in *url.Values, out *ExportOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_ExportOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_GetOptions(in *url.Values, out *GetOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["resourceVersion"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.ResourceVersion, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.ResourceVersion = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_GetOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_GetOptions(in *url.Values, out *GetOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_GetOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_ListOptions(in *url.Values, out *ListOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["labelSelector"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.LabelSelector, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.LabelSelector = "" | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["fieldSelector"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.FieldSelector, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.FieldSelector = "" | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["watch"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_bool(&values, &out.Watch, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Watch = false | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["allowWatchBookmarks"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_bool(&values, &out.AllowWatchBookmarks, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.AllowWatchBookmarks = false | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["resourceVersion"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.ResourceVersion, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.ResourceVersion = "" | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["timeoutSeconds"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_Pointer_int64(&values, &out.TimeoutSeconds, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.TimeoutSeconds = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["limit"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_int64(&values, &out.Limit, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Limit = 0 | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["continue"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.Continue, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Continue = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_ListOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_ListOptions(in *url.Values, out *ListOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_ListOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_PatchOptions(in *url.Values, out *PatchOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["dryRun"]; ok && len(values) > 0 { | ||||
| 		out.DryRun = *(*[]string)(unsafe.Pointer(&values)) | ||||
| 	} else { | ||||
| 		out.DryRun = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["force"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_Pointer_bool(&values, &out.Force, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.Force = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["fieldManager"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.FieldManager, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.FieldManager = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_PatchOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_PatchOptions(in *url.Values, out *PatchOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_PatchOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_TableOptions(in *url.Values, out *TableOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["-"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_bool(&values, &out.NoHeaders, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.NoHeaders = false | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["includeObject"]; ok && len(values) > 0 { | ||||
| 		if err := Convert_Slice_string_To_v1_IncludeObjectPolicy(&values, &out.IncludeObject, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.IncludeObject = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_TableOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_TableOptions(in *url.Values, out *TableOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_TableOptions(in, out, s) | ||||
| } | ||||
| 
 | ||||
| func autoConvert_url_Values_To_v1_UpdateOptions(in *url.Values, out *UpdateOptions, s conversion.Scope) error { | ||||
| 	// WARNING: Field TypeMeta does not have json tag, skipping.
 | ||||
| 
 | ||||
| 	if values, ok := map[string][]string(*in)["dryRun"]; ok && len(values) > 0 { | ||||
| 		out.DryRun = *(*[]string)(unsafe.Pointer(&values)) | ||||
| 	} else { | ||||
| 		out.DryRun = nil | ||||
| 	} | ||||
| 	if values, ok := map[string][]string(*in)["fieldManager"]; ok && len(values) > 0 { | ||||
| 		if err := runtime.Convert_Slice_string_To_string(&values, &out.FieldManager, s); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} else { | ||||
| 		out.FieldManager = "" | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // Convert_url_Values_To_v1_UpdateOptions is an autogenerated conversion function.
 | ||||
| func Convert_url_Values_To_v1_UpdateOptions(in *url.Values, out *UpdateOptions, s conversion.Scope) error { | ||||
| 	return autoConvert_url_Values_To_v1_UpdateOptions(in, out, s) | ||||
| } | ||||
|  | @ -313,7 +313,7 @@ func (in *ExportOptions) DeepCopyObject() runtime.Object { | |||
| } | ||||
| 
 | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *Fields) DeepCopyInto(out *Fields) { | ||||
| func (in *FieldsV1) DeepCopyInto(out *FieldsV1) { | ||||
| 	*out = *in | ||||
| 	if in.Raw != nil { | ||||
| 		in, out := &in.Raw, &out.Raw | ||||
|  | @ -323,12 +323,12 @@ func (in *Fields) DeepCopyInto(out *Fields) { | |||
| 	return | ||||
| } | ||||
| 
 | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Fields.
 | ||||
| func (in *Fields) DeepCopy() *Fields { | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new FieldsV1.
 | ||||
| func (in *FieldsV1) DeepCopy() *FieldsV1 { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Fields) | ||||
| 	out := new(FieldsV1) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | @ -615,9 +615,9 @@ func (in *ManagedFieldsEntry) DeepCopyInto(out *ManagedFieldsEntry) { | |||
| 		in, out := &in.Time, &out.Time | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	if in.Fields != nil { | ||||
| 		in, out := &in.Fields, &out.Fields | ||||
| 		*out = new(Fields) | ||||
| 	if in.FieldsV1 != nil { | ||||
| 		in, out := &in.FieldsV1, &out.FieldsV1 | ||||
| 		*out = new(FieldsV1) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
|  | @ -864,34 +864,6 @@ func (in *Preconditions) DeepCopy() *Preconditions { | |||
| 	return out | ||||
| } | ||||
| 
 | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *ProtoFields) DeepCopyInto(out *ProtoFields) { | ||||
| 	*out = *in | ||||
| 	if in.Map != nil { | ||||
| 		in, out := &in.Map, &out.Map | ||||
| 		*out = make(map[string]Fields, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			(*out)[key] = *val.DeepCopy() | ||||
| 		} | ||||
| 	} | ||||
| 	if in.Raw != nil { | ||||
| 		in, out := &in.Raw, &out.Raw | ||||
| 		*out = make([]byte, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ProtoFields.
 | ||||
| func (in *ProtoFields) DeepCopy() *ProtoFields { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ProtoFields) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
| 
 | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
 | ||||
| func (in *RootPaths) DeepCopyInto(out *RootPaths) { | ||||
| 	*out = *in | ||||
|  |  | |||
|  | @ -54,6 +54,11 @@ type Selector interface { | |||
| 
 | ||||
| 	// Make a deep copy of the selector.
 | ||||
| 	DeepCopySelector() Selector | ||||
| 
 | ||||
| 	// RequiresExactMatch allows a caller to introspect whether a given selector
 | ||||
| 	// requires a single specific label to be set, and if so returns the value it
 | ||||
| 	// requires.
 | ||||
| 	RequiresExactMatch(label string) (value string, found bool) | ||||
| } | ||||
| 
 | ||||
| // Everything returns a selector that matches all labels.
 | ||||
|  | @ -63,12 +68,13 @@ func Everything() Selector { | |||
| 
 | ||||
| type nothingSelector struct{} | ||||
| 
 | ||||
| func (n nothingSelector) Matches(_ Labels) bool              { return false } | ||||
| func (n nothingSelector) Empty() bool                        { return false } | ||||
| func (n nothingSelector) String() string                     { return "" } | ||||
| func (n nothingSelector) Add(_ ...Requirement) Selector      { return n } | ||||
| func (n nothingSelector) Requirements() (Requirements, bool) { return nil, false } | ||||
| func (n nothingSelector) DeepCopySelector() Selector         { return n } | ||||
| func (n nothingSelector) Matches(_ Labels) bool                                      { return false } | ||||
| func (n nothingSelector) Empty() bool                                                { return false } | ||||
| func (n nothingSelector) String() string                                             { return "" } | ||||
| func (n nothingSelector) Add(_ ...Requirement) Selector                              { return n } | ||||
| func (n nothingSelector) Requirements() (Requirements, bool)                         { return nil, false } | ||||
| func (n nothingSelector) DeepCopySelector() Selector                                 { return n } | ||||
| func (n nothingSelector) RequiresExactMatch(label string) (value string, found bool) { return "", false } | ||||
| 
 | ||||
| // Nothing returns a selector that matches no labels
 | ||||
| func Nothing() Selector { | ||||
|  | @ -358,6 +364,23 @@ func (lsel internalSelector) String() string { | |||
| 	return strings.Join(reqs, ",") | ||||
| } | ||||
| 
 | ||||
| // RequiresExactMatch introspect whether a given selector requires a single specific field
 | ||||
| // to be set, and if so returns the value it requires.
 | ||||
| func (lsel internalSelector) RequiresExactMatch(label string) (value string, found bool) { | ||||
| 	for ix := range lsel { | ||||
| 		if lsel[ix].key == label { | ||||
| 			switch lsel[ix].operator { | ||||
| 			case selection.Equals, selection.DoubleEquals, selection.In: | ||||
| 				if len(lsel[ix].strValues) == 1 { | ||||
| 					return lsel[ix].strValues[0], true | ||||
| 				} | ||||
| 			} | ||||
| 			return "", false | ||||
| 		} | ||||
| 	} | ||||
| 	return "", false | ||||
| } | ||||
| 
 | ||||
| // Token represents constant definition for lexer token
 | ||||
| type Token int | ||||
| 
 | ||||
|  | @ -850,7 +873,7 @@ func SelectorFromSet(ls Set) Selector { | |||
| 	if ls == nil || len(ls) == 0 { | ||||
| 		return internalSelector{} | ||||
| 	} | ||||
| 	var requirements internalSelector | ||||
| 	requirements := make([]Requirement, 0, len(ls)) | ||||
| 	for label, value := range ls { | ||||
| 		r, err := NewRequirement(label, selection.Equals, []string{value}) | ||||
| 		if err == nil { | ||||
|  | @ -862,7 +885,7 @@ func SelectorFromSet(ls Set) Selector { | |||
| 	} | ||||
| 	// sort to have deterministic string representation
 | ||||
| 	sort.Sort(ByKey(requirements)) | ||||
| 	return requirements | ||||
| 	return internalSelector(requirements) | ||||
| } | ||||
| 
 | ||||
| // SelectorFromValidatedSet returns a Selector which will match exactly the given Set.
 | ||||
|  | @ -872,13 +895,13 @@ func SelectorFromValidatedSet(ls Set) Selector { | |||
| 	if ls == nil || len(ls) == 0 { | ||||
| 		return internalSelector{} | ||||
| 	} | ||||
| 	var requirements internalSelector | ||||
| 	requirements := make([]Requirement, 0, len(ls)) | ||||
| 	for label, value := range ls { | ||||
| 		requirements = append(requirements, Requirement{key: label, operator: selection.Equals, strValues: []string{value}}) | ||||
| 	} | ||||
| 	// sort to have deterministic string representation
 | ||||
| 	sort.Sort(ByKey(requirements)) | ||||
| 	return requirements | ||||
| 	return internalSelector(requirements) | ||||
| } | ||||
| 
 | ||||
| // ParseToRequirements takes a string representing a selector and returns a list of
 | ||||
|  |  | |||
|  | @ -19,13 +19,17 @@ package runtime | |||
| import ( | ||||
| 	"bytes" | ||||
| 	"encoding/base64" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"net/url" | ||||
| 	"reflect" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"k8s.io/apimachinery/pkg/conversion/queryparams" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| 	"k8s.io/klog" | ||||
| ) | ||||
| 
 | ||||
| // codec binds an encoder and decoder.
 | ||||
|  | @ -100,10 +104,19 @@ type NoopEncoder struct { | |||
| 
 | ||||
| var _ Serializer = NoopEncoder{} | ||||
| 
 | ||||
| const noopEncoderIdentifier Identifier = "noop" | ||||
| 
 | ||||
| func (n NoopEncoder) Encode(obj Object, w io.Writer) error { | ||||
| 	// There is no need to handle runtime.CacheableObject, as we don't
 | ||||
| 	// process the obj at all.
 | ||||
| 	return fmt.Errorf("encoding is not allowed for this codec: %v", reflect.TypeOf(n.Decoder)) | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (n NoopEncoder) Identifier() Identifier { | ||||
| 	return noopEncoderIdentifier | ||||
| } | ||||
| 
 | ||||
| // NoopDecoder converts an Encoder to a Serializer or Codec for code that expects them but only uses encoding.
 | ||||
| type NoopDecoder struct { | ||||
| 	Encoder | ||||
|  | @ -193,19 +206,51 @@ func (c *parameterCodec) EncodeParameters(obj Object, to schema.GroupVersion) (u | |||
| type base64Serializer struct { | ||||
| 	Encoder | ||||
| 	Decoder | ||||
| 
 | ||||
| 	identifier Identifier | ||||
| } | ||||
| 
 | ||||
| func NewBase64Serializer(e Encoder, d Decoder) Serializer { | ||||
| 	return &base64Serializer{e, d} | ||||
| 	return &base64Serializer{ | ||||
| 		Encoder:    e, | ||||
| 		Decoder:    d, | ||||
| 		identifier: identifier(e), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func identifier(e Encoder) Identifier { | ||||
| 	result := map[string]string{ | ||||
| 		"name": "base64", | ||||
| 	} | ||||
| 	if e != nil { | ||||
| 		result["encoder"] = string(e.Identifier()) | ||||
| 	} | ||||
| 	identifier, err := json.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		klog.Fatalf("Failed marshaling identifier for base64Serializer: %v", err) | ||||
| 	} | ||||
| 	return Identifier(identifier) | ||||
| } | ||||
| 
 | ||||
| func (s base64Serializer) Encode(obj Object, stream io.Writer) error { | ||||
| 	if co, ok := obj.(CacheableObject); ok { | ||||
| 		return co.CacheEncode(s.Identifier(), s.doEncode, stream) | ||||
| 	} | ||||
| 	return s.doEncode(obj, stream) | ||||
| } | ||||
| 
 | ||||
| func (s base64Serializer) doEncode(obj Object, stream io.Writer) error { | ||||
| 	e := base64.NewEncoder(base64.StdEncoding, stream) | ||||
| 	err := s.Encoder.Encode(obj, e) | ||||
| 	e.Close() | ||||
| 	return err | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (s base64Serializer) Identifier() Identifier { | ||||
| 	return s.identifier | ||||
| } | ||||
| 
 | ||||
| func (s base64Serializer) Decode(data []byte, defaults *schema.GroupVersionKind, into Object) (Object, *schema.GroupVersionKind, error) { | ||||
| 	out := make([]byte, base64.StdEncoding.DecodedLen(len(data))) | ||||
| 	n, err := base64.StdEncoding.Decode(out, data) | ||||
|  | @ -238,6 +283,11 @@ var ( | |||
| 	DisabledGroupVersioner GroupVersioner = disabledGroupVersioner{} | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	internalGroupVersionerIdentifier = "internal" | ||||
| 	disabledGroupVersionerIdentifier = "disabled" | ||||
| ) | ||||
| 
 | ||||
| type internalGroupVersioner struct{} | ||||
| 
 | ||||
| // KindForGroupVersionKinds returns an internal Kind if one is found, or converts the first provided kind to the internal version.
 | ||||
|  | @ -253,6 +303,11 @@ func (internalGroupVersioner) KindForGroupVersionKinds(kinds []schema.GroupVersi | |||
| 	return schema.GroupVersionKind{}, false | ||||
| } | ||||
| 
 | ||||
| // Identifier implements GroupVersioner interface.
 | ||||
| func (internalGroupVersioner) Identifier() string { | ||||
| 	return internalGroupVersionerIdentifier | ||||
| } | ||||
| 
 | ||||
| type disabledGroupVersioner struct{} | ||||
| 
 | ||||
| // KindForGroupVersionKinds returns false for any input.
 | ||||
|  | @ -260,19 +315,9 @@ func (disabledGroupVersioner) KindForGroupVersionKinds(kinds []schema.GroupVersi | |||
| 	return schema.GroupVersionKind{}, false | ||||
| } | ||||
| 
 | ||||
| // GroupVersioners implements GroupVersioner and resolves to the first exact match for any kind.
 | ||||
| type GroupVersioners []GroupVersioner | ||||
| 
 | ||||
| // KindForGroupVersionKinds returns the first match of any of the group versioners, or false if no match occurred.
 | ||||
| func (gvs GroupVersioners) KindForGroupVersionKinds(kinds []schema.GroupVersionKind) (schema.GroupVersionKind, bool) { | ||||
| 	for _, gv := range gvs { | ||||
| 		target, ok := gv.KindForGroupVersionKinds(kinds) | ||||
| 		if !ok { | ||||
| 			continue | ||||
| 		} | ||||
| 		return target, true | ||||
| 	} | ||||
| 	return schema.GroupVersionKind{}, false | ||||
| // Identifier implements GroupVersioner interface.
 | ||||
| func (disabledGroupVersioner) Identifier() string { | ||||
| 	return disabledGroupVersionerIdentifier | ||||
| } | ||||
| 
 | ||||
| // Assert that schema.GroupVersion and GroupVersions implement GroupVersioner
 | ||||
|  | @ -330,3 +375,22 @@ func (v multiGroupVersioner) KindForGroupVersionKinds(kinds []schema.GroupVersio | |||
| 	} | ||||
| 	return schema.GroupVersionKind{}, false | ||||
| } | ||||
| 
 | ||||
| // Identifier implements GroupVersioner interface.
 | ||||
| func (v multiGroupVersioner) Identifier() string { | ||||
| 	groupKinds := make([]string, 0, len(v.acceptedGroupKinds)) | ||||
| 	for _, gk := range v.acceptedGroupKinds { | ||||
| 		groupKinds = append(groupKinds, gk.String()) | ||||
| 	} | ||||
| 	result := map[string]string{ | ||||
| 		"name":     "multi", | ||||
| 		"target":   v.target.String(), | ||||
| 		"accepted": strings.Join(groupKinds, ","), | ||||
| 		"coerce":   strconv.FormatBool(v.coerce), | ||||
| 	} | ||||
| 	identifier, err := json.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		klog.Fatalf("Failed marshaling Identifier for %#v: %v", v, err) | ||||
| 	} | ||||
| 	return string(identifier) | ||||
| } | ||||
|  |  | |||
|  | @ -61,19 +61,21 @@ var DefaultStringConversions = []interface{}{ | |||
| 	Convert_Slice_string_To_int64, | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_string(input *[]string, out *string, s conversion.Scope) error { | ||||
| 	if len(*input) == 0 { | ||||
| func Convert_Slice_string_To_string(in *[]string, out *string, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		*out = "" | ||||
| 		return nil | ||||
| 	} | ||||
| 	*out = (*input)[0] | ||||
| 	*out = (*in)[0] | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_int(input *[]string, out *int, s conversion.Scope) error { | ||||
| 	if len(*input) == 0 { | ||||
| func Convert_Slice_string_To_int(in *[]string, out *int, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		*out = 0 | ||||
| 		return nil | ||||
| 	} | ||||
| 	str := (*input)[0] | ||||
| 	str := (*in)[0] | ||||
| 	i, err := strconv.Atoi(str) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|  | @ -83,15 +85,16 @@ func Convert_Slice_string_To_int(input *[]string, out *int, s conversion.Scope) | |||
| } | ||||
| 
 | ||||
| // Convert_Slice_string_To_bool will convert a string parameter to boolean.
 | ||||
| // Only the absence of a value, a value of "false", or a value of "0" resolve to false.
 | ||||
| // Only the absence of a value (i.e. zero-length slice), a value of "false", or a
 | ||||
| // value of "0" resolve to false.
 | ||||
| // Any other value (including empty string) resolves to true.
 | ||||
| func Convert_Slice_string_To_bool(input *[]string, out *bool, s conversion.Scope) error { | ||||
| 	if len(*input) == 0 { | ||||
| func Convert_Slice_string_To_bool(in *[]string, out *bool, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		*out = false | ||||
| 		return nil | ||||
| 	} | ||||
| 	switch strings.ToLower((*input)[0]) { | ||||
| 	case "false", "0": | ||||
| 	switch { | ||||
| 	case (*in)[0] == "0", strings.EqualFold((*in)[0], "false"): | ||||
| 		*out = false | ||||
| 	default: | ||||
| 		*out = true | ||||
|  | @ -99,15 +102,79 @@ func Convert_Slice_string_To_bool(input *[]string, out *bool, s conversion.Scope | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_int64(input *[]string, out *int64, s conversion.Scope) error { | ||||
| 	if len(*input) == 0 { | ||||
| 		*out = 0 | ||||
| // Convert_Slice_string_To_bool will convert a string parameter to boolean.
 | ||||
| // Only the absence of a value (i.e. zero-length slice), a value of "false", or a
 | ||||
| // value of "0" resolve to false.
 | ||||
| // Any other value (including empty string) resolves to true.
 | ||||
| func Convert_Slice_string_To_Pointer_bool(in *[]string, out **bool, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		boolVar := false | ||||
| 		*out = &boolVar | ||||
| 		return nil | ||||
| 	} | ||||
| 	str := (*input)[0] | ||||
| 	i, err := strconv.ParseInt(str, 10, 64) | ||||
| 	switch { | ||||
| 	case (*in)[0] == "0", strings.EqualFold((*in)[0], "false"): | ||||
| 		boolVar := false | ||||
| 		*out = &boolVar | ||||
| 	default: | ||||
| 		boolVar := true | ||||
| 		*out = &boolVar | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func string_to_int64(in string) (int64, error) { | ||||
| 	return strconv.ParseInt(in, 10, 64) | ||||
| } | ||||
| 
 | ||||
| func Convert_string_To_int64(in *string, out *int64, s conversion.Scope) error { | ||||
| 	if in == nil { | ||||
| 		*out = 0 | ||||
| 		return nil | ||||
| 	} | ||||
| 	i, err := string_to_int64(*in) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*out = i | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_int64(in *[]string, out *int64, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		*out = 0 | ||||
| 		return nil | ||||
| 	} | ||||
| 	i, err := string_to_int64((*in)[0]) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*out = i | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_string_To_Pointer_int64(in *string, out **int64, s conversion.Scope) error { | ||||
| 	if in == nil { | ||||
| 		*out = nil | ||||
| 		return nil | ||||
| 	} | ||||
| 	i, err := string_to_int64(*in) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*out = &i | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Convert_Slice_string_To_Pointer_int64(in *[]string, out **int64, s conversion.Scope) error { | ||||
| 	if len(*in) == 0 { | ||||
| 		*out = nil | ||||
| 		return nil | ||||
| 	} | ||||
| 	i, err := string_to_int64((*in)[0]) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	*out = &i | ||||
| 	return nil | ||||
| } | ||||
|  |  | |||
|  | @ -37,13 +37,36 @@ type GroupVersioner interface { | |||
| 	// Scheme.New(target) and then perform a conversion between the current Go type and the destination Go type.
 | ||||
| 	// Sophisticated implementations may use additional information about the input kinds to pick a destination kind.
 | ||||
| 	KindForGroupVersionKinds(kinds []schema.GroupVersionKind) (target schema.GroupVersionKind, ok bool) | ||||
| 	// Identifier returns string representation of the object.
 | ||||
| 	// Identifiers of two different encoders should be equal only if for every input
 | ||||
| 	// kinds they return the same result.
 | ||||
| 	Identifier() string | ||||
| } | ||||
| 
 | ||||
| // Identifier represents an identifier.
 | ||||
| // Identitier of two different objects should be equal if and only if for every
 | ||||
| // input the output they produce is exactly the same.
 | ||||
| type Identifier string | ||||
| 
 | ||||
| // Encoder writes objects to a serialized form
 | ||||
| type Encoder interface { | ||||
| 	// Encode writes an object to a stream. Implementations may return errors if the versions are
 | ||||
| 	// incompatible, or if no conversion is defined.
 | ||||
| 	Encode(obj Object, w io.Writer) error | ||||
| 	// Identifier returns an identifier of the encoder.
 | ||||
| 	// Identifiers of two different encoders should be equal if and only if for every input
 | ||||
| 	// object it will be encoded to the same representation by both of them.
 | ||||
| 	//
 | ||||
| 	// Identifier is inteted for use with CacheableObject#CacheEncode method. In order to
 | ||||
| 	// correctly handle CacheableObject, Encode() method should look similar to below, where
 | ||||
| 	// doEncode() is the encoding logic of implemented encoder:
 | ||||
| 	//   func (e *MyEncoder) Encode(obj Object, w io.Writer) error {
 | ||||
| 	//     if co, ok := obj.(CacheableObject); ok {
 | ||||
| 	//       return co.CacheEncode(e.Identifier(), e.doEncode, w)
 | ||||
| 	//     }
 | ||||
| 	//     return e.doEncode(obj, w)
 | ||||
| 	//   }
 | ||||
| 	Identifier() Identifier | ||||
| } | ||||
| 
 | ||||
| // Decoder attempts to load an object from data.
 | ||||
|  | @ -132,6 +155,28 @@ type NegotiatedSerializer interface { | |||
| 	DecoderToVersion(serializer Decoder, gv GroupVersioner) Decoder | ||||
| } | ||||
| 
 | ||||
| // ClientNegotiator handles turning an HTTP content type into the appropriate encoder.
 | ||||
| // Use NewClientNegotiator or NewVersionedClientNegotiator to create this interface from
 | ||||
| // a NegotiatedSerializer.
 | ||||
| type ClientNegotiator interface { | ||||
| 	// Encoder returns the appropriate encoder for the provided contentType (e.g. application/json)
 | ||||
| 	// and any optional mediaType parameters (e.g. pretty=1), or an error. If no serializer is found
 | ||||
| 	// a NegotiateError will be returned. The current client implementations consider params to be
 | ||||
| 	// optional modifiers to the contentType and will ignore unrecognized parameters.
 | ||||
| 	Encoder(contentType string, params map[string]string) (Encoder, error) | ||||
| 	// Decoder returns the appropriate decoder for the provided contentType (e.g. application/json)
 | ||||
| 	// and any optional mediaType parameters (e.g. pretty=1), or an error. If no serializer is found
 | ||||
| 	// a NegotiateError will be returned. The current client implementations consider params to be
 | ||||
| 	// optional modifiers to the contentType and will ignore unrecognized parameters.
 | ||||
| 	Decoder(contentType string, params map[string]string) (Decoder, error) | ||||
| 	// StreamDecoder returns the appropriate stream decoder for the provided contentType (e.g.
 | ||||
| 	// application/json) and any optional mediaType parameters (e.g. pretty=1), or an error. If no
 | ||||
| 	// serializer is found a NegotiateError will be returned. The Serializer and Framer will always
 | ||||
| 	// be returned if a Decoder is returned. The current client implementations consider params to be
 | ||||
| 	// optional modifiers to the contentType and will ignore unrecognized parameters.
 | ||||
| 	StreamDecoder(contentType string, params map[string]string) (Decoder, Serializer, Framer, error) | ||||
| } | ||||
| 
 | ||||
| // StorageSerializer is an interface used for obtaining encoders, decoders, and serializers
 | ||||
| // that can read and write data at rest. This would commonly be used by client tools that must
 | ||||
| // read files, or server side storage interfaces that persist restful objects.
 | ||||
|  | @ -256,6 +301,27 @@ type Object interface { | |||
| 	DeepCopyObject() Object | ||||
| } | ||||
| 
 | ||||
| // CacheableObject allows an object to cache its different serializations
 | ||||
| // to avoid performing the same serialization multiple times.
 | ||||
| type CacheableObject interface { | ||||
| 	// CacheEncode writes an object to a stream. The <encode> function will
 | ||||
| 	// be used in case of cache miss. The <encode> function takes ownership
 | ||||
| 	// of the object.
 | ||||
| 	// If CacheableObject is a wrapper, then deep-copy of the wrapped object
 | ||||
| 	// should be passed to <encode> function.
 | ||||
| 	// CacheEncode assumes that for two different calls with the same <id>,
 | ||||
| 	// <encode> function will also be the same.
 | ||||
| 	CacheEncode(id Identifier, encode func(Object, io.Writer) error, w io.Writer) error | ||||
| 	// GetObject returns a deep-copy of an object to be encoded - the caller of
 | ||||
| 	// GetObject() is the owner of returned object. The reason for making a copy
 | ||||
| 	// is to avoid bugs, where caller modifies the object and forgets to copy it,
 | ||||
| 	// thus modifying the object for everyone.
 | ||||
| 	// The object returned by GetObject should be the same as the one that is supposed
 | ||||
| 	// to be passed to <encode> function in CacheEncode method.
 | ||||
| 	// If CacheableObject is a wrapper, the copy of wrapped object should be returned.
 | ||||
| 	GetObject() Object | ||||
| } | ||||
| 
 | ||||
| // Unstructured objects store values as map[string]interface{}, with only values that can be serialized
 | ||||
| // to JSON allowed.
 | ||||
| type Unstructured interface { | ||||
|  |  | |||
|  | @ -0,0 +1,146 @@ | |||
| /* | ||||
| Copyright 2019 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 runtime | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 
 | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
| 
 | ||||
| // NegotiateError is returned when a ClientNegotiator is unable to locate
 | ||||
| // a serializer for the requested operation.
 | ||||
| type NegotiateError struct { | ||||
| 	ContentType string | ||||
| 	Stream      bool | ||||
| } | ||||
| 
 | ||||
| func (e NegotiateError) Error() string { | ||||
| 	if e.Stream { | ||||
| 		return fmt.Sprintf("no stream serializers registered for %s", e.ContentType) | ||||
| 	} | ||||
| 	return fmt.Sprintf("no serializers registered for %s", e.ContentType) | ||||
| } | ||||
| 
 | ||||
| type clientNegotiator struct { | ||||
| 	serializer     NegotiatedSerializer | ||||
| 	encode, decode GroupVersioner | ||||
| } | ||||
| 
 | ||||
| func (n *clientNegotiator) Encoder(contentType string, params map[string]string) (Encoder, error) { | ||||
| 	// TODO: `pretty=1` is handled in NegotiateOutputMediaType, consider moving it to this method
 | ||||
| 	// if client negotiators truly need to use it
 | ||||
| 	mediaTypes := n.serializer.SupportedMediaTypes() | ||||
| 	info, ok := SerializerInfoForMediaType(mediaTypes, contentType) | ||||
| 	if !ok { | ||||
| 		if len(contentType) != 0 || len(mediaTypes) == 0 { | ||||
| 			return nil, NegotiateError{ContentType: contentType} | ||||
| 		} | ||||
| 		info = mediaTypes[0] | ||||
| 	} | ||||
| 	return n.serializer.EncoderForVersion(info.Serializer, n.encode), nil | ||||
| } | ||||
| 
 | ||||
| func (n *clientNegotiator) Decoder(contentType string, params map[string]string) (Decoder, error) { | ||||
| 	mediaTypes := n.serializer.SupportedMediaTypes() | ||||
| 	info, ok := SerializerInfoForMediaType(mediaTypes, contentType) | ||||
| 	if !ok { | ||||
| 		if len(contentType) != 0 || len(mediaTypes) == 0 { | ||||
| 			return nil, NegotiateError{ContentType: contentType} | ||||
| 		} | ||||
| 		info = mediaTypes[0] | ||||
| 	} | ||||
| 	return n.serializer.DecoderToVersion(info.Serializer, n.decode), nil | ||||
| } | ||||
| 
 | ||||
| func (n *clientNegotiator) StreamDecoder(contentType string, params map[string]string) (Decoder, Serializer, Framer, error) { | ||||
| 	mediaTypes := n.serializer.SupportedMediaTypes() | ||||
| 	info, ok := SerializerInfoForMediaType(mediaTypes, contentType) | ||||
| 	if !ok { | ||||
| 		if len(contentType) != 0 || len(mediaTypes) == 0 { | ||||
| 			return nil, nil, nil, NegotiateError{ContentType: contentType, Stream: true} | ||||
| 		} | ||||
| 		info = mediaTypes[0] | ||||
| 	} | ||||
| 	if info.StreamSerializer == nil { | ||||
| 		return nil, nil, nil, NegotiateError{ContentType: info.MediaType, Stream: true} | ||||
| 	} | ||||
| 	return n.serializer.DecoderToVersion(info.Serializer, n.decode), info.StreamSerializer.Serializer, info.StreamSerializer.Framer, nil | ||||
| } | ||||
| 
 | ||||
| // NewClientNegotiator will attempt to retrieve the appropriate encoder, decoder, or
 | ||||
| // stream decoder for a given content type. Does not perform any conversion, but will
 | ||||
| // encode the object to the desired group, version, and kind. Use when creating a client.
 | ||||
| func NewClientNegotiator(serializer NegotiatedSerializer, gv schema.GroupVersion) ClientNegotiator { | ||||
| 	return &clientNegotiator{ | ||||
| 		serializer: serializer, | ||||
| 		encode:     gv, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // NewInternalClientNegotiator applies the default client rules for connecting to a Kubernetes apiserver
 | ||||
| // where objects are converted to gv prior to sending and decoded to their internal representation prior
 | ||||
| // to retrieval.
 | ||||
| //
 | ||||
| // DEPRECATED: Internal clients are deprecated and will be removed in a future Kubernetes release.
 | ||||
| func NewInternalClientNegotiator(serializer NegotiatedSerializer, gv schema.GroupVersion) ClientNegotiator { | ||||
| 	decode := schema.GroupVersions{ | ||||
| 		{ | ||||
| 			Group:   gv.Group, | ||||
| 			Version: APIVersionInternal, | ||||
| 		}, | ||||
| 		// always include the legacy group as a decoding target to handle non-error `Status` return types
 | ||||
| 		{ | ||||
| 			Group:   "", | ||||
| 			Version: APIVersionInternal, | ||||
| 		}, | ||||
| 	} | ||||
| 	return &clientNegotiator{ | ||||
| 		encode:     gv, | ||||
| 		decode:     decode, | ||||
| 		serializer: serializer, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // NewSimpleClientNegotiator will negotiate for a single serializer. This should only be used
 | ||||
| // for testing or when the caller is taking responsibility for setting the GVK on encoded objects.
 | ||||
| func NewSimpleClientNegotiator(info SerializerInfo, gv schema.GroupVersion) ClientNegotiator { | ||||
| 	return &clientNegotiator{ | ||||
| 		serializer: &simpleNegotiatedSerializer{info: info}, | ||||
| 		encode:     gv, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| type simpleNegotiatedSerializer struct { | ||||
| 	info SerializerInfo | ||||
| } | ||||
| 
 | ||||
| func NewSimpleNegotiatedSerializer(info SerializerInfo) NegotiatedSerializer { | ||||
| 	return &simpleNegotiatedSerializer{info: info} | ||||
| } | ||||
| 
 | ||||
| func (n *simpleNegotiatedSerializer) SupportedMediaTypes() []SerializerInfo { | ||||
| 	return []SerializerInfo{n.info} | ||||
| } | ||||
| 
 | ||||
| func (n *simpleNegotiatedSerializer) EncoderForVersion(e Encoder, _ GroupVersioner) Encoder { | ||||
| 	return e | ||||
| } | ||||
| 
 | ||||
| func (n *simpleNegotiatedSerializer) DecoderToVersion(d Decoder, _gv GroupVersioner) Decoder { | ||||
| 	return d | ||||
| } | ||||
|  | @ -29,33 +29,3 @@ func (obj *TypeMeta) GroupVersionKind() schema.GroupVersionKind { | |||
| } | ||||
| 
 | ||||
| func (obj *TypeMeta) GetObjectKind() schema.ObjectKind { return obj } | ||||
| 
 | ||||
| // GetObjectKind implements Object for VersionedObjects, returning an empty ObjectKind
 | ||||
| // interface if no objects are provided, or the ObjectKind interface of the object in the
 | ||||
| // highest array position.
 | ||||
| func (obj *VersionedObjects) GetObjectKind() schema.ObjectKind { | ||||
| 	last := obj.Last() | ||||
| 	if last == nil { | ||||
| 		return schema.EmptyObjectKind | ||||
| 	} | ||||
| 	return last.GetObjectKind() | ||||
| } | ||||
| 
 | ||||
| // First returns the leftmost object in the VersionedObjects array, which is usually the
 | ||||
| // object as serialized on the wire.
 | ||||
| func (obj *VersionedObjects) First() Object { | ||||
| 	if len(obj.Objects) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return obj.Objects[0] | ||||
| } | ||||
| 
 | ||||
| // Last is the rightmost object in the VersionedObjects array, which is the object after
 | ||||
| // all transformations have been applied. This is the same object that would be returned
 | ||||
| // by Decode in a normal invocation (without VersionedObjects in the into argument).
 | ||||
| func (obj *VersionedObjects) Last() Object { | ||||
| 	if len(obj.Objects) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return obj.Objects[len(obj.Objects)-1] | ||||
| } | ||||
|  |  | |||
|  | @ -191,6 +191,11 @@ func (gv GroupVersion) String() string { | |||
| 	return gv.Version | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.GroupVersioner interface.
 | ||||
| func (gv GroupVersion) Identifier() string { | ||||
| 	return gv.String() | ||||
| } | ||||
| 
 | ||||
| // KindForGroupVersionKinds identifies the preferred GroupVersionKind out of a list. It returns ok false
 | ||||
| // if none of the options match the group. It prefers a match to group and version over just group.
 | ||||
| // TODO: Move GroupVersion to a package under pkg/runtime, since it's used by scheme.
 | ||||
|  | @ -246,6 +251,15 @@ func (gv GroupVersion) WithResource(resource string) GroupVersionResource { | |||
| //   in fewer places.
 | ||||
| type GroupVersions []GroupVersion | ||||
| 
 | ||||
| // Identifier implements runtime.GroupVersioner interface.
 | ||||
| func (gv GroupVersions) Identifier() string { | ||||
| 	groupVersions := make([]string, 0, len(gv)) | ||||
| 	for i := range gv { | ||||
| 		groupVersions = append(groupVersions, gv[i].String()) | ||||
| 	} | ||||
| 	return fmt.Sprintf("[%s]", strings.Join(groupVersions, ",")) | ||||
| } | ||||
| 
 | ||||
| // KindForGroupVersionKinds identifies the preferred GroupVersionKind out of a list. It returns ok false
 | ||||
| // if none of the options match the group.
 | ||||
| func (gvs GroupVersions) KindForGroupVersionKinds(kinds []GroupVersionKind) (GroupVersionKind, bool) { | ||||
|  |  | |||
|  | @ -322,7 +322,3 @@ func (f WithoutConversionCodecFactory) DecoderToVersion(serializer runtime.Decod | |||
| 		Decoder: serializer, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // DirectCodecFactory was renamed to WithoutConversionCodecFactory in 1.15.
 | ||||
| // TODO: remove in 1.16.
 | ||||
| type DirectCodecFactory = WithoutConversionCodecFactory | ||||
|  |  | |||
|  | @ -31,6 +31,7 @@ import ( | |||
| 	"k8s.io/apimachinery/pkg/runtime/serializer/recognizer" | ||||
| 	"k8s.io/apimachinery/pkg/util/framer" | ||||
| 	utilyaml "k8s.io/apimachinery/pkg/util/yaml" | ||||
| 	"k8s.io/klog" | ||||
| ) | ||||
| 
 | ||||
| // NewSerializer creates a JSON serializer that handles encoding versioned objects into the proper JSON form. If typer
 | ||||
|  | @ -53,13 +54,28 @@ func NewYAMLSerializer(meta MetaFactory, creater runtime.ObjectCreater, typer ru | |||
| // and are immutable.
 | ||||
| func NewSerializerWithOptions(meta MetaFactory, creater runtime.ObjectCreater, typer runtime.ObjectTyper, options SerializerOptions) *Serializer { | ||||
| 	return &Serializer{ | ||||
| 		meta:    meta, | ||||
| 		creater: creater, | ||||
| 		typer:   typer, | ||||
| 		options: options, | ||||
| 		meta:       meta, | ||||
| 		creater:    creater, | ||||
| 		typer:      typer, | ||||
| 		options:    options, | ||||
| 		identifier: identifier(options), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // identifier computes Identifier of Encoder based on the given options.
 | ||||
| func identifier(options SerializerOptions) runtime.Identifier { | ||||
| 	result := map[string]string{ | ||||
| 		"name":   "json", | ||||
| 		"yaml":   strconv.FormatBool(options.Yaml), | ||||
| 		"pretty": strconv.FormatBool(options.Pretty), | ||||
| 	} | ||||
| 	identifier, err := json.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		klog.Fatalf("Failed marshaling identifier for json Serializer: %v", err) | ||||
| 	} | ||||
| 	return runtime.Identifier(identifier) | ||||
| } | ||||
| 
 | ||||
| // SerializerOptions holds the options which are used to configure a JSON/YAML serializer.
 | ||||
| // example:
 | ||||
| // (1) To configure a JSON serializer, set `Yaml` to `false`.
 | ||||
|  | @ -85,6 +101,8 @@ type Serializer struct { | |||
| 	options SerializerOptions | ||||
| 	creater runtime.ObjectCreater | ||||
| 	typer   runtime.ObjectTyper | ||||
| 
 | ||||
| 	identifier runtime.Identifier | ||||
| } | ||||
| 
 | ||||
| // Serializer implements Serializer
 | ||||
|  | @ -188,16 +206,6 @@ func gvkWithDefaults(actual, defaultGVK schema.GroupVersionKind) schema.GroupVer | |||
| // On success or most errors, the method will return the calculated schema kind.
 | ||||
| // The gvk calculate priority will be originalData > default gvk > into
 | ||||
| func (s *Serializer) Decode(originalData []byte, gvk *schema.GroupVersionKind, into runtime.Object) (runtime.Object, *schema.GroupVersionKind, error) { | ||||
| 	if versioned, ok := into.(*runtime.VersionedObjects); ok { | ||||
| 		into = versioned.Last() | ||||
| 		obj, actual, err := s.Decode(originalData, gvk, into) | ||||
| 		if err != nil { | ||||
| 			return nil, actual, err | ||||
| 		} | ||||
| 		versioned.Objects = []runtime.Object{obj} | ||||
| 		return versioned, actual, nil | ||||
| 	} | ||||
| 
 | ||||
| 	data := originalData | ||||
| 	if s.options.Yaml { | ||||
| 		altered, err := yaml.YAMLToJSON(data) | ||||
|  | @ -286,6 +294,13 @@ func (s *Serializer) Decode(originalData []byte, gvk *schema.GroupVersionKind, i | |||
| 
 | ||||
| // Encode serializes the provided object to the given writer.
 | ||||
| func (s *Serializer) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	if co, ok := obj.(runtime.CacheableObject); ok { | ||||
| 		return co.CacheEncode(s.Identifier(), s.doEncode, w) | ||||
| 	} | ||||
| 	return s.doEncode(obj, w) | ||||
| } | ||||
| 
 | ||||
| func (s *Serializer) doEncode(obj runtime.Object, w io.Writer) error { | ||||
| 	if s.options.Yaml { | ||||
| 		json, err := caseSensitiveJsonIterator.Marshal(obj) | ||||
| 		if err != nil { | ||||
|  | @ -311,6 +326,11 @@ func (s *Serializer) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	return encoder.Encode(obj) | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (s *Serializer) Identifier() runtime.Identifier { | ||||
| 	return s.identifier | ||||
| } | ||||
| 
 | ||||
| // RecognizesData implements the RecognizingDecoder interface.
 | ||||
| func (s *Serializer) RecognizesData(peek io.Reader) (ok, unknown bool, err error) { | ||||
| 	if s.options.Yaml { | ||||
|  |  | |||
|  | @ -86,6 +86,8 @@ type Serializer struct { | |||
| var _ runtime.Serializer = &Serializer{} | ||||
| var _ recognizer.RecognizingDecoder = &Serializer{} | ||||
| 
 | ||||
| const serializerIdentifier runtime.Identifier = "protobuf" | ||||
| 
 | ||||
| // Decode attempts to convert the provided data into a protobuf message, extract the stored schema kind, apply the provided default
 | ||||
| // gvk, and then load that data into an object matching the desired schema kind or the provided into. If into is *runtime.Unknown,
 | ||||
| // the raw data will be extracted and no decoding will be performed. If into is not registered with the typer, then the object will
 | ||||
|  | @ -93,23 +95,6 @@ var _ recognizer.RecognizingDecoder = &Serializer{} | |||
| // not fully qualified with kind/version/group, the type of the into will be used to alter the returned gvk. On success or most
 | ||||
| // errors, the method will return the calculated schema kind.
 | ||||
| func (s *Serializer) Decode(originalData []byte, gvk *schema.GroupVersionKind, into runtime.Object) (runtime.Object, *schema.GroupVersionKind, error) { | ||||
| 	if versioned, ok := into.(*runtime.VersionedObjects); ok { | ||||
| 		into = versioned.Last() | ||||
| 		obj, actual, err := s.Decode(originalData, gvk, into) | ||||
| 		if err != nil { | ||||
| 			return nil, actual, err | ||||
| 		} | ||||
| 		// the last item in versioned becomes into, so if versioned was not originally empty we reset the object
 | ||||
| 		// array so the first position is the decoded object and the second position is the outermost object.
 | ||||
| 		// if there were no objects in the versioned list passed to us, only add ourselves.
 | ||||
| 		if into != nil && into != obj { | ||||
| 			versioned.Objects = []runtime.Object{obj, into} | ||||
| 		} else { | ||||
| 			versioned.Objects = []runtime.Object{obj} | ||||
| 		} | ||||
| 		return versioned, actual, err | ||||
| 	} | ||||
| 
 | ||||
| 	prefixLen := len(s.prefix) | ||||
| 	switch { | ||||
| 	case len(originalData) == 0: | ||||
|  | @ -176,6 +161,13 @@ func (s *Serializer) Decode(originalData []byte, gvk *schema.GroupVersionKind, i | |||
| 
 | ||||
| // Encode serializes the provided object to the given writer.
 | ||||
| func (s *Serializer) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	if co, ok := obj.(runtime.CacheableObject); ok { | ||||
| 		return co.CacheEncode(s.Identifier(), s.doEncode, w) | ||||
| 	} | ||||
| 	return s.doEncode(obj, w) | ||||
| } | ||||
| 
 | ||||
| func (s *Serializer) doEncode(obj runtime.Object, w io.Writer) error { | ||||
| 	prefixSize := uint64(len(s.prefix)) | ||||
| 
 | ||||
| 	var unk runtime.Unknown | ||||
|  | @ -245,6 +237,11 @@ func (s *Serializer) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (s *Serializer) Identifier() runtime.Identifier { | ||||
| 	return serializerIdentifier | ||||
| } | ||||
| 
 | ||||
| // RecognizesData implements the RecognizingDecoder interface.
 | ||||
| func (s *Serializer) RecognizesData(peek io.Reader) (bool, bool, error) { | ||||
| 	prefix := make([]byte, 4) | ||||
|  | @ -321,6 +318,8 @@ type RawSerializer struct { | |||
| 
 | ||||
| var _ runtime.Serializer = &RawSerializer{} | ||||
| 
 | ||||
| const rawSerializerIdentifier runtime.Identifier = "raw-protobuf" | ||||
| 
 | ||||
| // Decode attempts to convert the provided data into a protobuf message, extract the stored schema kind, apply the provided default
 | ||||
| // gvk, and then load that data into an object matching the desired schema kind or the provided into. If into is *runtime.Unknown,
 | ||||
| // the raw data will be extracted and no decoding will be performed. If into is not registered with the typer, then the object will
 | ||||
|  | @ -332,20 +331,6 @@ func (s *RawSerializer) Decode(originalData []byte, gvk *schema.GroupVersionKind | |||
| 		return nil, nil, fmt.Errorf("this serializer requires an object to decode into: %#v", s) | ||||
| 	} | ||||
| 
 | ||||
| 	if versioned, ok := into.(*runtime.VersionedObjects); ok { | ||||
| 		into = versioned.Last() | ||||
| 		obj, actual, err := s.Decode(originalData, gvk, into) | ||||
| 		if err != nil { | ||||
| 			return nil, actual, err | ||||
| 		} | ||||
| 		if into != nil && into != obj { | ||||
| 			versioned.Objects = []runtime.Object{obj, into} | ||||
| 		} else { | ||||
| 			versioned.Objects = []runtime.Object{obj} | ||||
| 		} | ||||
| 		return versioned, actual, err | ||||
| 	} | ||||
| 
 | ||||
| 	if len(originalData) == 0 { | ||||
| 		// TODO: treat like decoding {} from JSON with defaulting
 | ||||
| 		return nil, nil, fmt.Errorf("empty data") | ||||
|  | @ -419,6 +404,13 @@ func unmarshalToObject(typer runtime.ObjectTyper, creater runtime.ObjectCreater, | |||
| 
 | ||||
| // Encode serializes the provided object to the given writer. Overrides is ignored.
 | ||||
| func (s *RawSerializer) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	if co, ok := obj.(runtime.CacheableObject); ok { | ||||
| 		return co.CacheEncode(s.Identifier(), s.doEncode, w) | ||||
| 	} | ||||
| 	return s.doEncode(obj, w) | ||||
| } | ||||
| 
 | ||||
| func (s *RawSerializer) doEncode(obj runtime.Object, w io.Writer) error { | ||||
| 	switch t := obj.(type) { | ||||
| 	case bufferedReverseMarshaller: | ||||
| 		// this path performs a single allocation during write but requires the caller to implement
 | ||||
|  | @ -460,6 +452,11 @@ func (s *RawSerializer) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (s *RawSerializer) Identifier() runtime.Identifier { | ||||
| 	return rawSerializerIdentifier | ||||
| } | ||||
| 
 | ||||
| var LengthDelimitedFramer = lengthDelimitedFramer{} | ||||
| 
 | ||||
| type lengthDelimitedFramer struct{} | ||||
|  |  | |||
|  | @ -17,12 +17,15 @@ limitations under the License. | |||
| package versioning | ||||
| 
 | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| 	"io" | ||||
| 	"reflect" | ||||
| 	"sync" | ||||
| 
 | ||||
| 	"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| 	"k8s.io/klog" | ||||
| ) | ||||
| 
 | ||||
| // NewDefaultingCodecForScheme is a convenience method for callers that are using a scheme.
 | ||||
|  | @ -62,6 +65,8 @@ func NewCodec( | |||
| 		encodeVersion: encodeVersion, | ||||
| 		decodeVersion: decodeVersion, | ||||
| 
 | ||||
| 		identifier: identifier(encodeVersion, encoder), | ||||
| 
 | ||||
| 		originalSchemeName: originalSchemeName, | ||||
| 	} | ||||
| 	return internal | ||||
|  | @ -78,19 +83,47 @@ type codec struct { | |||
| 	encodeVersion runtime.GroupVersioner | ||||
| 	decodeVersion runtime.GroupVersioner | ||||
| 
 | ||||
| 	identifier runtime.Identifier | ||||
| 
 | ||||
| 	// originalSchemeName is optional, but when filled in it holds the name of the scheme from which this codec originates
 | ||||
| 	originalSchemeName string | ||||
| } | ||||
| 
 | ||||
| var identifiersMap sync.Map | ||||
| 
 | ||||
| type codecIdentifier struct { | ||||
| 	EncodeGV string `json:"encodeGV,omitempty"` | ||||
| 	Encoder  string `json:"encoder,omitempty"` | ||||
| 	Name     string `json:"name,omitempty"` | ||||
| } | ||||
| 
 | ||||
| // identifier computes Identifier of Encoder based on codec parameters.
 | ||||
| func identifier(encodeGV runtime.GroupVersioner, encoder runtime.Encoder) runtime.Identifier { | ||||
| 	result := codecIdentifier{ | ||||
| 		Name: "versioning", | ||||
| 	} | ||||
| 
 | ||||
| 	if encodeGV != nil { | ||||
| 		result.EncodeGV = encodeGV.Identifier() | ||||
| 	} | ||||
| 	if encoder != nil { | ||||
| 		result.Encoder = string(encoder.Identifier()) | ||||
| 	} | ||||
| 	if id, ok := identifiersMap.Load(result); ok { | ||||
| 		return id.(runtime.Identifier) | ||||
| 	} | ||||
| 	identifier, err := json.Marshal(result) | ||||
| 	if err != nil { | ||||
| 		klog.Fatalf("Failed marshaling identifier for codec: %v", err) | ||||
| 	} | ||||
| 	identifiersMap.Store(result, runtime.Identifier(identifier)) | ||||
| 	return runtime.Identifier(identifier) | ||||
| } | ||||
| 
 | ||||
| // Decode attempts a decode of the object, then tries to convert it to the internal version. If into is provided and the decoding is
 | ||||
| // successful, the returned runtime.Object will be the value passed as into. Note that this may bypass conversion if you pass an
 | ||||
| // into that matches the serialized version.
 | ||||
| func (c *codec) Decode(data []byte, defaultGVK *schema.GroupVersionKind, into runtime.Object) (runtime.Object, *schema.GroupVersionKind, error) { | ||||
| 	versioned, isVersioned := into.(*runtime.VersionedObjects) | ||||
| 	if isVersioned { | ||||
| 		into = versioned.Last() | ||||
| 	} | ||||
| 
 | ||||
| 	// If the into object is unstructured and expresses an opinion about its group/version,
 | ||||
| 	// create a new instance of the type so we always exercise the conversion path (skips short-circuiting on `into == obj`)
 | ||||
| 	decodeInto := into | ||||
|  | @ -115,22 +148,11 @@ func (c *codec) Decode(data []byte, defaultGVK *schema.GroupVersionKind, into ru | |||
| 	if into != nil { | ||||
| 		// perform defaulting if requested
 | ||||
| 		if c.defaulter != nil { | ||||
| 			// create a copy to ensure defaulting is not applied to the original versioned objects
 | ||||
| 			if isVersioned { | ||||
| 				versioned.Objects = []runtime.Object{obj.DeepCopyObject()} | ||||
| 			} | ||||
| 			c.defaulter.Default(obj) | ||||
| 		} else { | ||||
| 			if isVersioned { | ||||
| 				versioned.Objects = []runtime.Object{obj} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		// Short-circuit conversion if the into object is same object
 | ||||
| 		if into == obj { | ||||
| 			if isVersioned { | ||||
| 				return versioned, gvk, nil | ||||
| 			} | ||||
| 			return into, gvk, nil | ||||
| 		} | ||||
| 
 | ||||
|  | @ -138,19 +160,9 @@ func (c *codec) Decode(data []byte, defaultGVK *schema.GroupVersionKind, into ru | |||
| 			return nil, gvk, err | ||||
| 		} | ||||
| 
 | ||||
| 		if isVersioned { | ||||
| 			versioned.Objects = append(versioned.Objects, into) | ||||
| 			return versioned, gvk, nil | ||||
| 		} | ||||
| 		return into, gvk, nil | ||||
| 	} | ||||
| 
 | ||||
| 	// Convert if needed.
 | ||||
| 	if isVersioned { | ||||
| 		// create a copy, because ConvertToVersion does not guarantee non-mutation of objects
 | ||||
| 		versioned.Objects = []runtime.Object{obj.DeepCopyObject()} | ||||
| 	} | ||||
| 
 | ||||
| 	// perform defaulting if requested
 | ||||
| 	if c.defaulter != nil { | ||||
| 		c.defaulter.Default(obj) | ||||
|  | @ -160,18 +172,19 @@ func (c *codec) Decode(data []byte, defaultGVK *schema.GroupVersionKind, into ru | |||
| 	if err != nil { | ||||
| 		return nil, gvk, err | ||||
| 	} | ||||
| 	if isVersioned { | ||||
| 		if versioned.Last() != out { | ||||
| 			versioned.Objects = append(versioned.Objects, out) | ||||
| 		} | ||||
| 		return versioned, gvk, nil | ||||
| 	} | ||||
| 	return out, gvk, nil | ||||
| } | ||||
| 
 | ||||
| // Encode ensures the provided object is output in the appropriate group and version, invoking
 | ||||
| // conversion if necessary. Unversioned objects (according to the ObjectTyper) are output as is.
 | ||||
| func (c *codec) Encode(obj runtime.Object, w io.Writer) error { | ||||
| 	if co, ok := obj.(runtime.CacheableObject); ok { | ||||
| 		return co.CacheEncode(c.Identifier(), c.doEncode, w) | ||||
| 	} | ||||
| 	return c.doEncode(obj, w) | ||||
| } | ||||
| 
 | ||||
| func (c *codec) doEncode(obj runtime.Object, w io.Writer) error { | ||||
| 	switch obj := obj.(type) { | ||||
| 	case *runtime.Unknown: | ||||
| 		return c.encoder.Encode(obj, w) | ||||
|  | @ -230,3 +243,8 @@ func (c *codec) Encode(obj runtime.Object, w io.Writer) error { | |||
| 	// Conversion is responsible for setting the proper group, version, and kind onto the outgoing object
 | ||||
| 	return c.encoder.Encode(out, w) | ||||
| } | ||||
| 
 | ||||
| // Identifier implements runtime.Encoder interface.
 | ||||
| func (c *codec) Identifier() runtime.Identifier { | ||||
| 	return c.identifier | ||||
| } | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
		Reference in New Issue