(feat) Add auto-discovery in k8s | Adarsh
This commit is contained in:
		
							
								
								
									
										202
									
								
								vendor/k8s.io/api/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								vendor/k8s.io/api/LICENSE
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,202 @@ | ||||
|  | ||||
|                                  Apache License | ||||
|                            Version 2.0, January 2004 | ||||
|                         http://www.apache.org/licenses/ | ||||
|  | ||||
|    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
|    1. Definitions. | ||||
|  | ||||
|       "License" shall mean the terms and conditions for use, reproduction, | ||||
|       and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
|       "Licensor" shall mean the copyright owner or entity authorized by | ||||
|       the copyright owner that is granting the License. | ||||
|  | ||||
|       "Legal Entity" shall mean the union of the acting entity and all | ||||
|       other entities that control, are controlled by, or are under common | ||||
|       control with that entity. For the purposes of this definition, | ||||
|       "control" means (i) the power, direct or indirect, to cause the | ||||
|       direction or management of such entity, whether by contract or | ||||
|       otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||
|       outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
|       "You" (or "Your") shall mean an individual or Legal Entity | ||||
|       exercising permissions granted by this License. | ||||
|  | ||||
|       "Source" form shall mean the preferred form for making modifications, | ||||
|       including but not limited to software source code, documentation | ||||
|       source, and configuration files. | ||||
|  | ||||
|       "Object" form shall mean any form resulting from mechanical | ||||
|       transformation or translation of a Source form, including but | ||||
|       not limited to compiled object code, generated documentation, | ||||
|       and conversions to other media types. | ||||
|  | ||||
|       "Work" shall mean the work of authorship, whether in Source or | ||||
|       Object form, made available under the License, as indicated by a | ||||
|       copyright notice that is included in or attached to the work | ||||
|       (an example is provided in the Appendix below). | ||||
|  | ||||
|       "Derivative Works" shall mean any work, whether in Source or Object | ||||
|       form, that is based on (or derived from) the Work and for which the | ||||
|       editorial revisions, annotations, elaborations, or other modifications | ||||
|       represent, as a whole, an original work of authorship. For the purposes | ||||
|       of this License, Derivative Works shall not include works that remain | ||||
|       separable from, or merely link (or bind by name) to the interfaces of, | ||||
|       the Work and Derivative Works thereof. | ||||
|  | ||||
|       "Contribution" shall mean any work of authorship, including | ||||
|       the original version of the Work and any modifications or additions | ||||
|       to that Work or Derivative Works thereof, that is intentionally | ||||
|       submitted to Licensor for inclusion in the Work by the copyright owner | ||||
|       or by an individual or Legal Entity authorized to submit on behalf of | ||||
|       the copyright owner. For the purposes of this definition, "submitted" | ||||
|       means any form of electronic, verbal, or written communication sent | ||||
|       to the Licensor or its representatives, including but not limited to | ||||
|       communication on electronic mailing lists, source code control systems, | ||||
|       and issue tracking systems that are managed by, or on behalf of, the | ||||
|       Licensor for the purpose of discussing and improving the Work, but | ||||
|       excluding communication that is conspicuously marked or otherwise | ||||
|       designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
|       "Contributor" shall mean Licensor and any individual or Legal Entity | ||||
|       on behalf of whom a Contribution has been received by Licensor and | ||||
|       subsequently incorporated within the Work. | ||||
|  | ||||
|    2. Grant of Copyright License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       copyright license to reproduce, prepare Derivative Works of, | ||||
|       publicly display, publicly perform, sublicense, and distribute the | ||||
|       Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
|    3. Grant of Patent License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       (except as stated in this section) patent license to make, have made, | ||||
|       use, offer to sell, sell, import, and otherwise transfer the Work, | ||||
|       where such license applies only to those patent claims licensable | ||||
|       by such Contributor that are necessarily infringed by their | ||||
|       Contribution(s) alone or by combination of their Contribution(s) | ||||
|       with the Work to which such Contribution(s) was submitted. If You | ||||
|       institute patent litigation against any entity (including a | ||||
|       cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||
|       or a Contribution incorporated within the Work constitutes direct | ||||
|       or contributory patent infringement, then any patent licenses | ||||
|       granted to You under this License for that Work shall terminate | ||||
|       as of the date such litigation is filed. | ||||
|  | ||||
|    4. Redistribution. You may reproduce and distribute copies of the | ||||
|       Work or Derivative Works thereof in any medium, with or without | ||||
|       modifications, and in Source or Object form, provided that You | ||||
|       meet the following conditions: | ||||
|  | ||||
|       (a) You must give any other recipients of the Work or | ||||
|           Derivative Works a copy of this License; and | ||||
|  | ||||
|       (b) You must cause any modified files to carry prominent notices | ||||
|           stating that You changed the files; and | ||||
|  | ||||
|       (c) You must retain, in the Source form of any Derivative Works | ||||
|           that You distribute, all copyright, patent, trademark, and | ||||
|           attribution notices from the Source form of the Work, | ||||
|           excluding those notices that do not pertain to any part of | ||||
|           the Derivative Works; and | ||||
|  | ||||
|       (d) If the Work includes a "NOTICE" text file as part of its | ||||
|           distribution, then any Derivative Works that You distribute must | ||||
|           include a readable copy of the attribution notices contained | ||||
|           within such NOTICE file, excluding those notices that do not | ||||
|           pertain to any part of the Derivative Works, in at least one | ||||
|           of the following places: within a NOTICE text file distributed | ||||
|           as part of the Derivative Works; within the Source form or | ||||
|           documentation, if provided along with the Derivative Works; or, | ||||
|           within a display generated by the Derivative Works, if and | ||||
|           wherever such third-party notices normally appear. The contents | ||||
|           of the NOTICE file are for informational purposes only and | ||||
|           do not modify the License. You may add Your own attribution | ||||
|           notices within Derivative Works that You distribute, alongside | ||||
|           or as an addendum to the NOTICE text from the Work, provided | ||||
|           that such additional attribution notices cannot be construed | ||||
|           as modifying the License. | ||||
|  | ||||
|       You may add Your own copyright statement to Your modifications and | ||||
|       may provide additional or different license terms and conditions | ||||
|       for use, reproduction, or distribution of Your modifications, or | ||||
|       for any such Derivative Works as a whole, provided Your use, | ||||
|       reproduction, and distribution of the Work otherwise complies with | ||||
|       the conditions stated in this License. | ||||
|  | ||||
|    5. Submission of Contributions. Unless You explicitly state otherwise, | ||||
|       any Contribution intentionally submitted for inclusion in the Work | ||||
|       by You to the Licensor shall be under the terms and conditions of | ||||
|       this License, without any additional terms or conditions. | ||||
|       Notwithstanding the above, nothing herein shall supersede or modify | ||||
|       the terms of any separate license agreement you may have executed | ||||
|       with Licensor regarding such Contributions. | ||||
|  | ||||
|    6. Trademarks. This License does not grant permission to use the trade | ||||
|       names, trademarks, service marks, or product names of the Licensor, | ||||
|       except as required for reasonable and customary use in describing the | ||||
|       origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
|    7. Disclaimer of Warranty. Unless required by applicable law or | ||||
|       agreed to in writing, Licensor provides the Work (and each | ||||
|       Contributor provides its Contributions) on an "AS IS" BASIS, | ||||
|       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
|       implied, including, without limitation, any warranties or conditions | ||||
|       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||
|       PARTICULAR PURPOSE. You are solely responsible for determining the | ||||
|       appropriateness of using or redistributing the Work and assume any | ||||
|       risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
|    8. Limitation of Liability. In no event and under no legal theory, | ||||
|       whether in tort (including negligence), contract, or otherwise, | ||||
|       unless required by applicable law (such as deliberate and grossly | ||||
|       negligent acts) or agreed to in writing, shall any Contributor be | ||||
|       liable to You for damages, including any direct, indirect, special, | ||||
|       incidental, or consequential damages of any character arising as a | ||||
|       result of this License or out of the use or inability to use the | ||||
|       Work (including but not limited to damages for loss of goodwill, | ||||
|       work stoppage, computer failure or malfunction, or any and all | ||||
|       other commercial damages or losses), even if such Contributor | ||||
|       has been advised of the possibility of such damages. | ||||
|  | ||||
|    9. Accepting Warranty or Additional Liability. While redistributing | ||||
|       the Work or Derivative Works thereof, You may choose to offer, | ||||
|       and charge a fee for, acceptance of support, warranty, indemnity, | ||||
|       or other liability obligations and/or rights consistent with this | ||||
|       License. However, in accepting such obligations, You may act only | ||||
|       on Your own behalf and on Your sole responsibility, not on behalf | ||||
|       of any other Contributor, and only if You agree to indemnify, | ||||
|       defend, and hold each Contributor harmless for any liability | ||||
|       incurred by, or claims asserted against, such Contributor by reason | ||||
|       of your accepting any such warranty or additional liability. | ||||
|  | ||||
|    END OF TERMS AND CONDITIONS | ||||
|  | ||||
|    APPENDIX: How to apply the Apache License to your work. | ||||
|  | ||||
|       To apply the Apache License to your work, attach the following | ||||
|       boilerplate notice, with the fields enclosed by brackets "[]" | ||||
|       replaced with your own identifying information. (Don't include | ||||
|       the brackets!)  The text should be enclosed in the appropriate | ||||
|       comment syntax for the file format. We also recommend that a | ||||
|       file or class name and description of purpose be included on the | ||||
|       same "printed page" as the copyright notice for easier | ||||
|       identification within third-party archives. | ||||
|  | ||||
|    Copyright [yyyy] [name of copyright owner] | ||||
|  | ||||
|    Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|    you may not use this file except in compliance with the License. | ||||
|    You may obtain a copy of the License at | ||||
|  | ||||
|        http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|    Unless required by applicable law or agreed to in writing, software | ||||
|    distributed under the License is distributed on an "AS IS" BASIS, | ||||
|    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|    See the License for the specific language governing permissions and | ||||
|    limitations under the License. | ||||
							
								
								
									
										26
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,26 @@ | ||||
| /* | ||||
| Copyright 2017 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
| // +groupName=admissionregistration.k8s.io | ||||
|  | ||||
| // Package v1beta1 is the v1beta1 version of the API. | ||||
| // AdmissionConfiguration and AdmissionPluginConfiguration are legacy static admission plugin configuration | ||||
| // MutatingWebhookConfiguration and ValidatingWebhookConfiguration are for the | ||||
| // new dynamic admission controller configuration. | ||||
| package v1beta1 // import "k8s.io/api/admissionregistration/v1beta1" | ||||
							
								
								
									
										2302
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2302
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										300
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										300
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,300 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.admissionregistration.v1beta1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta1"; | ||||
|  | ||||
| // MutatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and may change the object. | ||||
| message MutatingWebhookConfiguration { | ||||
|   // Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Webhooks is a list of webhooks and the affected resources and operations. | ||||
|   // +optional | ||||
|   // +patchMergeKey=name | ||||
|   // +patchStrategy=merge | ||||
|   repeated Webhook Webhooks = 2; | ||||
| } | ||||
|  | ||||
| // MutatingWebhookConfigurationList is a list of MutatingWebhookConfiguration. | ||||
| message MutatingWebhookConfigurationList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // List of MutatingWebhookConfiguration. | ||||
|   repeated MutatingWebhookConfiguration items = 2; | ||||
| } | ||||
|  | ||||
| // Rule is a tuple of APIGroups, APIVersion, and Resources.It is recommended | ||||
| // to make sure that all the tuple expansions are valid. | ||||
| message Rule { | ||||
|   // APIGroups is the API groups the resources belong to. '*' is all groups. | ||||
|   // If '*' is present, the length of the slice must be one. | ||||
|   // Required. | ||||
|   repeated string apiGroups = 1; | ||||
|  | ||||
|   // APIVersions is the API versions the resources belong to. '*' is all versions. | ||||
|   // If '*' is present, the length of the slice must be one. | ||||
|   // Required. | ||||
|   repeated string apiVersions = 2; | ||||
|  | ||||
|   // Resources is a list of resources this rule applies to. | ||||
|   // | ||||
|   // For example: | ||||
|   // 'pods' means pods. | ||||
|   // 'pods/log' means the log subresource of pods. | ||||
|   // '*' means all resources, but not subresources. | ||||
|   // 'pods/*' means all subresources of pods. | ||||
|   // '*/scale' means all scale subresources. | ||||
|   // '*/*' means all resources and their subresources. | ||||
|   // | ||||
|   // If wildcard is present, the validation rule will ensure resources do not | ||||
|   // overlap with each other. | ||||
|   // | ||||
|   // Depending on the enclosing object, subresources might not be allowed. | ||||
|   // Required. | ||||
|   repeated string resources = 3; | ||||
|  | ||||
|   // scope specifies the scope of this rule. | ||||
|   // Valid values are "Cluster", "Namespaced", and "*" | ||||
|   // "Cluster" means that only cluster-scoped resources will match this rule. | ||||
|   // Namespace API objects are cluster-scoped. | ||||
|   // "Namespaced" means that only namespaced resources will match this rule. | ||||
|   // "*" means that there are no scope restrictions. | ||||
|   // Subresources match the scope of their parent resource. | ||||
|   // Default is "*". | ||||
|   // | ||||
|   // +optional | ||||
|   optional string scope = 4; | ||||
| } | ||||
|  | ||||
| // RuleWithOperations is a tuple of Operations and Resources. It is recommended to make | ||||
| // sure that all the tuple expansions are valid. | ||||
| message RuleWithOperations { | ||||
|   // Operations is the operations the admission hook cares about - CREATE, UPDATE, or * | ||||
|   // for all operations. | ||||
|   // If '*' is present, the length of the slice must be one. | ||||
|   // Required. | ||||
|   repeated string operations = 1; | ||||
|  | ||||
|   // Rule is embedded, it describes other criteria of the rule, like | ||||
|   // APIGroups, APIVersions, Resources, etc. | ||||
|   optional Rule rule = 2; | ||||
| } | ||||
|  | ||||
| // ServiceReference holds a reference to Service.legacy.k8s.io | ||||
| message ServiceReference { | ||||
|   // `namespace` is the namespace of the service. | ||||
|   // Required | ||||
|   optional string namespace = 1; | ||||
|  | ||||
|   // `name` is the name of the service. | ||||
|   // Required | ||||
|   optional string name = 2; | ||||
|  | ||||
|   // `path` is an optional URL path which will be sent in any request to | ||||
|   // this service. | ||||
|   // +optional | ||||
|   optional string path = 3; | ||||
| } | ||||
|  | ||||
| // ValidatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and object without changing it. | ||||
| message ValidatingWebhookConfiguration { | ||||
|   // Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Webhooks is a list of webhooks and the affected resources and operations. | ||||
|   // +optional | ||||
|   // +patchMergeKey=name | ||||
|   // +patchStrategy=merge | ||||
|   repeated Webhook Webhooks = 2; | ||||
| } | ||||
|  | ||||
| // ValidatingWebhookConfigurationList is a list of ValidatingWebhookConfiguration. | ||||
| message ValidatingWebhookConfigurationList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // List of ValidatingWebhookConfiguration. | ||||
|   repeated ValidatingWebhookConfiguration items = 2; | ||||
| } | ||||
|  | ||||
| // Webhook describes an admission webhook and the resources and operations it applies to. | ||||
| message Webhook { | ||||
|   // The name of the admission webhook. | ||||
|   // Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where | ||||
|   // "imagepolicy" is the name of the webhook, and kubernetes.io is the name | ||||
|   // of the organization. | ||||
|   // Required. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // ClientConfig defines how to communicate with the hook. | ||||
|   // Required | ||||
|   optional WebhookClientConfig clientConfig = 2; | ||||
|  | ||||
|   // Rules describes what operations on what resources/subresources the webhook cares about. | ||||
|   // The webhook cares about an operation if it matches _any_ Rule. | ||||
|   // However, in order to prevent ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks | ||||
|   // from putting the cluster in a state which cannot be recovered from without completely | ||||
|   // disabling the plugin, ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks are never called | ||||
|   // on admission requests for ValidatingWebhookConfiguration and MutatingWebhookConfiguration objects. | ||||
|   repeated RuleWithOperations rules = 3; | ||||
|  | ||||
|   // FailurePolicy defines how unrecognized errors from the admission endpoint are handled - | ||||
|   // allowed values are Ignore or Fail. Defaults to Ignore. | ||||
|   // +optional | ||||
|   optional string failurePolicy = 4; | ||||
|  | ||||
|   // NamespaceSelector decides whether to run the webhook on an object based | ||||
|   // on whether the namespace for that object matches the selector. If the | ||||
|   // object itself is a namespace, the matching is performed on | ||||
|   // object.metadata.labels. If the object is another cluster scoped resource, | ||||
|   // it never skips the webhook. | ||||
|   // | ||||
|   // For example, to run the webhook on any objects whose namespace is not | ||||
|   // associated with "runlevel" of "0" or "1";  you will set the selector as | ||||
|   // follows: | ||||
|   // "namespaceSelector": { | ||||
|   //   "matchExpressions": [ | ||||
|   //     { | ||||
|   //       "key": "runlevel", | ||||
|   //       "operator": "NotIn", | ||||
|   //       "values": [ | ||||
|   //         "0", | ||||
|   //         "1" | ||||
|   //       ] | ||||
|   //     } | ||||
|   //   ] | ||||
|   // } | ||||
|   // | ||||
|   // If instead you want to only run the webhook on any objects whose | ||||
|   // namespace is associated with the "environment" of "prod" or "staging"; | ||||
|   // you will set the selector as follows: | ||||
|   // "namespaceSelector": { | ||||
|   //   "matchExpressions": [ | ||||
|   //     { | ||||
|   //       "key": "environment", | ||||
|   //       "operator": "In", | ||||
|   //       "values": [ | ||||
|   //         "prod", | ||||
|   //         "staging" | ||||
|   //       ] | ||||
|   //     } | ||||
|   //   ] | ||||
|   // } | ||||
|   // | ||||
|   // See | ||||
|   // https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/ | ||||
|   // for more examples of label selectors. | ||||
|   // | ||||
|   // Default to the empty LabelSelector, which matches everything. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector namespaceSelector = 5; | ||||
|  | ||||
|   // SideEffects states whether this webhookk has side effects. | ||||
|   // Acceptable values are: Unknown, None, Some, NoneOnDryRun | ||||
|   // Webhooks with side effects MUST implement a reconciliation system, since a request may be | ||||
|   // rejected by a future step in the admission change and the side effects therefore need to be undone. | ||||
|   // Requests with the dryRun attribute will be auto-rejected if they match a webhook with | ||||
|   // sideEffects == Unknown or Some. Defaults to Unknown. | ||||
|   // +optional | ||||
|   optional string sideEffects = 6; | ||||
|  | ||||
|   // TimeoutSeconds specifies the timeout for this webhook. After the timeout passes, | ||||
|   // the webhook call will be ignored or the API call will fail based on the | ||||
|   // failure policy. | ||||
|   // The timeout value must be between 1 and 30 seconds. | ||||
|   // Default to 30 seconds. | ||||
|   // +optional | ||||
|   optional int32 timeoutSeconds = 7; | ||||
|  | ||||
|   // AdmissionReviewVersions is an ordered list of preferred `AdmissionReview` | ||||
|   // versions the Webhook expects. API server will try to use first version in | ||||
|   // the list which it supports. If none of the versions specified in this list | ||||
|   // supported by API server, validation will fail for this object. | ||||
|   // If a persisted webhook configuration specifies allowed versions and does not | ||||
|   // include any versions known to the API Server, calls to the webhook will fail | ||||
|   // and be subject to the failure policy. | ||||
|   // Default to `['v1beta1']`. | ||||
|   // +optional | ||||
|   repeated string admissionReviewVersions = 8; | ||||
| } | ||||
|  | ||||
| // WebhookClientConfig contains the information to make a TLS | ||||
| // connection with the webhook | ||||
| message WebhookClientConfig { | ||||
|   // `url` gives the location of the webhook, in standard URL form | ||||
|   // (`scheme://host:port/path`). Exactly one of `url` or `service` | ||||
|   // must be specified. | ||||
|   // | ||||
|   // The `host` should not refer to a service running in the cluster; use | ||||
|   // the `service` field instead. The host might be resolved via external | ||||
|   // DNS in some apiservers (e.g., `kube-apiserver` cannot resolve | ||||
|   // in-cluster DNS as that would be a layering violation). `host` may | ||||
|   // also be an IP address. | ||||
|   // | ||||
|   // Please note that using `localhost` or `127.0.0.1` as a `host` is | ||||
|   // risky unless you take great care to run this webhook on all hosts | ||||
|   // which run an apiserver which might need to make calls to this | ||||
|   // webhook. Such installs are likely to be non-portable, i.e., not easy | ||||
|   // to turn up in a new cluster. | ||||
|   // | ||||
|   // The scheme must be "https"; the URL must begin with "https://". | ||||
|   // | ||||
|   // A path is optional, and if present may be any string permissible in | ||||
|   // a URL. You may use the path to pass an arbitrary string to the | ||||
|   // webhook, for example, a cluster identifier. | ||||
|   // | ||||
|   // Attempting to use a user or basic auth e.g. "user:password@" is not | ||||
|   // allowed. Fragments ("#...") and query parameters ("?...") are not | ||||
|   // allowed, either. | ||||
|   // | ||||
|   // +optional | ||||
|   optional string url = 3; | ||||
|  | ||||
|   // `service` is a reference to the service for this webhook. Either | ||||
|   // `service` or `url` must be specified. | ||||
|   // | ||||
|   // If the webhook is running within the cluster, then you should use `service`. | ||||
|   // | ||||
|   // Port 443 will be used if it is open, otherwise it is an error. | ||||
|   // | ||||
|   // +optional | ||||
|   optional ServiceReference service = 1; | ||||
|  | ||||
|   // `caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. | ||||
|   // If unspecified, system trust roots on the apiserver are used. | ||||
|   // +optional | ||||
|   optional bytes caBundle = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										53
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| /* | ||||
| Copyright 2017 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| const GroupName = "admissionregistration.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&ValidatingWebhookConfiguration{}, | ||||
| 		&ValidatingWebhookConfigurationList{}, | ||||
| 		&MutatingWebhookConfiguration{}, | ||||
| 		&MutatingWebhookConfigurationList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										349
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										349
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,349 @@ | ||||
| /* | ||||
| Copyright 2017 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // Rule is a tuple of APIGroups, APIVersion, and Resources.It is recommended | ||||
| // to make sure that all the tuple expansions are valid. | ||||
| type Rule struct { | ||||
| 	// APIGroups is the API groups the resources belong to. '*' is all groups. | ||||
| 	// If '*' is present, the length of the slice must be one. | ||||
| 	// Required. | ||||
| 	APIGroups []string `json:"apiGroups,omitempty" protobuf:"bytes,1,rep,name=apiGroups"` | ||||
|  | ||||
| 	// APIVersions is the API versions the resources belong to. '*' is all versions. | ||||
| 	// If '*' is present, the length of the slice must be one. | ||||
| 	// Required. | ||||
| 	APIVersions []string `json:"apiVersions,omitempty" protobuf:"bytes,2,rep,name=apiVersions"` | ||||
|  | ||||
| 	// Resources is a list of resources this rule applies to. | ||||
| 	// | ||||
| 	// For example: | ||||
| 	// 'pods' means pods. | ||||
| 	// 'pods/log' means the log subresource of pods. | ||||
| 	// '*' means all resources, but not subresources. | ||||
| 	// 'pods/*' means all subresources of pods. | ||||
| 	// '*/scale' means all scale subresources. | ||||
| 	// '*/*' means all resources and their subresources. | ||||
| 	// | ||||
| 	// If wildcard is present, the validation rule will ensure resources do not | ||||
| 	// overlap with each other. | ||||
| 	// | ||||
| 	// Depending on the enclosing object, subresources might not be allowed. | ||||
| 	// Required. | ||||
| 	Resources []string `json:"resources,omitempty" protobuf:"bytes,3,rep,name=resources"` | ||||
|  | ||||
| 	// scope specifies the scope of this rule. | ||||
| 	// Valid values are "Cluster", "Namespaced", and "*" | ||||
| 	// "Cluster" means that only cluster-scoped resources will match this rule. | ||||
| 	// Namespace API objects are cluster-scoped. | ||||
| 	// "Namespaced" means that only namespaced resources will match this rule. | ||||
| 	// "*" means that there are no scope restrictions. | ||||
| 	// Subresources match the scope of their parent resource. | ||||
| 	// Default is "*". | ||||
| 	// | ||||
| 	// +optional | ||||
| 	Scope *ScopeType `json:"scope,omitempty" protobuf:"bytes,4,rep,name=scope"` | ||||
| } | ||||
|  | ||||
| type ScopeType string | ||||
|  | ||||
| const ( | ||||
| 	// ClusterScope means that scope is limited to cluster-scoped objects. | ||||
| 	// Namespace objects are cluster-scoped. | ||||
| 	ClusterScope ScopeType = "Cluster" | ||||
| 	// NamespacedScope means that scope is limited to namespaced objects. | ||||
| 	NamespacedScope ScopeType = "Namespaced" | ||||
| 	// AllScopes means that all scopes are included. | ||||
| 	AllScopes ScopeType = "*" | ||||
| ) | ||||
|  | ||||
| type FailurePolicyType string | ||||
|  | ||||
| const ( | ||||
| 	// Ignore means that an error calling the webhook is ignored. | ||||
| 	Ignore FailurePolicyType = "Ignore" | ||||
| 	// Fail means that an error calling the webhook causes the admission to fail. | ||||
| 	Fail FailurePolicyType = "Fail" | ||||
| ) | ||||
|  | ||||
| type SideEffectClass string | ||||
|  | ||||
| const ( | ||||
| 	// SideEffectClassUnknown means that no information is known about the side effects of calling the webhook. | ||||
| 	// If a request with the dry-run attribute would trigger a call to this webhook, the request will instead fail. | ||||
| 	SideEffectClassUnknown SideEffectClass = "Unknown" | ||||
| 	// SideEffectClassNone means that calling the webhook will have no side effects. | ||||
| 	SideEffectClassNone SideEffectClass = "None" | ||||
| 	// SideEffectClassSome means that calling the webhook will possibly have side effects. | ||||
| 	// If a request with the dry-run attribute would trigger a call to this webhook, the request will instead fail. | ||||
| 	SideEffectClassSome SideEffectClass = "Some" | ||||
| 	// SideEffectClassNoneOnDryRun means that calling the webhook will possibly have side effects, but if the | ||||
| 	// request being reviewed has the dry-run attribute, the side effects will be suppressed. | ||||
| 	SideEffectClassNoneOnDryRun SideEffectClass = "NoneOnDryRun" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ValidatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and object without changing it. | ||||
| type ValidatingWebhookConfiguration struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// Webhooks is a list of webhooks and the affected resources and operations. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=name | ||||
| 	// +patchStrategy=merge | ||||
| 	Webhooks []Webhook `json:"webhooks,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=Webhooks"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ValidatingWebhookConfigurationList is a list of ValidatingWebhookConfiguration. | ||||
| type ValidatingWebhookConfigurationList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// List of ValidatingWebhookConfiguration. | ||||
| 	Items []ValidatingWebhookConfiguration `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // MutatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and may change the object. | ||||
| type MutatingWebhookConfiguration struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// Webhooks is a list of webhooks and the affected resources and operations. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=name | ||||
| 	// +patchStrategy=merge | ||||
| 	Webhooks []Webhook `json:"webhooks,omitempty" patchStrategy:"merge" patchMergeKey:"name" protobuf:"bytes,2,rep,name=Webhooks"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // MutatingWebhookConfigurationList is a list of MutatingWebhookConfiguration. | ||||
| type MutatingWebhookConfigurationList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	// List of MutatingWebhookConfiguration. | ||||
| 	Items []MutatingWebhookConfiguration `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // Webhook describes an admission webhook and the resources and operations it applies to. | ||||
| type Webhook struct { | ||||
| 	// The name of the admission webhook. | ||||
| 	// Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where | ||||
| 	// "imagepolicy" is the name of the webhook, and kubernetes.io is the name | ||||
| 	// of the organization. | ||||
| 	// Required. | ||||
| 	Name string `json:"name" protobuf:"bytes,1,opt,name=name"` | ||||
|  | ||||
| 	// ClientConfig defines how to communicate with the hook. | ||||
| 	// Required | ||||
| 	ClientConfig WebhookClientConfig `json:"clientConfig" protobuf:"bytes,2,opt,name=clientConfig"` | ||||
|  | ||||
| 	// Rules describes what operations on what resources/subresources the webhook cares about. | ||||
| 	// The webhook cares about an operation if it matches _any_ Rule. | ||||
| 	// However, in order to prevent ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks | ||||
| 	// from putting the cluster in a state which cannot be recovered from without completely | ||||
| 	// disabling the plugin, ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks are never called | ||||
| 	// on admission requests for ValidatingWebhookConfiguration and MutatingWebhookConfiguration objects. | ||||
| 	Rules []RuleWithOperations `json:"rules,omitempty" protobuf:"bytes,3,rep,name=rules"` | ||||
|  | ||||
| 	// FailurePolicy defines how unrecognized errors from the admission endpoint are handled - | ||||
| 	// allowed values are Ignore or Fail. Defaults to Ignore. | ||||
| 	// +optional | ||||
| 	FailurePolicy *FailurePolicyType `json:"failurePolicy,omitempty" protobuf:"bytes,4,opt,name=failurePolicy,casttype=FailurePolicyType"` | ||||
|  | ||||
| 	// NamespaceSelector decides whether to run the webhook on an object based | ||||
| 	// on whether the namespace for that object matches the selector. If the | ||||
| 	// object itself is a namespace, the matching is performed on | ||||
| 	// object.metadata.labels. If the object is another cluster scoped resource, | ||||
| 	// it never skips the webhook. | ||||
| 	// | ||||
| 	// For example, to run the webhook on any objects whose namespace is not | ||||
| 	// associated with "runlevel" of "0" or "1";  you will set the selector as | ||||
| 	// follows: | ||||
| 	// "namespaceSelector": { | ||||
| 	//   "matchExpressions": [ | ||||
| 	//     { | ||||
| 	//       "key": "runlevel", | ||||
| 	//       "operator": "NotIn", | ||||
| 	//       "values": [ | ||||
| 	//         "0", | ||||
| 	//         "1" | ||||
| 	//       ] | ||||
| 	//     } | ||||
| 	//   ] | ||||
| 	// } | ||||
| 	// | ||||
| 	// If instead you want to only run the webhook on any objects whose | ||||
| 	// namespace is associated with the "environment" of "prod" or "staging"; | ||||
| 	// you will set the selector as follows: | ||||
| 	// "namespaceSelector": { | ||||
| 	//   "matchExpressions": [ | ||||
| 	//     { | ||||
| 	//       "key": "environment", | ||||
| 	//       "operator": "In", | ||||
| 	//       "values": [ | ||||
| 	//         "prod", | ||||
| 	//         "staging" | ||||
| 	//       ] | ||||
| 	//     } | ||||
| 	//   ] | ||||
| 	// } | ||||
| 	// | ||||
| 	// See | ||||
| 	// https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/ | ||||
| 	// for more examples of label selectors. | ||||
| 	// | ||||
| 	// Default to the empty LabelSelector, which matches everything. | ||||
| 	// +optional | ||||
| 	NamespaceSelector *metav1.LabelSelector `json:"namespaceSelector,omitempty" protobuf:"bytes,5,opt,name=namespaceSelector"` | ||||
|  | ||||
| 	// SideEffects states whether this webhookk has side effects. | ||||
| 	// Acceptable values are: Unknown, None, Some, NoneOnDryRun | ||||
| 	// Webhooks with side effects MUST implement a reconciliation system, since a request may be | ||||
| 	// rejected by a future step in the admission change and the side effects therefore need to be undone. | ||||
| 	// Requests with the dryRun attribute will be auto-rejected if they match a webhook with | ||||
| 	// sideEffects == Unknown or Some. Defaults to Unknown. | ||||
| 	// +optional | ||||
| 	SideEffects *SideEffectClass `json:"sideEffects,omitempty" protobuf:"bytes,6,opt,name=sideEffects,casttype=SideEffectClass"` | ||||
|  | ||||
| 	// TimeoutSeconds specifies the timeout for this webhook. After the timeout passes, | ||||
| 	// the webhook call will be ignored or the API call will fail based on the | ||||
| 	// failure policy. | ||||
| 	// The timeout value must be between 1 and 30 seconds. | ||||
| 	// Default to 30 seconds. | ||||
| 	// +optional | ||||
| 	TimeoutSeconds *int32 `json:"timeoutSeconds,omitempty" protobuf:"varint,7,opt,name=timeoutSeconds"` | ||||
|  | ||||
| 	// AdmissionReviewVersions is an ordered list of preferred `AdmissionReview` | ||||
| 	// versions the Webhook expects. API server will try to use first version in | ||||
| 	// the list which it supports. If none of the versions specified in this list | ||||
| 	// supported by API server, validation will fail for this object. | ||||
| 	// If a persisted webhook configuration specifies allowed versions and does not | ||||
| 	// include any versions known to the API Server, calls to the webhook will fail | ||||
| 	// and be subject to the failure policy. | ||||
| 	// Default to `['v1beta1']`. | ||||
| 	// +optional | ||||
| 	AdmissionReviewVersions []string `json:"admissionReviewVersions,omitempty" protobuf:"bytes,8,rep,name=admissionReviewVersions"` | ||||
| } | ||||
|  | ||||
| // RuleWithOperations is a tuple of Operations and Resources. It is recommended to make | ||||
| // sure that all the tuple expansions are valid. | ||||
| type RuleWithOperations struct { | ||||
| 	// Operations is the operations the admission hook cares about - CREATE, UPDATE, or * | ||||
| 	// for all operations. | ||||
| 	// If '*' is present, the length of the slice must be one. | ||||
| 	// Required. | ||||
| 	Operations []OperationType `json:"operations,omitempty" protobuf:"bytes,1,rep,name=operations,casttype=OperationType"` | ||||
| 	// Rule is embedded, it describes other criteria of the rule, like | ||||
| 	// APIGroups, APIVersions, Resources, etc. | ||||
| 	Rule `json:",inline" protobuf:"bytes,2,opt,name=rule"` | ||||
| } | ||||
|  | ||||
| type OperationType string | ||||
|  | ||||
| // The constants should be kept in sync with those defined in k8s.io/kubernetes/pkg/admission/interface.go. | ||||
| const ( | ||||
| 	OperationAll OperationType = "*" | ||||
| 	Create       OperationType = "CREATE" | ||||
| 	Update       OperationType = "UPDATE" | ||||
| 	Delete       OperationType = "DELETE" | ||||
| 	Connect      OperationType = "CONNECT" | ||||
| ) | ||||
|  | ||||
| // WebhookClientConfig contains the information to make a TLS | ||||
| // connection with the webhook | ||||
| type WebhookClientConfig struct { | ||||
| 	// `url` gives the location of the webhook, in standard URL form | ||||
| 	// (`scheme://host:port/path`). Exactly one of `url` or `service` | ||||
| 	// must be specified. | ||||
| 	// | ||||
| 	// The `host` should not refer to a service running in the cluster; use | ||||
| 	// the `service` field instead. The host might be resolved via external | ||||
| 	// DNS in some apiservers (e.g., `kube-apiserver` cannot resolve | ||||
| 	// in-cluster DNS as that would be a layering violation). `host` may | ||||
| 	// also be an IP address. | ||||
| 	// | ||||
| 	// Please note that using `localhost` or `127.0.0.1` as a `host` is | ||||
| 	// risky unless you take great care to run this webhook on all hosts | ||||
| 	// which run an apiserver which might need to make calls to this | ||||
| 	// webhook. Such installs are likely to be non-portable, i.e., not easy | ||||
| 	// to turn up in a new cluster. | ||||
| 	// | ||||
| 	// The scheme must be "https"; the URL must begin with "https://". | ||||
| 	// | ||||
| 	// A path is optional, and if present may be any string permissible in | ||||
| 	// a URL. You may use the path to pass an arbitrary string to the | ||||
| 	// webhook, for example, a cluster identifier. | ||||
| 	// | ||||
| 	// Attempting to use a user or basic auth e.g. "user:password@" is not | ||||
| 	// allowed. Fragments ("#...") and query parameters ("?...") are not | ||||
| 	// allowed, either. | ||||
| 	// | ||||
| 	// +optional | ||||
| 	URL *string `json:"url,omitempty" protobuf:"bytes,3,opt,name=url"` | ||||
|  | ||||
| 	// `service` is a reference to the service for this webhook. Either | ||||
| 	// `service` or `url` must be specified. | ||||
| 	// | ||||
| 	// If the webhook is running within the cluster, then you should use `service`. | ||||
| 	// | ||||
| 	// Port 443 will be used if it is open, otherwise it is an error. | ||||
| 	// | ||||
| 	// +optional | ||||
| 	Service *ServiceReference `json:"service,omitempty" protobuf:"bytes,1,opt,name=service"` | ||||
|  | ||||
| 	// `caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. | ||||
| 	// If unspecified, system trust roots on the apiserver are used. | ||||
| 	// +optional | ||||
| 	CABundle []byte `json:"caBundle,omitempty" protobuf:"bytes,2,opt,name=caBundle"` | ||||
| } | ||||
|  | ||||
| // ServiceReference holds a reference to Service.legacy.k8s.io | ||||
| type ServiceReference struct { | ||||
| 	// `namespace` is the namespace of the service. | ||||
| 	// Required | ||||
| 	Namespace string `json:"namespace" protobuf:"bytes,1,opt,name=namespace"` | ||||
| 	// `name` is the name of the service. | ||||
| 	// Required | ||||
| 	Name string `json:"name" protobuf:"bytes,2,opt,name=name"` | ||||
|  | ||||
| 	// `path` is an optional URL path which will be sent in any request to | ||||
| 	// this service. | ||||
| 	// +optional | ||||
| 	Path *string `json:"path,omitempty" protobuf:"bytes,3,opt,name=path"` | ||||
| } | ||||
							
								
								
									
										129
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,129 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_MutatingWebhookConfiguration = map[string]string{ | ||||
| 	"":         "MutatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and may change the object.", | ||||
| 	"metadata": "Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata.", | ||||
| 	"webhooks": "Webhooks is a list of webhooks and the affected resources and operations.", | ||||
| } | ||||
|  | ||||
| func (MutatingWebhookConfiguration) SwaggerDoc() map[string]string { | ||||
| 	return map_MutatingWebhookConfiguration | ||||
| } | ||||
|  | ||||
| var map_MutatingWebhookConfigurationList = map[string]string{ | ||||
| 	"":         "MutatingWebhookConfigurationList is a list of MutatingWebhookConfiguration.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of MutatingWebhookConfiguration.", | ||||
| } | ||||
|  | ||||
| func (MutatingWebhookConfigurationList) SwaggerDoc() map[string]string { | ||||
| 	return map_MutatingWebhookConfigurationList | ||||
| } | ||||
|  | ||||
| var map_Rule = map[string]string{ | ||||
| 	"":            "Rule is a tuple of APIGroups, APIVersion, and Resources.It is recommended to make sure that all the tuple expansions are valid.", | ||||
| 	"apiGroups":   "APIGroups is the API groups the resources belong to. '*' is all groups. If '*' is present, the length of the slice must be one. Required.", | ||||
| 	"apiVersions": "APIVersions is the API versions the resources belong to. '*' is all versions. If '*' is present, the length of the slice must be one. Required.", | ||||
| 	"resources":   "Resources is a list of resources this rule applies to.\n\nFor example: 'pods' means pods. 'pods/log' means the log subresource of pods. '*' means all resources, but not subresources. 'pods/*' means all subresources of pods. '*/scale' means all scale subresources. '*/*' means all resources and their subresources.\n\nIf wildcard is present, the validation rule will ensure resources do not overlap with each other.\n\nDepending on the enclosing object, subresources might not be allowed. Required.", | ||||
| 	"scope":       "scope specifies the scope of this rule. Valid values are \"Cluster\", \"Namespaced\", and \"*\" \"Cluster\" means that only cluster-scoped resources will match this rule. Namespace API objects are cluster-scoped. \"Namespaced\" means that only namespaced resources will match this rule. \"*\" means that there are no scope restrictions. Subresources match the scope of their parent resource. Default is \"*\".", | ||||
| } | ||||
|  | ||||
| func (Rule) SwaggerDoc() map[string]string { | ||||
| 	return map_Rule | ||||
| } | ||||
|  | ||||
| var map_RuleWithOperations = map[string]string{ | ||||
| 	"":           "RuleWithOperations is a tuple of Operations and Resources. It is recommended to make sure that all the tuple expansions are valid.", | ||||
| 	"operations": "Operations is the operations the admission hook cares about - CREATE, UPDATE, or * for all operations. If '*' is present, the length of the slice must be one. Required.", | ||||
| } | ||||
|  | ||||
| func (RuleWithOperations) SwaggerDoc() map[string]string { | ||||
| 	return map_RuleWithOperations | ||||
| } | ||||
|  | ||||
| var map_ServiceReference = map[string]string{ | ||||
| 	"":          "ServiceReference holds a reference to Service.legacy.k8s.io", | ||||
| 	"namespace": "`namespace` is the namespace of the service. Required", | ||||
| 	"name":      "`name` is the name of the service. Required", | ||||
| 	"path":      "`path` is an optional URL path which will be sent in any request to this service.", | ||||
| } | ||||
|  | ||||
| func (ServiceReference) SwaggerDoc() map[string]string { | ||||
| 	return map_ServiceReference | ||||
| } | ||||
|  | ||||
| var map_ValidatingWebhookConfiguration = map[string]string{ | ||||
| 	"":         "ValidatingWebhookConfiguration describes the configuration of and admission webhook that accept or reject and object without changing it.", | ||||
| 	"metadata": "Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata.", | ||||
| 	"webhooks": "Webhooks is a list of webhooks and the affected resources and operations.", | ||||
| } | ||||
|  | ||||
| func (ValidatingWebhookConfiguration) SwaggerDoc() map[string]string { | ||||
| 	return map_ValidatingWebhookConfiguration | ||||
| } | ||||
|  | ||||
| var map_ValidatingWebhookConfigurationList = map[string]string{ | ||||
| 	"":         "ValidatingWebhookConfigurationList is a list of ValidatingWebhookConfiguration.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of ValidatingWebhookConfiguration.", | ||||
| } | ||||
|  | ||||
| func (ValidatingWebhookConfigurationList) SwaggerDoc() map[string]string { | ||||
| 	return map_ValidatingWebhookConfigurationList | ||||
| } | ||||
|  | ||||
| var map_Webhook = map[string]string{ | ||||
| 	"":                        "Webhook describes an admission webhook and the resources and operations it applies to.", | ||||
| 	"name":                    "The name of the admission webhook. Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where \"imagepolicy\" is the name of the webhook, and kubernetes.io is the name of the organization. Required.", | ||||
| 	"clientConfig":            "ClientConfig defines how to communicate with the hook. Required", | ||||
| 	"rules":                   "Rules describes what operations on what resources/subresources the webhook cares about. The webhook cares about an operation if it matches _any_ Rule. However, in order to prevent ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks from putting the cluster in a state which cannot be recovered from without completely disabling the plugin, ValidatingAdmissionWebhooks and MutatingAdmissionWebhooks are never called on admission requests for ValidatingWebhookConfiguration and MutatingWebhookConfiguration objects.", | ||||
| 	"failurePolicy":           "FailurePolicy defines how unrecognized errors from the admission endpoint are handled - allowed values are Ignore or Fail. Defaults to Ignore.", | ||||
| 	"namespaceSelector":       "NamespaceSelector decides whether to run the webhook on an object based on whether the namespace for that object matches the selector. If the object itself is a namespace, the matching is performed on object.metadata.labels. If the object is another cluster scoped resource, it never skips the webhook.\n\nFor example, to run the webhook on any objects whose namespace is not associated with \"runlevel\" of \"0\" or \"1\";  you will set the selector as follows: \"namespaceSelector\": {\n  \"matchExpressions\": [\n    {\n      \"key\": \"runlevel\",\n      \"operator\": \"NotIn\",\n      \"values\": [\n        \"0\",\n        \"1\"\n      ]\n    }\n  ]\n}\n\nIf instead you want to only run the webhook on any objects whose namespace is associated with the \"environment\" of \"prod\" or \"staging\"; you will set the selector as follows: \"namespaceSelector\": {\n  \"matchExpressions\": [\n    {\n      \"key\": \"environment\",\n      \"operator\": \"In\",\n      \"values\": [\n        \"prod\",\n        \"staging\"\n      ]\n    }\n  ]\n}\n\nSee https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/ for more examples of label selectors.\n\nDefault to the empty LabelSelector, which matches everything.", | ||||
| 	"sideEffects":             "SideEffects states whether this webhookk has side effects. Acceptable values are: Unknown, None, Some, NoneOnDryRun Webhooks with side effects MUST implement a reconciliation system, since a request may be rejected by a future step in the admission change and the side effects therefore need to be undone. Requests with the dryRun attribute will be auto-rejected if they match a webhook with sideEffects == Unknown or Some. Defaults to Unknown.", | ||||
| 	"timeoutSeconds":          "TimeoutSeconds specifies the timeout for this webhook. After the timeout passes, the webhook call will be ignored or the API call will fail based on the failure policy. The timeout value must be between 1 and 30 seconds. Default to 30 seconds.", | ||||
| 	"admissionReviewVersions": "AdmissionReviewVersions is an ordered list of preferred `AdmissionReview` versions the Webhook expects. API server will try to use first version in the list which it supports. If none of the versions specified in this list supported by API server, validation will fail for this object. If a persisted webhook configuration specifies allowed versions and does not include any versions known to the API Server, calls to the webhook will fail and be subject to the failure policy. Default to `['v1beta1']`.", | ||||
| } | ||||
|  | ||||
| func (Webhook) SwaggerDoc() map[string]string { | ||||
| 	return map_Webhook | ||||
| } | ||||
|  | ||||
| var map_WebhookClientConfig = map[string]string{ | ||||
| 	"":         "WebhookClientConfig contains the information to make a TLS connection with the webhook", | ||||
| 	"url":      "`url` gives the location of the webhook, in standard URL form (`scheme://host:port/path`). Exactly one of `url` or `service` must be specified.\n\nThe `host` should not refer to a service running in the cluster; use the `service` field instead. The host might be resolved via external DNS in some apiservers (e.g., `kube-apiserver` cannot resolve in-cluster DNS as that would be a layering violation). `host` may also be an IP address.\n\nPlease note that using `localhost` or `127.0.0.1` as a `host` is risky unless you take great care to run this webhook on all hosts which run an apiserver which might need to make calls to this webhook. Such installs are likely to be non-portable, i.e., not easy to turn up in a new cluster.\n\nThe scheme must be \"https\"; the URL must begin with \"https://\".\n\nA path is optional, and if present may be any string permissible in a URL. You may use the path to pass an arbitrary string to the webhook, for example, a cluster identifier.\n\nAttempting to use a user or basic auth e.g. \"user:password@\" is not allowed. Fragments (\"#...\") and query parameters (\"?...\") are not allowed, either.", | ||||
| 	"service":  "`service` is a reference to the service for this webhook. Either `service` or `url` must be specified.\n\nIf the webhook is running within the cluster, then you should use `service`.\n\nPort 443 will be used if it is open, otherwise it is an error.", | ||||
| 	"caBundle": "`caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.", | ||||
| } | ||||
|  | ||||
| func (WebhookClientConfig) SwaggerDoc() map[string]string { | ||||
| 	return map_WebhookClientConfig | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										317
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										317
									
								
								vendor/k8s.io/api/admissionregistration/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,317 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MutatingWebhookConfiguration) DeepCopyInto(out *MutatingWebhookConfiguration) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Webhooks != nil { | ||||
| 		in, out := &in.Webhooks, &out.Webhooks | ||||
| 		*out = make([]Webhook, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MutatingWebhookConfiguration. | ||||
| func (in *MutatingWebhookConfiguration) DeepCopy() *MutatingWebhookConfiguration { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MutatingWebhookConfiguration) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *MutatingWebhookConfiguration) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MutatingWebhookConfigurationList) DeepCopyInto(out *MutatingWebhookConfigurationList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]MutatingWebhookConfiguration, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MutatingWebhookConfigurationList. | ||||
| func (in *MutatingWebhookConfigurationList) DeepCopy() *MutatingWebhookConfigurationList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MutatingWebhookConfigurationList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *MutatingWebhookConfigurationList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Rule) DeepCopyInto(out *Rule) { | ||||
| 	*out = *in | ||||
| 	if in.APIGroups != nil { | ||||
| 		in, out := &in.APIGroups, &out.APIGroups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.APIVersions != nil { | ||||
| 		in, out := &in.APIVersions, &out.APIVersions | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Resources != nil { | ||||
| 		in, out := &in.Resources, &out.Resources | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Scope != nil { | ||||
| 		in, out := &in.Scope, &out.Scope | ||||
| 		*out = new(ScopeType) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Rule. | ||||
| func (in *Rule) DeepCopy() *Rule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Rule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RuleWithOperations) DeepCopyInto(out *RuleWithOperations) { | ||||
| 	*out = *in | ||||
| 	if in.Operations != nil { | ||||
| 		in, out := &in.Operations, &out.Operations | ||||
| 		*out = make([]OperationType, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	in.Rule.DeepCopyInto(&out.Rule) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RuleWithOperations. | ||||
| func (in *RuleWithOperations) DeepCopy() *RuleWithOperations { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RuleWithOperations) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ServiceReference) DeepCopyInto(out *ServiceReference) { | ||||
| 	*out = *in | ||||
| 	if in.Path != nil { | ||||
| 		in, out := &in.Path, &out.Path | ||||
| 		*out = new(string) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ServiceReference. | ||||
| func (in *ServiceReference) DeepCopy() *ServiceReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ServiceReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ValidatingWebhookConfiguration) DeepCopyInto(out *ValidatingWebhookConfiguration) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Webhooks != nil { | ||||
| 		in, out := &in.Webhooks, &out.Webhooks | ||||
| 		*out = make([]Webhook, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ValidatingWebhookConfiguration. | ||||
| func (in *ValidatingWebhookConfiguration) DeepCopy() *ValidatingWebhookConfiguration { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ValidatingWebhookConfiguration) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ValidatingWebhookConfiguration) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ValidatingWebhookConfigurationList) DeepCopyInto(out *ValidatingWebhookConfigurationList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ValidatingWebhookConfiguration, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ValidatingWebhookConfigurationList. | ||||
| func (in *ValidatingWebhookConfigurationList) DeepCopy() *ValidatingWebhookConfigurationList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ValidatingWebhookConfigurationList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ValidatingWebhookConfigurationList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Webhook) DeepCopyInto(out *Webhook) { | ||||
| 	*out = *in | ||||
| 	in.ClientConfig.DeepCopyInto(&out.ClientConfig) | ||||
| 	if in.Rules != nil { | ||||
| 		in, out := &in.Rules, &out.Rules | ||||
| 		*out = make([]RuleWithOperations, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.FailurePolicy != nil { | ||||
| 		in, out := &in.FailurePolicy, &out.FailurePolicy | ||||
| 		*out = new(FailurePolicyType) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.NamespaceSelector != nil { | ||||
| 		in, out := &in.NamespaceSelector, &out.NamespaceSelector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.SideEffects != nil { | ||||
| 		in, out := &in.SideEffects, &out.SideEffects | ||||
| 		*out = new(SideEffectClass) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.TimeoutSeconds != nil { | ||||
| 		in, out := &in.TimeoutSeconds, &out.TimeoutSeconds | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.AdmissionReviewVersions != nil { | ||||
| 		in, out := &in.AdmissionReviewVersions, &out.AdmissionReviewVersions | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Webhook. | ||||
| func (in *Webhook) DeepCopy() *Webhook { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Webhook) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *WebhookClientConfig) DeepCopyInto(out *WebhookClientConfig) { | ||||
| 	*out = *in | ||||
| 	if in.URL != nil { | ||||
| 		in, out := &in.URL, &out.URL | ||||
| 		*out = new(string) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Service != nil { | ||||
| 		in, out := &in.Service, &out.Service | ||||
| 		*out = new(ServiceReference) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.CABundle != nil { | ||||
| 		in, out := &in.CABundle, &out.CABundle | ||||
| 		*out = make([]byte, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new WebhookClientConfig. | ||||
| func (in *WebhookClientConfig) DeepCopy() *WebhookClientConfig { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(WebhookClientConfig) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/apps/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/apps/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2017 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1 // import "k8s.io/api/apps/v1" | ||||
							
								
								
									
										6930
									
								
								vendor/k8s.io/api/apps/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6930
									
								
								vendor/k8s.io/api/apps/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										701
									
								
								vendor/k8s.io/api/apps/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										701
									
								
								vendor/k8s.io/api/apps/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,701 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.apps.v1; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/util/intstr/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1"; | ||||
|  | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| message ControllerRevision { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Data is the serialized representation of the state. | ||||
|   optional k8s.io.apimachinery.pkg.runtime.RawExtension data = 2; | ||||
|  | ||||
|   // Revision indicates the revision of the state represented by Data. | ||||
|   optional int64 revision = 3; | ||||
| } | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| message ControllerRevisionList { | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is the list of ControllerRevisions | ||||
|   repeated ControllerRevision items = 2; | ||||
| } | ||||
|  | ||||
| // DaemonSet represents the configuration of a daemon set. | ||||
| message DaemonSet { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // The desired behavior of this daemon set. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional DaemonSetSpec spec = 2; | ||||
|  | ||||
|   // The current status of this daemon set. 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 | ||||
|   // +optional | ||||
|   optional DaemonSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // DaemonSetCondition describes the state of a DaemonSet at a certain point. | ||||
| message DaemonSetCondition { | ||||
|   // Type of DaemonSet condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // DaemonSetList is a collection of daemon sets. | ||||
| message DaemonSetList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // A list of daemon sets. | ||||
|   repeated DaemonSet items = 2; | ||||
| } | ||||
|  | ||||
| // DaemonSetSpec is the specification of a daemon set. | ||||
| message DaemonSetSpec { | ||||
|   // A label query over pods that are managed by the daemon set. | ||||
|   // Must match in order to be controlled. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 1; | ||||
|  | ||||
|   // An object that describes the pod that will be created. | ||||
|   // The DaemonSet will create exactly one copy of this pod on every node | ||||
|   // that matches the template's node selector (or on every node if no node | ||||
|   // selector is specified). | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 2; | ||||
|  | ||||
|   // An update strategy to replace existing DaemonSet pods with new pods. | ||||
|   // +optional | ||||
|   optional DaemonSetUpdateStrategy updateStrategy = 3; | ||||
|  | ||||
|   // The minimum number of seconds for which a newly created DaemonSet pod should | ||||
|   // be ready without any of its container crashing, for it to be considered | ||||
|   // available. Defaults to 0 (pod will be considered available as soon as it | ||||
|   // is ready). | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 4; | ||||
|  | ||||
|   // The number of old history to retain to allow rollback. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 10. | ||||
|   // +optional | ||||
|   optional int32 revisionHistoryLimit = 6; | ||||
| } | ||||
|  | ||||
| // DaemonSetStatus represents the current status of a daemon set. | ||||
| message DaemonSetStatus { | ||||
|   // The number of nodes that are running at least 1 | ||||
|   // daemon pod and are supposed to run the daemon pod. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 currentNumberScheduled = 1; | ||||
|  | ||||
|   // The number of nodes that are running the daemon pod, but are | ||||
|   // not supposed to run the daemon pod. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 numberMisscheduled = 2; | ||||
|  | ||||
|   // The total number of nodes that should be running the daemon | ||||
|   // pod (including nodes correctly running the daemon pod). | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 desiredNumberScheduled = 3; | ||||
|  | ||||
|   // The number of nodes that should be running the daemon pod and have one | ||||
|   // or more of the daemon pod running and ready. | ||||
|   optional int32 numberReady = 4; | ||||
|  | ||||
|   // The most recent generation observed by the daemon set controller. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 5; | ||||
|  | ||||
|   // The total number of nodes that are running updated daemon pod | ||||
|   // +optional | ||||
|   optional int32 updatedNumberScheduled = 6; | ||||
|  | ||||
|   // The number of nodes that should be running the | ||||
|   // daemon pod and have one or more of the daemon pod running and | ||||
|   // available (ready for at least spec.minReadySeconds) | ||||
|   // +optional | ||||
|   optional int32 numberAvailable = 7; | ||||
|  | ||||
|   // The number of nodes that should be running the | ||||
|   // daemon pod and have none of the daemon pod running and available | ||||
|   // (ready for at least spec.minReadySeconds) | ||||
|   // +optional | ||||
|   optional int32 numberUnavailable = 8; | ||||
|  | ||||
|   // Count of hash collisions for the DaemonSet. The DaemonSet controller | ||||
|   // uses this field as a collision avoidance mechanism when it needs to | ||||
|   // create the name for the newest ControllerRevision. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 9; | ||||
|  | ||||
|   // Represents the latest available observations of a DaemonSet's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated DaemonSetCondition conditions = 10; | ||||
| } | ||||
|  | ||||
| // DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet. | ||||
| message DaemonSetUpdateStrategy { | ||||
|   // Type of daemon set update. Can be "RollingUpdate" or "OnDelete". Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Rolling update config params. Present only if type = "RollingUpdate". | ||||
|   // --- | ||||
|   // TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
|   // to be. Same as Deployment `strategy.rollingUpdate`. | ||||
|   // See https://github.com/kubernetes/kubernetes/issues/35345 | ||||
|   // +optional | ||||
|   optional RollingUpdateDaemonSet rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| message Deployment { | ||||
|   // Standard object metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentSpec spec = 2; | ||||
|  | ||||
|   // Most recently observed status of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentStatus status = 3; | ||||
| } | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| message DeploymentCondition { | ||||
|   // Type of deployment condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // The last time this condition was updated. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastUpdateTime = 6; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 7; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| message DeploymentList { | ||||
|   // Standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is the list of Deployments. | ||||
|   repeated Deployment items = 2; | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| message DeploymentSpec { | ||||
|   // Number of desired pods. This is a pointer to distinguish between explicit | ||||
|   // zero and not specified. Defaults to 1. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // Label selector for pods. Existing ReplicaSets whose pods are | ||||
|   // selected by this will be the ones affected by this deployment. | ||||
|   // It must match the pod template's labels. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // Template describes the pods that will be created. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // The deployment strategy to use to replace existing pods with new ones. | ||||
|   // +optional | ||||
|   // +patchStrategy=retainKeys | ||||
|   optional DeploymentStrategy strategy = 4; | ||||
|  | ||||
|   // Minimum number of seconds for which a newly created pod should be ready | ||||
|   // without any of its container crashing, for it to be considered available. | ||||
|   // Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 5; | ||||
|  | ||||
|   // The number of old ReplicaSets to retain to allow rollback. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 10. | ||||
|   // +optional | ||||
|   optional int32 revisionHistoryLimit = 6; | ||||
|  | ||||
|   // Indicates that the deployment is paused. | ||||
|   // +optional | ||||
|   optional bool paused = 7; | ||||
|  | ||||
|   // The maximum time in seconds for a deployment to make progress before it | ||||
|   // is considered to be failed. The deployment controller will continue to | ||||
|   // process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
|   // reason will be surfaced in the deployment status. Note that progress will | ||||
|   // not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
|   optional int32 progressDeadlineSeconds = 9; | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| message DeploymentStatus { | ||||
|   // The generation observed by the deployment controller. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
|   // +optional | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
|   // +optional | ||||
|   optional int32 updatedReplicas = 3; | ||||
|  | ||||
|   // Total number of ready pods targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 readyReplicas = 7; | ||||
|  | ||||
|   // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 availableReplicas = 4; | ||||
|  | ||||
|   // Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
|   // pods that are still required for the deployment to have 100% available capacity. They may | ||||
|   // either be pods that are running but not yet available or pods that still have not been created. | ||||
|   // +optional | ||||
|   optional int32 unavailableReplicas = 5; | ||||
|  | ||||
|   // Represents the latest available observations of a deployment's current state. | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated DeploymentCondition conditions = 6; | ||||
|  | ||||
|   // Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
|   // field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ReplicaSet. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 8; | ||||
| } | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| message DeploymentStrategy { | ||||
|   // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Rolling update config params. Present only if DeploymentStrategyType = | ||||
|   // RollingUpdate. | ||||
|   // --- | ||||
|   // TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
|   // to be. | ||||
|   // +optional | ||||
|   optional RollingUpdateDeployment rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
| // ReplicaSet ensures that a specified number of pod replicas are running at any given time. | ||||
| message ReplicaSet { | ||||
|   // If the Labels of a ReplicaSet are empty, they are defaulted to | ||||
|   // be the same as the Pod(s) that the ReplicaSet manages. | ||||
|   // Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/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 ReplicaSet. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ReplicaSetSpec spec = 2; | ||||
|  | ||||
|   // Status is the most recently observed status of the ReplicaSet. | ||||
|   // 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 | ||||
|   // +optional | ||||
|   optional ReplicaSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // ReplicaSetCondition describes the state of a replica set at a certain point. | ||||
| message ReplicaSetCondition { | ||||
|   // Type of replica set condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // The last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // ReplicaSetList is a collection of ReplicaSets. | ||||
| message ReplicaSetList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // List of ReplicaSets. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller | ||||
|   repeated ReplicaSet items = 2; | ||||
| } | ||||
|  | ||||
| // ReplicaSetSpec is the specification of a ReplicaSet. | ||||
| message ReplicaSetSpec { | ||||
|   // Replicas is the number of desired replicas. | ||||
|   // This is a pointer to distinguish between explicit zero and unspecified. | ||||
|   // Defaults to 1. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // Minimum number of seconds for which a newly created pod should be ready | ||||
|   // without any of its container crashing, for it to be considered available. | ||||
|   // Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 4; | ||||
|  | ||||
|   // Selector is a label query over pods that should match the replica count. | ||||
|   // Label keys and values that must match in order to be controlled by this replica set. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // Template is the object that describes the pod that will be created if | ||||
|   // insufficient replicas are detected. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
|   // +optional | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
| } | ||||
|  | ||||
| // ReplicaSetStatus represents the current status of a ReplicaSet. | ||||
| message ReplicaSetStatus { | ||||
|   // Replicas is the most recently oberved number of replicas. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // The number of pods that have labels matching the labels of the pod template of the replicaset. | ||||
|   // +optional | ||||
|   optional int32 fullyLabeledReplicas = 2; | ||||
|  | ||||
|   // The number of ready replicas for this replica set. | ||||
|   // +optional | ||||
|   optional int32 readyReplicas = 4; | ||||
|  | ||||
|   // The number of available replicas (ready for at least minReadySeconds) for this replica set. | ||||
|   // +optional | ||||
|   optional int32 availableReplicas = 5; | ||||
|  | ||||
|   // ObservedGeneration reflects the generation of the most recently observed ReplicaSet. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 3; | ||||
|  | ||||
|   // Represents the latest available observations of a replica set's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated ReplicaSetCondition conditions = 6; | ||||
| } | ||||
|  | ||||
| // Spec to control the desired behavior of daemon set rolling update. | ||||
| message RollingUpdateDaemonSet { | ||||
|   // The maximum number of DaemonSet pods that can be unavailable during the | ||||
|   // update. Value can be an absolute number (ex: 5) or a percentage of total | ||||
|   // number of DaemonSet pods at the start of the update (ex: 10%). Absolute | ||||
|   // number is calculated from percentage by rounding up. | ||||
|   // This cannot be 0. | ||||
|   // Default value is 1. | ||||
|   // Example: when this is set to 30%, at most 30% of the total number of nodes | ||||
|   // that should be running the daemon pod (i.e. status.desiredNumberScheduled) | ||||
|   // can have their pods stopped for an update at any given | ||||
|   // time. The update starts by stopping at most 30% of those DaemonSet pods | ||||
|   // and then brings up new DaemonSet pods in their place. Once the new pods | ||||
|   // are available, it then proceeds onto other DaemonSet pods, thus ensuring | ||||
|   // that at least 70% of original number of DaemonSet pods are available at | ||||
|   // all times during the update. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 1; | ||||
| } | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| message RollingUpdateDeployment { | ||||
|   // The maximum number of pods that can be unavailable during the update. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // Absolute number is calculated from percentage by rounding down. | ||||
|   // This can not be 0 if MaxSurge is 0. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
|   // immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
|   // can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
|   // that the total number of pods available at all times during the update is at | ||||
|   // least 70% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 1; | ||||
|  | ||||
|   // The maximum number of pods that can be scheduled above the desired number of | ||||
|   // pods. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // This can not be 0 if MaxUnavailable is 0. | ||||
|   // Absolute number is calculated from percentage by rounding up. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
|   // the rolling update starts, such that the total number of old and new pods do not exceed | ||||
|   // 130% of desired pods. Once old pods have been killed, | ||||
|   // new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
|   // at any time during the update is at most 130% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxSurge = 2; | ||||
| } | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| message RollingUpdateStatefulSetStrategy { | ||||
|   // Partition indicates the ordinal at which the StatefulSet should be | ||||
|   // partitioned. | ||||
|   // Default value is 0. | ||||
|   // +optional | ||||
|   optional int32 partition = 1; | ||||
| } | ||||
|  | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| message StatefulSet { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec defines the desired identities of pods in this set. | ||||
|   // +optional | ||||
|   optional StatefulSetSpec spec = 2; | ||||
|  | ||||
|   // Status is the current status of Pods in this StatefulSet. This data | ||||
|   // may be out of date by some window of time. | ||||
|   // +optional | ||||
|   optional StatefulSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| message StatefulSetCondition { | ||||
|   // Type of statefulset condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| message StatefulSetList { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   repeated StatefulSet items = 2; | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| message StatefulSetSpec { | ||||
|   // replicas is the desired number of replicas of the given Template. | ||||
|   // These are replicas in the sense that they are instantiations of the | ||||
|   // same Template, but individual replicas also have a consistent identity. | ||||
|   // If unspecified, defaults to 1. | ||||
|   // TODO: Consider a rename of this field. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // selector is a label query over pods that should match the replica count. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // template is the object that describes the pod that will be created if | ||||
|   // insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
|   // will fulfill this Template, but have a unique identity from the rest | ||||
|   // of the StatefulSet. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
|   // The StatefulSet controller is responsible for mapping network identities to | ||||
|   // claims in a way that maintains the identity of a pod. Every claim in | ||||
|   // this list must have at least one matching (by name) volumeMount in one | ||||
|   // container in the template. A claim in this list takes precedence over | ||||
|   // any volumes in the template, with the same name. | ||||
|   // TODO: Define the behavior if a claim already exists with the same name. | ||||
|   // +optional | ||||
|   repeated k8s.io.api.core.v1.PersistentVolumeClaim volumeClaimTemplates = 4; | ||||
|  | ||||
|   // serviceName is the name of the service that governs this StatefulSet. | ||||
|   // This service must exist before the StatefulSet, and is responsible for | ||||
|   // the network identity of the set. Pods get DNS/hostnames that follow the | ||||
|   // pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
|   // where "pod-specific-string" is managed by the StatefulSet controller. | ||||
|   optional string serviceName = 5; | ||||
|  | ||||
|   // podManagementPolicy controls how pods are created during initial scale up, | ||||
|   // when replacing pods on nodes, or when scaling down. The default policy is | ||||
|   // `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
|   // pod-1, etc) and the controller will wait until each pod is ready before | ||||
|   // continuing. When scaling down, the pods are removed in the opposite order. | ||||
|   // The alternative policy is `Parallel` which will create pods in parallel | ||||
|   // to match the desired scale without waiting, and on scale down will delete | ||||
|   // all pods at once. | ||||
|   // +optional | ||||
|   optional string podManagementPolicy = 6; | ||||
|  | ||||
|   // updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
|   // employed to update Pods in the StatefulSet when a revision is made to | ||||
|   // Template. | ||||
|   optional StatefulSetUpdateStrategy updateStrategy = 7; | ||||
|  | ||||
|   // revisionHistoryLimit is the maximum number of revisions that will | ||||
|   // be maintained in the StatefulSet's revision history. The revision history | ||||
|   // consists of all revisions not represented by a currently applied | ||||
|   // StatefulSetSpec version. The default value is 10. | ||||
|   optional int32 revisionHistoryLimit = 8; | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| message StatefulSetStatus { | ||||
|   // observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
|   // StatefulSet's generation, which is updated on mutation by the API Server. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // replicas is the number of Pods created by the StatefulSet controller. | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
|   optional int32 readyReplicas = 3; | ||||
|  | ||||
|   // currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by currentRevision. | ||||
|   optional int32 currentReplicas = 4; | ||||
|  | ||||
|   // updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by updateRevision. | ||||
|   optional int32 updatedReplicas = 5; | ||||
|  | ||||
|   // currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
|   // sequence [0,currentReplicas). | ||||
|   optional string currentRevision = 6; | ||||
|  | ||||
|   // updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
|   // [replicas-updatedReplicas,replicas) | ||||
|   optional string updateRevision = 7; | ||||
|  | ||||
|   // collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
|   // uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ControllerRevision. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 9; | ||||
|  | ||||
|   // Represents the latest available observations of a statefulset's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated StatefulSetCondition conditions = 10; | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| message StatefulSetUpdateStrategy { | ||||
|   // Type indicates the type of the StatefulSetUpdateStrategy. | ||||
|   // Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
|   // +optional | ||||
|   optional RollingUpdateStatefulSetStrategy rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										60
									
								
								vendor/k8s.io/api/apps/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								vendor/k8s.io/api/apps/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "apps" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Deployment{}, | ||||
| 		&DeploymentList{}, | ||||
| 		&StatefulSet{}, | ||||
| 		&StatefulSetList{}, | ||||
| 		&DaemonSet{}, | ||||
| 		&DaemonSetList{}, | ||||
| 		&ReplicaSet{}, | ||||
| 		&ReplicaSetList{}, | ||||
| 		&ControllerRevision{}, | ||||
| 		&ControllerRevisionList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										826
									
								
								vendor/k8s.io/api/apps/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										826
									
								
								vendor/k8s.io/api/apps/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,826 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	ControllerRevisionHashLabelKey = "controller-revision-hash" | ||||
| 	StatefulSetRevisionLabel       = ControllerRevisionHashLabelKey | ||||
| 	DeprecatedRollbackTo           = "deprecated.deployment.rollback.to" | ||||
| 	DeprecatedTemplateGeneration   = "deprecated.daemonset.template.generation" | ||||
| 	StatefulSetPodNameLabel        = "statefulset.kubernetes.io/pod-name" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:method=GetScale,verb=get,subresource=scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +genclient:method=UpdateScale,verb=update,subresource=scale,input=k8s.io/api/autoscaling/v1.Scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| type StatefulSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec defines the desired identities of pods in this set. | ||||
| 	// +optional | ||||
| 	Spec StatefulSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is the current status of Pods in this StatefulSet. This data | ||||
| 	// may be out of date by some window of time. | ||||
| 	// +optional | ||||
| 	Status StatefulSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // PodManagementPolicyType defines the policy for creating pods under a stateful set. | ||||
| type PodManagementPolicyType string | ||||
|  | ||||
| const ( | ||||
| 	// OrderedReadyPodManagement will create pods in strictly increasing order on | ||||
| 	// scale up and strictly decreasing order on scale down, progressing only when | ||||
| 	// the previous pod is ready or terminated. At most one pod will be changed | ||||
| 	// at any time. | ||||
| 	OrderedReadyPodManagement PodManagementPolicyType = "OrderedReady" | ||||
| 	// ParallelPodManagement will create and delete pods as soon as the stateful set | ||||
| 	// replica count is changed, and will not wait for pods to be ready or complete | ||||
| 	// termination. | ||||
| 	ParallelPodManagement PodManagementPolicyType = "Parallel" | ||||
| ) | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| type StatefulSetUpdateStrategy struct { | ||||
| 	// Type indicates the type of the StatefulSetUpdateStrategy. | ||||
| 	// Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type StatefulSetUpdateStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetStrategyType"` | ||||
| 	// RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateStatefulSetStrategy `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategyType is a string enumeration type that enumerates | ||||
| // all possible update strategies for the StatefulSet controller. | ||||
| type StatefulSetUpdateStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// RollingUpdateStatefulSetStrategyType indicates that update will be | ||||
| 	// applied to all Pods in the StatefulSet with respect to the StatefulSet | ||||
| 	// ordering constraints. When a scale operation is performed with this | ||||
| 	// strategy, new Pods will be created from the specification version indicated | ||||
| 	// by the StatefulSet's updateRevision. | ||||
| 	RollingUpdateStatefulSetStrategyType = "RollingUpdate" | ||||
| 	// OnDeleteStatefulSetStrategyType triggers the legacy behavior. Version | ||||
| 	// tracking and ordered rolling restarts are disabled. Pods are recreated | ||||
| 	// from the StatefulSetSpec when they are manually deleted. When a scale | ||||
| 	// operation is performed with this strategy,specification version indicated | ||||
| 	// by the StatefulSet's currentRevision. | ||||
| 	OnDeleteStatefulSetStrategyType = "OnDelete" | ||||
| ) | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| type RollingUpdateStatefulSetStrategy struct { | ||||
| 	// Partition indicates the ordinal at which the StatefulSet should be | ||||
| 	// partitioned. | ||||
| 	// Default value is 0. | ||||
| 	// +optional | ||||
| 	Partition *int32 `json:"partition,omitempty" protobuf:"varint,1,opt,name=partition"` | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| type StatefulSetSpec struct { | ||||
| 	// replicas is the desired number of replicas of the given Template. | ||||
| 	// These are replicas in the sense that they are instantiations of the | ||||
| 	// same Template, but individual replicas also have a consistent identity. | ||||
| 	// If unspecified, defaults to 1. | ||||
| 	// TODO: Consider a rename of this field. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// selector is a label query over pods that should match the replica count. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// template is the object that describes the pod that will be created if | ||||
| 	// insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
| 	// will fulfill this Template, but have a unique identity from the rest | ||||
| 	// of the StatefulSet. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
| 	// The StatefulSet controller is responsible for mapping network identities to | ||||
| 	// claims in a way that maintains the identity of a pod. Every claim in | ||||
| 	// this list must have at least one matching (by name) volumeMount in one | ||||
| 	// container in the template. A claim in this list takes precedence over | ||||
| 	// any volumes in the template, with the same name. | ||||
| 	// TODO: Define the behavior if a claim already exists with the same name. | ||||
| 	// +optional | ||||
| 	VolumeClaimTemplates []v1.PersistentVolumeClaim `json:"volumeClaimTemplates,omitempty" protobuf:"bytes,4,rep,name=volumeClaimTemplates"` | ||||
|  | ||||
| 	// serviceName is the name of the service that governs this StatefulSet. | ||||
| 	// This service must exist before the StatefulSet, and is responsible for | ||||
| 	// the network identity of the set. Pods get DNS/hostnames that follow the | ||||
| 	// pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
| 	// where "pod-specific-string" is managed by the StatefulSet controller. | ||||
| 	ServiceName string `json:"serviceName" protobuf:"bytes,5,opt,name=serviceName"` | ||||
|  | ||||
| 	// podManagementPolicy controls how pods are created during initial scale up, | ||||
| 	// when replacing pods on nodes, or when scaling down. The default policy is | ||||
| 	// `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
| 	// pod-1, etc) and the controller will wait until each pod is ready before | ||||
| 	// continuing. When scaling down, the pods are removed in the opposite order. | ||||
| 	// The alternative policy is `Parallel` which will create pods in parallel | ||||
| 	// to match the desired scale without waiting, and on scale down will delete | ||||
| 	// all pods at once. | ||||
| 	// +optional | ||||
| 	PodManagementPolicy PodManagementPolicyType `json:"podManagementPolicy,omitempty" protobuf:"bytes,6,opt,name=podManagementPolicy,casttype=PodManagementPolicyType"` | ||||
|  | ||||
| 	// updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
| 	// employed to update Pods in the StatefulSet when a revision is made to | ||||
| 	// Template. | ||||
| 	UpdateStrategy StatefulSetUpdateStrategy `json:"updateStrategy,omitempty" protobuf:"bytes,7,opt,name=updateStrategy"` | ||||
|  | ||||
| 	// revisionHistoryLimit is the maximum number of revisions that will | ||||
| 	// be maintained in the StatefulSet's revision history. The revision history | ||||
| 	// consists of all revisions not represented by a currently applied | ||||
| 	// StatefulSetSpec version. The default value is 10. | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,8,opt,name=revisionHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| type StatefulSetStatus struct { | ||||
| 	// observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
| 	// StatefulSet's generation, which is updated on mutation by the API Server. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// replicas is the number of Pods created by the StatefulSet controller. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,3,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by currentRevision. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas,omitempty" protobuf:"varint,4,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by updateRevision. | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,5,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
| 	// sequence [0,currentReplicas). | ||||
| 	CurrentRevision string `json:"currentRevision,omitempty" protobuf:"bytes,6,opt,name=currentRevision"` | ||||
|  | ||||
| 	// updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
| 	// [replicas-updatedReplicas,replicas) | ||||
| 	UpdateRevision string `json:"updateRevision,omitempty" protobuf:"bytes,7,opt,name=updateRevision"` | ||||
|  | ||||
| 	// collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
| 	// uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ControllerRevision. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,9,opt,name=collisionCount"` | ||||
|  | ||||
| 	// Represents the latest available observations of a statefulset's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []StatefulSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,10,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type StatefulSetConditionType string | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| type StatefulSetCondition struct { | ||||
| 	// Type of statefulset condition. | ||||
| 	Type StatefulSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| type StatefulSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	Items           []StatefulSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:method=GetScale,verb=get,subresource=scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +genclient:method=UpdateScale,verb=update,subresource=scale,input=k8s.io/api/autoscaling/v1.Scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| type Deployment struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of the Deployment. | ||||
| 	// +optional | ||||
| 	Spec DeploymentSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Most recently observed status of the Deployment. | ||||
| 	// +optional | ||||
| 	Status DeploymentStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| type DeploymentSpec struct { | ||||
| 	// Number of desired pods. This is a pointer to distinguish between explicit | ||||
| 	// zero and not specified. Defaults to 1. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// Label selector for pods. Existing ReplicaSets whose pods are | ||||
| 	// selected by this will be the ones affected by this deployment. | ||||
| 	// It must match the pod template's labels. | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// Template describes the pods that will be created. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// The deployment strategy to use to replace existing pods with new ones. | ||||
| 	// +optional | ||||
| 	// +patchStrategy=retainKeys | ||||
| 	Strategy DeploymentStrategy `json:"strategy,omitempty" patchStrategy:"retainKeys" protobuf:"bytes,4,opt,name=strategy"` | ||||
|  | ||||
| 	// Minimum number of seconds for which a newly created pod should be ready | ||||
| 	// without any of its container crashing, for it to be considered available. | ||||
| 	// Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,5,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// The number of old ReplicaSets to retain to allow rollback. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 10. | ||||
| 	// +optional | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` | ||||
|  | ||||
| 	// Indicates that the deployment is paused. | ||||
| 	// +optional | ||||
| 	Paused bool `json:"paused,omitempty" protobuf:"varint,7,opt,name=paused"` | ||||
|  | ||||
| 	// The maximum time in seconds for a deployment to make progress before it | ||||
| 	// is considered to be failed. The deployment controller will continue to | ||||
| 	// process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
| 	// reason will be surfaced in the deployment status. Note that progress will | ||||
| 	// not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
| 	ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty" protobuf:"varint,9,opt,name=progressDeadlineSeconds"` | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	// DefaultDeploymentUniqueLabelKey is the default key of the selector that is added | ||||
| 	// to existing ReplicaSets (and label key that is added to its pods) to prevent the existing ReplicaSets | ||||
| 	// to select new pods (and old pods being select by new ReplicaSet). | ||||
| 	DefaultDeploymentUniqueLabelKey string = "pod-template-hash" | ||||
| ) | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| type DeploymentStrategy struct { | ||||
| 	// Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type DeploymentStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=DeploymentStrategyType"` | ||||
|  | ||||
| 	// Rolling update config params. Present only if DeploymentStrategyType = | ||||
| 	// RollingUpdate. | ||||
| 	//--- | ||||
| 	// TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
| 	// to be. | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateDeployment `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| type DeploymentStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// Kill all existing pods before creating new ones. | ||||
| 	RecreateDeploymentStrategyType DeploymentStrategyType = "Recreate" | ||||
|  | ||||
| 	// Replace the old ReplicaSets by new one using rolling update i.e gradually scale down the old ReplicaSets and scale up the new one. | ||||
| 	RollingUpdateDeploymentStrategyType DeploymentStrategyType = "RollingUpdate" | ||||
| ) | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| type RollingUpdateDeployment struct { | ||||
| 	// The maximum number of pods that can be unavailable during the update. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// Absolute number is calculated from percentage by rounding down. | ||||
| 	// This can not be 0 if MaxSurge is 0. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
| 	// immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
| 	// can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
| 	// that the total number of pods available at all times during the update is at | ||||
| 	// least 70% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` | ||||
|  | ||||
| 	// The maximum number of pods that can be scheduled above the desired number of | ||||
| 	// pods. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// This can not be 0 if MaxUnavailable is 0. | ||||
| 	// Absolute number is calculated from percentage by rounding up. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
| 	// the rolling update starts, such that the total number of old and new pods do not exceed | ||||
| 	// 130% of desired pods. Once old pods have been killed, | ||||
| 	// new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
| 	// at any time during the update is at most 130% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty" protobuf:"bytes,2,opt,name=maxSurge"` | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| type DeploymentStatus struct { | ||||
| 	// The generation observed by the deployment controller. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
| 	// +optional | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,3,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// Total number of ready pods targeted by this deployment. | ||||
| 	// +optional | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,7,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
| 	// +optional | ||||
| 	AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,4,opt,name=availableReplicas"` | ||||
|  | ||||
| 	// Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
| 	// pods that are still required for the deployment to have 100% available capacity. They may | ||||
| 	// either be pods that are running but not yet available or pods that still have not been created. | ||||
| 	// +optional | ||||
| 	UnavailableReplicas int32 `json:"unavailableReplicas,omitempty" protobuf:"varint,5,opt,name=unavailableReplicas"` | ||||
|  | ||||
| 	// Represents the latest available observations of a deployment's current state. | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []DeploymentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,6,rep,name=conditions"` | ||||
|  | ||||
| 	// Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
| 	// field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ReplicaSet. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,8,opt,name=collisionCount"` | ||||
| } | ||||
|  | ||||
| type DeploymentConditionType string | ||||
|  | ||||
| // These are valid conditions of a deployment. | ||||
| const ( | ||||
| 	// Available means the deployment is available, ie. at least the minimum available | ||||
| 	// replicas required are up and running for at least minReadySeconds. | ||||
| 	DeploymentAvailable DeploymentConditionType = "Available" | ||||
| 	// Progressing means the deployment is progressing. Progress for a deployment is | ||||
| 	// considered when a new replica set is created or adopted, and when new pods scale | ||||
| 	// up or old pods scale down. Progress is not estimated for paused deployments or | ||||
| 	// when progressDeadlineSeconds is not specified. | ||||
| 	DeploymentProgressing DeploymentConditionType = "Progressing" | ||||
| 	// ReplicaFailure is added in a deployment when one of its pods fails to be created | ||||
| 	// or deleted. | ||||
| 	DeploymentReplicaFailure DeploymentConditionType = "ReplicaFailure" | ||||
| ) | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| type DeploymentCondition struct { | ||||
| 	// Type of deployment condition. | ||||
| 	Type DeploymentConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DeploymentConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// The last time this condition was updated. | ||||
| 	LastUpdateTime metav1.Time `json:"lastUpdateTime,omitempty" protobuf:"bytes,6,opt,name=lastUpdateTime"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,7,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| type DeploymentList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is the list of Deployments. | ||||
| 	Items []Deployment `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet. | ||||
| type DaemonSetUpdateStrategy struct { | ||||
| 	// Type of daemon set update. Can be "RollingUpdate" or "OnDelete". Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type DaemonSetUpdateStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type"` | ||||
|  | ||||
| 	// Rolling update config params. Present only if type = "RollingUpdate". | ||||
| 	//--- | ||||
| 	// TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
| 	// to be. Same as Deployment `strategy.rollingUpdate`. | ||||
| 	// See https://github.com/kubernetes/kubernetes/issues/35345 | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateDaemonSet `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| type DaemonSetUpdateStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// Replace the old daemons by new ones using rolling update i.e replace them on each node one after the other. | ||||
| 	RollingUpdateDaemonSetStrategyType DaemonSetUpdateStrategyType = "RollingUpdate" | ||||
|  | ||||
| 	// Replace the old daemons only when it's killed | ||||
| 	OnDeleteDaemonSetStrategyType DaemonSetUpdateStrategyType = "OnDelete" | ||||
| ) | ||||
|  | ||||
| // Spec to control the desired behavior of daemon set rolling update. | ||||
| type RollingUpdateDaemonSet struct { | ||||
| 	// The maximum number of DaemonSet pods that can be unavailable during the | ||||
| 	// update. Value can be an absolute number (ex: 5) or a percentage of total | ||||
| 	// number of DaemonSet pods at the start of the update (ex: 10%). Absolute | ||||
| 	// number is calculated from percentage by rounding up. | ||||
| 	// This cannot be 0. | ||||
| 	// Default value is 1. | ||||
| 	// Example: when this is set to 30%, at most 30% of the total number of nodes | ||||
| 	// that should be running the daemon pod (i.e. status.desiredNumberScheduled) | ||||
| 	// can have their pods stopped for an update at any given | ||||
| 	// time. The update starts by stopping at most 30% of those DaemonSet pods | ||||
| 	// and then brings up new DaemonSet pods in their place. Once the new pods | ||||
| 	// are available, it then proceeds onto other DaemonSet pods, thus ensuring | ||||
| 	// that at least 70% of original number of DaemonSet pods are available at | ||||
| 	// all times during the update. | ||||
| 	// +optional | ||||
| 	MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` | ||||
| } | ||||
|  | ||||
| // DaemonSetSpec is the specification of a daemon set. | ||||
| type DaemonSetSpec struct { | ||||
| 	// A label query over pods that are managed by the daemon set. | ||||
| 	// Must match in order to be controlled. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,1,opt,name=selector"` | ||||
|  | ||||
| 	// An object that describes the pod that will be created. | ||||
| 	// The DaemonSet will create exactly one copy of this pod on every node | ||||
| 	// that matches the template's node selector (or on every node if no node | ||||
| 	// selector is specified). | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,2,opt,name=template"` | ||||
|  | ||||
| 	// An update strategy to replace existing DaemonSet pods with new pods. | ||||
| 	// +optional | ||||
| 	UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty" protobuf:"bytes,3,opt,name=updateStrategy"` | ||||
|  | ||||
| 	// The minimum number of seconds for which a newly created DaemonSet pod should | ||||
| 	// be ready without any of its container crashing, for it to be considered | ||||
| 	// available. Defaults to 0 (pod will be considered available as soon as it | ||||
| 	// is ready). | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// The number of old history to retain to allow rollback. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 10. | ||||
| 	// +optional | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // DaemonSetStatus represents the current status of a daemon set. | ||||
| type DaemonSetStatus struct { | ||||
| 	// The number of nodes that are running at least 1 | ||||
| 	// daemon pod and are supposed to run the daemon pod. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	CurrentNumberScheduled int32 `json:"currentNumberScheduled" protobuf:"varint,1,opt,name=currentNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that are running the daemon pod, but are | ||||
| 	// not supposed to run the daemon pod. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	NumberMisscheduled int32 `json:"numberMisscheduled" protobuf:"varint,2,opt,name=numberMisscheduled"` | ||||
|  | ||||
| 	// The total number of nodes that should be running the daemon | ||||
| 	// pod (including nodes correctly running the daemon pod). | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	DesiredNumberScheduled int32 `json:"desiredNumberScheduled" protobuf:"varint,3,opt,name=desiredNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that should be running the daemon pod and have one | ||||
| 	// or more of the daemon pod running and ready. | ||||
| 	NumberReady int32 `json:"numberReady" protobuf:"varint,4,opt,name=numberReady"` | ||||
|  | ||||
| 	// The most recent generation observed by the daemon set controller. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,5,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// The total number of nodes that are running updated daemon pod | ||||
| 	// +optional | ||||
| 	UpdatedNumberScheduled int32 `json:"updatedNumberScheduled,omitempty" protobuf:"varint,6,opt,name=updatedNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that should be running the | ||||
| 	// daemon pod and have one or more of the daemon pod running and | ||||
| 	// available (ready for at least spec.minReadySeconds) | ||||
| 	// +optional | ||||
| 	NumberAvailable int32 `json:"numberAvailable,omitempty" protobuf:"varint,7,opt,name=numberAvailable"` | ||||
|  | ||||
| 	// The number of nodes that should be running the | ||||
| 	// daemon pod and have none of the daemon pod running and available | ||||
| 	// (ready for at least spec.minReadySeconds) | ||||
| 	// +optional | ||||
| 	NumberUnavailable int32 `json:"numberUnavailable,omitempty" protobuf:"varint,8,opt,name=numberUnavailable"` | ||||
|  | ||||
| 	// Count of hash collisions for the DaemonSet. The DaemonSet controller | ||||
| 	// uses this field as a collision avoidance mechanism when it needs to | ||||
| 	// create the name for the newest ControllerRevision. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,9,opt,name=collisionCount"` | ||||
|  | ||||
| 	// Represents the latest available observations of a DaemonSet's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []DaemonSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,10,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type DaemonSetConditionType string | ||||
|  | ||||
| // TODO: Add valid condition types of a DaemonSet. | ||||
|  | ||||
| // DaemonSetCondition describes the state of a DaemonSet at a certain point. | ||||
| type DaemonSetCondition struct { | ||||
| 	// Type of DaemonSet condition. | ||||
| 	Type DaemonSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DaemonSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DaemonSet represents the configuration of a daemon set. | ||||
| type DaemonSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// The desired behavior of this daemon set. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec DaemonSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// The current status of this daemon set. 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 | ||||
| 	// +optional | ||||
| 	Status DaemonSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	// DefaultDaemonSetUniqueLabelKey is the default label key that is added | ||||
| 	// to existing DaemonSet pods to distinguish between old and new | ||||
| 	// DaemonSet pods during DaemonSet template updates. | ||||
| 	DefaultDaemonSetUniqueLabelKey = ControllerRevisionHashLabelKey | ||||
| ) | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DaemonSetList is a collection of daemon sets. | ||||
| type DaemonSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// A list of daemon sets. | ||||
| 	Items []DaemonSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:method=GetScale,verb=get,subresource=scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +genclient:method=UpdateScale,verb=update,subresource=scale,input=k8s.io/api/autoscaling/v1.Scale,result=k8s.io/api/autoscaling/v1.Scale | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ReplicaSet ensures that a specified number of pod replicas are running at any given time. | ||||
| type ReplicaSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// If the Labels of a ReplicaSet are empty, they are defaulted to | ||||
| 	// be the same as the Pod(s) that the ReplicaSet manages. | ||||
| 	// Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/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 ReplicaSet. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec ReplicaSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is the most recently observed status of the ReplicaSet. | ||||
| 	// 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 | ||||
| 	// +optional | ||||
| 	Status ReplicaSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ReplicaSetList is a collection of ReplicaSets. | ||||
| type ReplicaSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// List of ReplicaSets. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller | ||||
| 	Items []ReplicaSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // ReplicaSetSpec is the specification of a ReplicaSet. | ||||
| type ReplicaSetSpec struct { | ||||
| 	// Replicas is the number of desired replicas. | ||||
| 	// This is a pointer to distinguish between explicit zero and unspecified. | ||||
| 	// Defaults to 1. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// Minimum number of seconds for which a newly created pod should be ready | ||||
| 	// without any of its container crashing, for it to be considered available. | ||||
| 	// Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// Selector is a label query over pods that should match the replica count. | ||||
| 	// Label keys and values that must match in order to be controlled by this replica set. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// Template is the object that describes the pod that will be created if | ||||
| 	// insufficient replicas are detected. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
| 	// +optional | ||||
| 	Template v1.PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,3,opt,name=template"` | ||||
| } | ||||
|  | ||||
| // ReplicaSetStatus represents the current status of a ReplicaSet. | ||||
| type ReplicaSetStatus struct { | ||||
| 	// Replicas is the most recently oberved number of replicas. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// The number of pods that have labels matching the labels of the pod template of the replicaset. | ||||
| 	// +optional | ||||
| 	FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty" protobuf:"varint,2,opt,name=fullyLabeledReplicas"` | ||||
|  | ||||
| 	// The number of ready replicas for this replica set. | ||||
| 	// +optional | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,4,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// The number of available replicas (ready for at least minReadySeconds) for this replica set. | ||||
| 	// +optional | ||||
| 	AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,5,opt,name=availableReplicas"` | ||||
|  | ||||
| 	// ObservedGeneration reflects the generation of the most recently observed ReplicaSet. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,3,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// Represents the latest available observations of a replica set's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []ReplicaSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,6,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type ReplicaSetConditionType string | ||||
|  | ||||
| // These are valid conditions of a replica set. | ||||
| const ( | ||||
| 	// ReplicaSetReplicaFailure is added in a replica set when one of its pods fails to be created | ||||
| 	// due to insufficient quota, limit ranges, pod security policy, node selectors, etc. or deleted | ||||
| 	// due to kubelet being down or finalizers are failing. | ||||
| 	ReplicaSetReplicaFailure ReplicaSetConditionType = "ReplicaFailure" | ||||
| ) | ||||
|  | ||||
| // ReplicaSetCondition describes the state of a replica set at a certain point. | ||||
| type ReplicaSetCondition struct { | ||||
| 	// Type of replica set condition. | ||||
| 	Type ReplicaSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=ReplicaSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// The last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| type ControllerRevision struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Data is the serialized representation of the state. | ||||
| 	Data runtime.RawExtension `json:"data,omitempty" protobuf:"bytes,2,opt,name=data"` | ||||
|  | ||||
| 	// Revision indicates the revision of the state represented by Data. | ||||
| 	Revision int64 `json:"revision" protobuf:"varint,3,opt,name=revision"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| type ControllerRevisionList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is the list of ControllerRevisions | ||||
| 	Items []ControllerRevision `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										365
									
								
								vendor/k8s.io/api/apps/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										365
									
								
								vendor/k8s.io/api/apps/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,365 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_ControllerRevision = map[string]string{ | ||||
| 	"":         "ControllerRevision implements an immutable snapshot of state data. Clients are responsible for serializing and deserializing the objects that contain their internal state. Once a ControllerRevision has been successfully created, it can not be updated. The API Server will fail validation of all requests that attempt to mutate the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, it may be subject to name and representation changes in future releases, and clients should not depend on its stability. It is primarily for internal use by controllers.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"data":     "Data is the serialized representation of the state.", | ||||
| 	"revision": "Revision indicates the revision of the state represented by Data.", | ||||
| } | ||||
|  | ||||
| func (ControllerRevision) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevision | ||||
| } | ||||
|  | ||||
| var map_ControllerRevisionList = map[string]string{ | ||||
| 	"":         "ControllerRevisionList is a resource containing a list of ControllerRevision objects.", | ||||
| 	"metadata": "More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"items":    "Items is the list of ControllerRevisions", | ||||
| } | ||||
|  | ||||
| func (ControllerRevisionList) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevisionList | ||||
| } | ||||
|  | ||||
| var map_DaemonSet = map[string]string{ | ||||
| 	"":         "DaemonSet represents the configuration of a daemon set.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "The desired behavior of this daemon set. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "The current status of this daemon set. 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", | ||||
| } | ||||
|  | ||||
| func (DaemonSet) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSet | ||||
| } | ||||
|  | ||||
| var map_DaemonSetCondition = map[string]string{ | ||||
| 	"":                   "DaemonSetCondition describes the state of a DaemonSet at a certain point.", | ||||
| 	"type":               "Type of DaemonSet condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetCondition | ||||
| } | ||||
|  | ||||
| var map_DaemonSetList = map[string]string{ | ||||
| 	"":         "DaemonSetList is a collection of daemon sets.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"items":    "A list of daemon sets.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetList | ||||
| } | ||||
|  | ||||
| var map_DaemonSetSpec = map[string]string{ | ||||
| 	"":                     "DaemonSetSpec is the specification of a daemon set.", | ||||
| 	"selector":             "A label query over pods that are managed by the daemon set. Must match in order to be controlled. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":             "An object that describes the pod that will be created. The DaemonSet will create exactly one copy of this pod on every node that matches the template's node selector (or on every node if no node selector is specified). More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template", | ||||
| 	"updateStrategy":       "An update strategy to replace existing DaemonSet pods with new pods.", | ||||
| 	"minReadySeconds":      "The minimum number of seconds for which a newly created DaemonSet pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready).", | ||||
| 	"revisionHistoryLimit": "The number of old history to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetSpec | ||||
| } | ||||
|  | ||||
| var map_DaemonSetStatus = map[string]string{ | ||||
| 	"":                       "DaemonSetStatus represents the current status of a daemon set.", | ||||
| 	"currentNumberScheduled": "The number of nodes that are running at least 1 daemon pod and are supposed to run the daemon pod. More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"numberMisscheduled":     "The number of nodes that are running the daemon pod, but are not supposed to run the daemon pod. More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"desiredNumberScheduled": "The total number of nodes that should be running the daemon pod (including nodes correctly running the daemon pod). More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"numberReady":            "The number of nodes that should be running the daemon pod and have one or more of the daemon pod running and ready.", | ||||
| 	"observedGeneration":     "The most recent generation observed by the daemon set controller.", | ||||
| 	"updatedNumberScheduled": "The total number of nodes that are running updated daemon pod", | ||||
| 	"numberAvailable":        "The number of nodes that should be running the daemon pod and have one or more of the daemon pod running and available (ready for at least spec.minReadySeconds)", | ||||
| 	"numberUnavailable":      "The number of nodes that should be running the daemon pod and have none of the daemon pod running and available (ready for at least spec.minReadySeconds)", | ||||
| 	"collisionCount":         "Count of hash collisions for the DaemonSet. The DaemonSet controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ControllerRevision.", | ||||
| 	"conditions":             "Represents the latest available observations of a DaemonSet's current state.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetStatus | ||||
| } | ||||
|  | ||||
| var map_DaemonSetUpdateStrategy = map[string]string{ | ||||
| 	"":              "DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet.", | ||||
| 	"type":          "Type of daemon set update. Can be \"RollingUpdate\" or \"OnDelete\". Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "Rolling update config params. Present only if type = \"RollingUpdate\".", | ||||
| } | ||||
|  | ||||
| func (DaemonSetUpdateStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetUpdateStrategy | ||||
| } | ||||
|  | ||||
| var map_Deployment = map[string]string{ | ||||
| 	"":         "Deployment enables declarative updates for Pods and ReplicaSets.", | ||||
| 	"metadata": "Standard object metadata.", | ||||
| 	"spec":     "Specification of the desired behavior of the Deployment.", | ||||
| 	"status":   "Most recently observed status of the Deployment.", | ||||
| } | ||||
|  | ||||
| func (Deployment) SwaggerDoc() map[string]string { | ||||
| 	return map_Deployment | ||||
| } | ||||
|  | ||||
| var map_DeploymentCondition = map[string]string{ | ||||
| 	"":                   "DeploymentCondition describes the state of a deployment at a certain point.", | ||||
| 	"type":               "Type of deployment condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastUpdateTime":     "The last time this condition was updated.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (DeploymentCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentCondition | ||||
| } | ||||
|  | ||||
| var map_DeploymentList = map[string]string{ | ||||
| 	"":         "DeploymentList is a list of Deployments.", | ||||
| 	"metadata": "Standard list metadata.", | ||||
| 	"items":    "Items is the list of Deployments.", | ||||
| } | ||||
|  | ||||
| func (DeploymentList) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentList | ||||
| } | ||||
|  | ||||
| var map_DeploymentSpec = map[string]string{ | ||||
| 	"":                        "DeploymentSpec is the specification of the desired behavior of the Deployment.", | ||||
| 	"replicas":                "Number of desired pods. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", | ||||
| 	"selector":                "Label selector for pods. Existing ReplicaSets whose pods are selected by this will be the ones affected by this deployment. It must match the pod template's labels.", | ||||
| 	"template":                "Template describes the pods that will be created.", | ||||
| 	"strategy":                "The deployment strategy to use to replace existing pods with new ones.", | ||||
| 	"minReadySeconds":         "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", | ||||
| 	"revisionHistoryLimit":    "The number of old ReplicaSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.", | ||||
| 	"paused":                  "Indicates that the deployment is paused.", | ||||
| 	"progressDeadlineSeconds": "The maximum time in seconds for a deployment to make progress before it is considered to be failed. The deployment controller will continue to process failed deployments and a condition with a ProgressDeadlineExceeded reason will be surfaced in the deployment status. Note that progress will not be estimated during the time a deployment is paused. Defaults to 600s.", | ||||
| } | ||||
|  | ||||
| func (DeploymentSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentSpec | ||||
| } | ||||
|  | ||||
| var map_DeploymentStatus = map[string]string{ | ||||
| 	"":                    "DeploymentStatus is the most recently observed status of the Deployment.", | ||||
| 	"observedGeneration":  "The generation observed by the deployment controller.", | ||||
| 	"replicas":            "Total number of non-terminated pods targeted by this deployment (their labels match the selector).", | ||||
| 	"updatedReplicas":     "Total number of non-terminated pods targeted by this deployment that have the desired template spec.", | ||||
| 	"readyReplicas":       "Total number of ready pods targeted by this deployment.", | ||||
| 	"availableReplicas":   "Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.", | ||||
| 	"unavailableReplicas": "Total number of unavailable pods targeted by this deployment. This is the total number of pods that are still required for the deployment to have 100% available capacity. They may either be pods that are running but not yet available or pods that still have not been created.", | ||||
| 	"conditions":          "Represents the latest available observations of a deployment's current state.", | ||||
| 	"collisionCount":      "Count of hash collisions for the Deployment. The Deployment controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ReplicaSet.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStatus | ||||
| } | ||||
|  | ||||
| var map_DeploymentStrategy = map[string]string{ | ||||
| 	"":              "DeploymentStrategy describes how to replace existing pods with new ones.", | ||||
| 	"type":          "Type of deployment. Can be \"Recreate\" or \"RollingUpdate\". Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "Rolling update config params. Present only if DeploymentStrategyType = RollingUpdate.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStrategy | ||||
| } | ||||
|  | ||||
| var map_ReplicaSet = map[string]string{ | ||||
| 	"":         "ReplicaSet ensures that a specified number of pod replicas are running at any given time.", | ||||
| 	"metadata": "If the Labels of a ReplicaSet are empty, they are defaulted to be the same as the Pod(s) that the ReplicaSet 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 ReplicaSet. 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 ReplicaSet. 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", | ||||
| } | ||||
|  | ||||
| func (ReplicaSet) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSet | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetCondition = map[string]string{ | ||||
| 	"":                   "ReplicaSetCondition describes the state of a replica set at a certain point.", | ||||
| 	"type":               "Type of replica set condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "The last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetCondition | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetList = map[string]string{ | ||||
| 	"":         "ReplicaSetList is a collection of ReplicaSets.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of ReplicaSets. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetList | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetSpec = map[string]string{ | ||||
| 	"":                "ReplicaSetSpec is the specification of a ReplicaSet.", | ||||
| 	"replicas":        "Replicas is the number of desired replicas. This is a pointer to distinguish between explicit zero and unspecified. Defaults to 1. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller", | ||||
| 	"minReadySeconds": "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", | ||||
| 	"selector":        "Selector is a label query over pods that should match the replica count. Label keys and values that must match in order to be controlled by this replica set. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":        "Template is the object that describes the pod that will be created if insufficient replicas are detected. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetSpec | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetStatus = map[string]string{ | ||||
| 	"":                     "ReplicaSetStatus represents the current status of a ReplicaSet.", | ||||
| 	"replicas":             "Replicas is the most recently oberved number of replicas. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller", | ||||
| 	"fullyLabeledReplicas": "The number of pods that have labels matching the labels of the pod template of the replicaset.", | ||||
| 	"readyReplicas":        "The number of ready replicas for this replica set.", | ||||
| 	"availableReplicas":    "The number of available replicas (ready for at least minReadySeconds) for this replica set.", | ||||
| 	"observedGeneration":   "ObservedGeneration reflects the generation of the most recently observed ReplicaSet.", | ||||
| 	"conditions":           "Represents the latest available observations of a replica set's current state.", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetStatus | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateDaemonSet = map[string]string{ | ||||
| 	"":               "Spec to control the desired behavior of daemon set rolling update.", | ||||
| 	"maxUnavailable": "The maximum number of DaemonSet pods that can be unavailable during the update. Value can be an absolute number (ex: 5) or a percentage of total number of DaemonSet pods at the start of the update (ex: 10%). Absolute number is calculated from percentage by rounding up. This cannot be 0. Default value is 1. Example: when this is set to 30%, at most 30% of the total number of nodes that should be running the daemon pod (i.e. status.desiredNumberScheduled) can have their pods stopped for an update at any given time. The update starts by stopping at most 30% of those DaemonSet pods and then brings up new DaemonSet pods in their place. Once the new pods are available, it then proceeds onto other DaemonSet pods, thus ensuring that at least 70% of original number of DaemonSet pods are available at all times during the update.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateDaemonSet) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateDaemonSet | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateDeployment = map[string]string{ | ||||
| 	"":               "Spec to control the desired behavior of rolling update.", | ||||
| 	"maxUnavailable": "The maximum number of pods that can be unavailable during the update. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). Absolute number is calculated from percentage by rounding down. This can not be 0 if MaxSurge is 0. Defaults to 25%. Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods immediately when the rolling update starts. Once new pods are ready, old ReplicaSet can be scaled down further, followed by scaling up the new ReplicaSet, ensuring that the total number of pods available at all times during the update is at least 70% of desired pods.", | ||||
| 	"maxSurge":       "The maximum number of pods that can be scheduled above the desired number of pods. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). This can not be 0 if MaxUnavailable is 0. Absolute number is calculated from percentage by rounding up. Defaults to 25%. Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when the rolling update starts, such that the total number of old and new pods do not exceed 130% of desired pods. Once old pods have been killed, new ReplicaSet can be scaled up further, ensuring that total number of pods running at any time during the update is at most 130% of desired pods.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateDeployment) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateDeployment | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateStatefulSetStrategy = map[string]string{ | ||||
| 	"":          "RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType.", | ||||
| 	"partition": "Partition indicates the ordinal at which the StatefulSet should be partitioned. Default value is 0.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateStatefulSetStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateStatefulSetStrategy | ||||
| } | ||||
|  | ||||
| var map_StatefulSet = map[string]string{ | ||||
| 	"":       "StatefulSet represents a set of pods with consistent identities. Identities are defined as:\n - Network: A single stable DNS and hostname.\n - Storage: As many VolumeClaims as requested.\nThe StatefulSet guarantees that a given network identity will always map to the same storage identity.", | ||||
| 	"spec":   "Spec defines the desired identities of pods in this set.", | ||||
| 	"status": "Status is the current status of Pods in this StatefulSet. This data may be out of date by some window of time.", | ||||
| } | ||||
|  | ||||
| func (StatefulSet) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSet | ||||
| } | ||||
|  | ||||
| var map_StatefulSetCondition = map[string]string{ | ||||
| 	"":                   "StatefulSetCondition describes the state of a statefulset at a certain point.", | ||||
| 	"type":               "Type of statefulset condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetCondition | ||||
| } | ||||
|  | ||||
| var map_StatefulSetList = map[string]string{ | ||||
| 	"": "StatefulSetList is a collection of StatefulSets.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetList | ||||
| } | ||||
|  | ||||
| var map_StatefulSetSpec = map[string]string{ | ||||
| 	"":                     "A StatefulSetSpec is the specification of a StatefulSet.", | ||||
| 	"replicas":             "replicas is the desired number of replicas of the given Template. These are replicas in the sense that they are instantiations of the same Template, but individual replicas also have a consistent identity. If unspecified, defaults to 1.", | ||||
| 	"selector":             "selector is a label query over pods that should match the replica count. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":             "template is the object that describes the pod that will be created if insufficient replicas are detected. Each pod stamped out by the StatefulSet will fulfill this Template, but have a unique identity from the rest of the StatefulSet.", | ||||
| 	"volumeClaimTemplates": "volumeClaimTemplates is a list of claims that pods are allowed to reference. The StatefulSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pod. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.", | ||||
| 	"serviceName":          "serviceName is the name of the service that governs this StatefulSet. This service must exist before the StatefulSet, and is responsible for the network identity of the set. Pods get DNS/hostnames that follow the pattern: pod-specific-string.serviceName.default.svc.cluster.local where \"pod-specific-string\" is managed by the StatefulSet controller.", | ||||
| 	"podManagementPolicy":  "podManagementPolicy controls how pods are created during initial scale up, when replacing pods on nodes, or when scaling down. The default policy is `OrderedReady`, where pods are created in increasing order (pod-0, then pod-1, etc) and the controller will wait until each pod is ready before continuing. When scaling down, the pods are removed in the opposite order. The alternative policy is `Parallel` which will create pods in parallel to match the desired scale without waiting, and on scale down will delete all pods at once.", | ||||
| 	"updateStrategy":       "updateStrategy indicates the StatefulSetUpdateStrategy that will be employed to update Pods in the StatefulSet when a revision is made to Template.", | ||||
| 	"revisionHistoryLimit": "revisionHistoryLimit is the maximum number of revisions that will be maintained in the StatefulSet's revision history. The revision history consists of all revisions not represented by a currently applied StatefulSetSpec version. The default value is 10.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetSpec | ||||
| } | ||||
|  | ||||
| var map_StatefulSetStatus = map[string]string{ | ||||
| 	"":                   "StatefulSetStatus represents the current state of a StatefulSet.", | ||||
| 	"observedGeneration": "observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the StatefulSet's generation, which is updated on mutation by the API Server.", | ||||
| 	"replicas":           "replicas is the number of Pods created by the StatefulSet controller.", | ||||
| 	"readyReplicas":      "readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition.", | ||||
| 	"currentReplicas":    "currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by currentRevision.", | ||||
| 	"updatedReplicas":    "updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by updateRevision.", | ||||
| 	"currentRevision":    "currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [0,currentReplicas).", | ||||
| 	"updateRevision":     "updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [replicas-updatedReplicas,replicas)", | ||||
| 	"collisionCount":     "collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ControllerRevision.", | ||||
| 	"conditions":         "Represents the latest available observations of a statefulset's current state.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetStatus | ||||
| } | ||||
|  | ||||
| var map_StatefulSetUpdateStrategy = map[string]string{ | ||||
| 	"":              "StatefulSetUpdateStrategy indicates the strategy that the StatefulSet controller will use to perform updates. It includes any additional parameters necessary to perform the update for the indicated strategy.", | ||||
| 	"type":          "Type indicates the type of the StatefulSetUpdateStrategy. Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetUpdateStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetUpdateStrategy | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										772
									
								
								vendor/k8s.io/api/apps/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										772
									
								
								vendor/k8s.io/api/apps/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,772 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| import ( | ||||
| 	corev1 "k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevision) DeepCopyInto(out *ControllerRevision) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Data.DeepCopyInto(&out.Data) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevision. | ||||
| func (in *ControllerRevision) DeepCopy() *ControllerRevision { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevision) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevision) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevisionList) DeepCopyInto(out *ControllerRevisionList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ControllerRevision, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevisionList. | ||||
| func (in *ControllerRevisionList) DeepCopy() *ControllerRevisionList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevisionList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevisionList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSet) DeepCopyInto(out *DaemonSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSet. | ||||
| func (in *DaemonSet) DeepCopy() *DaemonSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DaemonSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetCondition) DeepCopyInto(out *DaemonSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetCondition. | ||||
| func (in *DaemonSetCondition) DeepCopy() *DaemonSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetList) DeepCopyInto(out *DaemonSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]DaemonSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetList. | ||||
| func (in *DaemonSetList) DeepCopy() *DaemonSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DaemonSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetSpec) DeepCopyInto(out *DaemonSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	in.UpdateStrategy.DeepCopyInto(&out.UpdateStrategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetSpec. | ||||
| func (in *DaemonSetSpec) DeepCopy() *DaemonSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetStatus) DeepCopyInto(out *DaemonSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]DaemonSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetStatus. | ||||
| func (in *DaemonSetStatus) DeepCopy() *DaemonSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetUpdateStrategy) DeepCopyInto(out *DaemonSetUpdateStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateDaemonSet) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetUpdateStrategy. | ||||
| func (in *DaemonSetUpdateStrategy) DeepCopy() *DaemonSetUpdateStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetUpdateStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Deployment) DeepCopyInto(out *Deployment) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Deployment. | ||||
| func (in *Deployment) DeepCopy() *Deployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Deployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Deployment) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentCondition) DeepCopyInto(out *DeploymentCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastUpdateTime.DeepCopyInto(&out.LastUpdateTime) | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentCondition. | ||||
| func (in *DeploymentCondition) DeepCopy() *DeploymentCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentList) DeepCopyInto(out *DeploymentList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]Deployment, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentList. | ||||
| func (in *DeploymentList) DeepCopy() *DeploymentList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DeploymentList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentSpec) DeepCopyInto(out *DeploymentSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	in.Strategy.DeepCopyInto(&out.Strategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.ProgressDeadlineSeconds != nil { | ||||
| 		in, out := &in.ProgressDeadlineSeconds, &out.ProgressDeadlineSeconds | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentSpec. | ||||
| func (in *DeploymentSpec) DeepCopy() *DeploymentSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStatus) DeepCopyInto(out *DeploymentStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]DeploymentCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStatus. | ||||
| func (in *DeploymentStatus) DeepCopy() *DeploymentStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStrategy) DeepCopyInto(out *DeploymentStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateDeployment) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStrategy. | ||||
| func (in *DeploymentStrategy) DeepCopy() *DeploymentStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSet) DeepCopyInto(out *ReplicaSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSet. | ||||
| func (in *ReplicaSet) DeepCopy() *ReplicaSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ReplicaSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetCondition) DeepCopyInto(out *ReplicaSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetCondition. | ||||
| func (in *ReplicaSetCondition) DeepCopy() *ReplicaSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetList) DeepCopyInto(out *ReplicaSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ReplicaSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetList. | ||||
| func (in *ReplicaSetList) DeepCopy() *ReplicaSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ReplicaSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetSpec) DeepCopyInto(out *ReplicaSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetSpec. | ||||
| func (in *ReplicaSetSpec) DeepCopy() *ReplicaSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetStatus) DeepCopyInto(out *ReplicaSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]ReplicaSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetStatus. | ||||
| func (in *ReplicaSetStatus) DeepCopy() *ReplicaSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateDaemonSet) DeepCopyInto(out *RollingUpdateDaemonSet) { | ||||
| 	*out = *in | ||||
| 	if in.MaxUnavailable != nil { | ||||
| 		in, out := &in.MaxUnavailable, &out.MaxUnavailable | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateDaemonSet. | ||||
| func (in *RollingUpdateDaemonSet) DeepCopy() *RollingUpdateDaemonSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateDaemonSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateDeployment) DeepCopyInto(out *RollingUpdateDeployment) { | ||||
| 	*out = *in | ||||
| 	if in.MaxUnavailable != nil { | ||||
| 		in, out := &in.MaxUnavailable, &out.MaxUnavailable | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.MaxSurge != nil { | ||||
| 		in, out := &in.MaxSurge, &out.MaxSurge | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateDeployment. | ||||
| func (in *RollingUpdateDeployment) DeepCopy() *RollingUpdateDeployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateDeployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopyInto(out *RollingUpdateStatefulSetStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.Partition != nil { | ||||
| 		in, out := &in.Partition, &out.Partition | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateStatefulSetStrategy. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopy() *RollingUpdateStatefulSetStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateStatefulSetStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSet) DeepCopyInto(out *StatefulSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSet. | ||||
| func (in *StatefulSet) DeepCopy() *StatefulSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetCondition) DeepCopyInto(out *StatefulSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetCondition. | ||||
| func (in *StatefulSetCondition) DeepCopy() *StatefulSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetList) DeepCopyInto(out *StatefulSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]StatefulSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetList. | ||||
| func (in *StatefulSetList) DeepCopy() *StatefulSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetSpec) DeepCopyInto(out *StatefulSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	if in.VolumeClaimTemplates != nil { | ||||
| 		in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates | ||||
| 		*out = make([]corev1.PersistentVolumeClaim, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	in.UpdateStrategy.DeepCopyInto(&out.UpdateStrategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetSpec. | ||||
| func (in *StatefulSetSpec) DeepCopy() *StatefulSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetStatus) DeepCopyInto(out *StatefulSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]StatefulSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetStatus. | ||||
| func (in *StatefulSetStatus) DeepCopy() *StatefulSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopyInto(out *StatefulSetUpdateStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateStatefulSetStrategy) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetUpdateStrategy. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopy() *StatefulSetUpdateStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetUpdateStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/apps/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/apps/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1beta1 // import "k8s.io/api/apps/v1beta1" | ||||
							
								
								
									
										5281
									
								
								vendor/k8s.io/api/apps/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5281
									
								
								vendor/k8s.io/api/apps/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										484
									
								
								vendor/k8s.io/api/apps/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										484
									
								
								vendor/k8s.io/api/apps/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,484 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.apps.v1beta1; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/util/intstr/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta1"; | ||||
|  | ||||
| // DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1beta2/ControllerRevision. See the | ||||
| // release notes for more information. | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| message ControllerRevision { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Data is the serialized representation of the state. | ||||
|   optional k8s.io.apimachinery.pkg.runtime.RawExtension data = 2; | ||||
|  | ||||
|   // Revision indicates the revision of the state represented by Data. | ||||
|   optional int64 revision = 3; | ||||
| } | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| message ControllerRevisionList { | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is the list of ControllerRevisions | ||||
|   repeated ControllerRevision items = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of Deployment is deprecated by apps/v1beta2/Deployment. See the release notes for | ||||
| // more information. | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| message Deployment { | ||||
|   // Standard object metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentSpec spec = 2; | ||||
|  | ||||
|   // Most recently observed status of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentStatus status = 3; | ||||
| } | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| message DeploymentCondition { | ||||
|   // Type of deployment condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // The last time this condition was updated. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastUpdateTime = 6; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 7; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| message DeploymentList { | ||||
|   // Standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is the list of Deployments. | ||||
|   repeated Deployment items = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED. | ||||
| // DeploymentRollback stores the information required to rollback a deployment. | ||||
| message DeploymentRollback { | ||||
|   // Required: This must match the Name of a deployment. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // The annotations to be updated to a deployment | ||||
|   // +optional | ||||
|   map<string, string> updatedAnnotations = 2; | ||||
|  | ||||
|   // The config of this deployment rollback. | ||||
|   optional RollbackConfig rollbackTo = 3; | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| message DeploymentSpec { | ||||
|   // Number of desired pods. This is a pointer to distinguish between explicit | ||||
|   // zero and not specified. Defaults to 1. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // Label selector for pods. Existing ReplicaSets whose pods are | ||||
|   // selected by this will be the ones affected by this deployment. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // Template describes the pods that will be created. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // The deployment strategy to use to replace existing pods with new ones. | ||||
|   // +optional | ||||
|   // +patchStrategy=retainKeys | ||||
|   optional DeploymentStrategy strategy = 4; | ||||
|  | ||||
|   // Minimum number of seconds for which a newly created pod should be ready | ||||
|   // without any of its container crashing, for it to be considered available. | ||||
|   // Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 5; | ||||
|  | ||||
|   // The number of old ReplicaSets to retain to allow rollback. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 2. | ||||
|   // +optional | ||||
|   optional int32 revisionHistoryLimit = 6; | ||||
|  | ||||
|   // Indicates that the deployment is paused. | ||||
|   // +optional | ||||
|   optional bool paused = 7; | ||||
|  | ||||
|   // DEPRECATED. | ||||
|   // The config this deployment is rolling back to. Will be cleared after rollback is done. | ||||
|   // +optional | ||||
|   optional RollbackConfig rollbackTo = 8; | ||||
|  | ||||
|   // The maximum time in seconds for a deployment to make progress before it | ||||
|   // is considered to be failed. The deployment controller will continue to | ||||
|   // process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
|   // reason will be surfaced in the deployment status. Note that progress will | ||||
|   // not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
|   // +optional | ||||
|   optional int32 progressDeadlineSeconds = 9; | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| message DeploymentStatus { | ||||
|   // The generation observed by the deployment controller. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
|   // +optional | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
|   // +optional | ||||
|   optional int32 updatedReplicas = 3; | ||||
|  | ||||
|   // Total number of ready pods targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 readyReplicas = 7; | ||||
|  | ||||
|   // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 availableReplicas = 4; | ||||
|  | ||||
|   // Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
|   // pods that are still required for the deployment to have 100% available capacity. They may | ||||
|   // either be pods that are running but not yet available or pods that still have not been created. | ||||
|   // +optional | ||||
|   optional int32 unavailableReplicas = 5; | ||||
|  | ||||
|   // Represents the latest available observations of a deployment's current state. | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated DeploymentCondition conditions = 6; | ||||
|  | ||||
|   // Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
|   // field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ReplicaSet. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 8; | ||||
| } | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| message DeploymentStrategy { | ||||
|   // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Rolling update config params. Present only if DeploymentStrategyType = | ||||
|   // RollingUpdate. | ||||
|   // --- | ||||
|   // TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
|   // to be. | ||||
|   // +optional | ||||
|   optional RollingUpdateDeployment rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED. | ||||
| message RollbackConfig { | ||||
|   // The revision to rollback to. If set to 0, rollback to the last revision. | ||||
|   // +optional | ||||
|   optional int64 revision = 1; | ||||
| } | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| message RollingUpdateDeployment { | ||||
|   // The maximum number of pods that can be unavailable during the update. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // Absolute number is calculated from percentage by rounding down. | ||||
|   // This can not be 0 if MaxSurge is 0. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
|   // immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
|   // can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
|   // that the total number of pods available at all times during the update is at | ||||
|   // least 70% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 1; | ||||
|  | ||||
|   // The maximum number of pods that can be scheduled above the desired number of | ||||
|   // pods. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // This can not be 0 if MaxUnavailable is 0. | ||||
|   // Absolute number is calculated from percentage by rounding up. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
|   // the rolling update starts, such that the total number of old and new pods do not exceed | ||||
|   // 130% of desired pods. Once old pods have been killed, | ||||
|   // new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
|   // at any time during the update is at most 130% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxSurge = 2; | ||||
| } | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| message RollingUpdateStatefulSetStrategy { | ||||
|   // Partition indicates the ordinal at which the StatefulSet should be | ||||
|   // partitioned. | ||||
|   optional int32 partition = 1; | ||||
| } | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| message Scale { | ||||
|   // Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional ScaleSpec spec = 2; | ||||
|  | ||||
|   // current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only. | ||||
|   // +optional | ||||
|   optional ScaleStatus status = 3; | ||||
| } | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource | ||||
| message ScaleSpec { | ||||
|   // desired number of instances for the scaled object. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| message ScaleStatus { | ||||
|   // actual number of observed instances of the scaled object. | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
|   // +optional | ||||
|   map<string, string> selector = 2; | ||||
|  | ||||
|   // label selector for pods that should match the replicas count. This is a serializated | ||||
|   // version of both map-based and more expressive set-based selectors. This is done to | ||||
|   // avoid introspection in the clients. The string will be in the same format as the | ||||
|   // query-param syntax. If the target type only supports map-based selectors, both this | ||||
|   // field and map-based selector field are populated. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   // +optional | ||||
|   optional string targetSelector = 3; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of StatefulSet is deprecated by apps/v1beta2/StatefulSet. See the release notes for | ||||
| // more information. | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| message StatefulSet { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec defines the desired identities of pods in this set. | ||||
|   // +optional | ||||
|   optional StatefulSetSpec spec = 2; | ||||
|  | ||||
|   // Status is the current status of Pods in this StatefulSet. This data | ||||
|   // may be out of date by some window of time. | ||||
|   // +optional | ||||
|   optional StatefulSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| message StatefulSetCondition { | ||||
|   // Type of statefulset condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| message StatefulSetList { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   repeated StatefulSet items = 2; | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| message StatefulSetSpec { | ||||
|   // replicas is the desired number of replicas of the given Template. | ||||
|   // These are replicas in the sense that they are instantiations of the | ||||
|   // same Template, but individual replicas also have a consistent identity. | ||||
|   // If unspecified, defaults to 1. | ||||
|   // TODO: Consider a rename of this field. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // selector is a label query over pods that should match the replica count. | ||||
|   // If empty, defaulted to labels on the pod template. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // template is the object that describes the pod that will be created if | ||||
|   // insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
|   // will fulfill this Template, but have a unique identity from the rest | ||||
|   // of the StatefulSet. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
|   // The StatefulSet controller is responsible for mapping network identities to | ||||
|   // claims in a way that maintains the identity of a pod. Every claim in | ||||
|   // this list must have at least one matching (by name) volumeMount in one | ||||
|   // container in the template. A claim in this list takes precedence over | ||||
|   // any volumes in the template, with the same name. | ||||
|   // TODO: Define the behavior if a claim already exists with the same name. | ||||
|   // +optional | ||||
|   repeated k8s.io.api.core.v1.PersistentVolumeClaim volumeClaimTemplates = 4; | ||||
|  | ||||
|   // serviceName is the name of the service that governs this StatefulSet. | ||||
|   // This service must exist before the StatefulSet, and is responsible for | ||||
|   // the network identity of the set. Pods get DNS/hostnames that follow the | ||||
|   // pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
|   // where "pod-specific-string" is managed by the StatefulSet controller. | ||||
|   optional string serviceName = 5; | ||||
|  | ||||
|   // podManagementPolicy controls how pods are created during initial scale up, | ||||
|   // when replacing pods on nodes, or when scaling down. The default policy is | ||||
|   // `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
|   // pod-1, etc) and the controller will wait until each pod is ready before | ||||
|   // continuing. When scaling down, the pods are removed in the opposite order. | ||||
|   // The alternative policy is `Parallel` which will create pods in parallel | ||||
|   // to match the desired scale without waiting, and on scale down will delete | ||||
|   // all pods at once. | ||||
|   // +optional | ||||
|   optional string podManagementPolicy = 6; | ||||
|  | ||||
|   // updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
|   // employed to update Pods in the StatefulSet when a revision is made to | ||||
|   // Template. | ||||
|   optional StatefulSetUpdateStrategy updateStrategy = 7; | ||||
|  | ||||
|   // revisionHistoryLimit is the maximum number of revisions that will | ||||
|   // be maintained in the StatefulSet's revision history. The revision history | ||||
|   // consists of all revisions not represented by a currently applied | ||||
|   // StatefulSetSpec version. The default value is 10. | ||||
|   optional int32 revisionHistoryLimit = 8; | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| message StatefulSetStatus { | ||||
|   // observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
|   // StatefulSet's generation, which is updated on mutation by the API Server. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // replicas is the number of Pods created by the StatefulSet controller. | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
|   optional int32 readyReplicas = 3; | ||||
|  | ||||
|   // currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by currentRevision. | ||||
|   optional int32 currentReplicas = 4; | ||||
|  | ||||
|   // updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by updateRevision. | ||||
|   optional int32 updatedReplicas = 5; | ||||
|  | ||||
|   // currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
|   // sequence [0,currentReplicas). | ||||
|   optional string currentRevision = 6; | ||||
|  | ||||
|   // updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
|   // [replicas-updatedReplicas,replicas) | ||||
|   optional string updateRevision = 7; | ||||
|  | ||||
|   // collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
|   // uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ControllerRevision. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 9; | ||||
|  | ||||
|   // Represents the latest available observations of a statefulset's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated StatefulSetCondition conditions = 10; | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| message StatefulSetUpdateStrategy { | ||||
|   // Type indicates the type of the StatefulSetUpdateStrategy. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
|   optional RollingUpdateStatefulSetStrategy rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										58
									
								
								vendor/k8s.io/api/apps/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/k8s.io/api/apps/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,58 @@ | ||||
| /* | ||||
| Copyright 2016 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "apps" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Deployment{}, | ||||
| 		&DeploymentList{}, | ||||
| 		&DeploymentRollback{}, | ||||
| 		&Scale{}, | ||||
| 		&StatefulSet{}, | ||||
| 		&StatefulSetList{}, | ||||
| 		&ControllerRevision{}, | ||||
| 		&ControllerRevisionList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										567
									
								
								vendor/k8s.io/api/apps/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										567
									
								
								vendor/k8s.io/api/apps/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,567 @@ | ||||
| /* | ||||
| Copyright 2016 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	ControllerRevisionHashLabelKey = "controller-revision-hash" | ||||
| 	StatefulSetRevisionLabel       = ControllerRevisionHashLabelKey | ||||
| 	StatefulSetPodNameLabel        = "statefulset.kubernetes.io/pod-name" | ||||
| ) | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource | ||||
| type ScaleSpec struct { | ||||
| 	// desired number of instances for the scaled object. | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| type ScaleStatus struct { | ||||
| 	// actual number of observed instances of the scaled object. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
| 	// +optional | ||||
| 	Selector map[string]string `json:"selector,omitempty" protobuf:"bytes,2,rep,name=selector"` | ||||
|  | ||||
| 	// label selector for pods that should match the replicas count. This is a serializated | ||||
| 	// version of both map-based and more expressive set-based selectors. This is done to | ||||
| 	// avoid introspection in the clients. The string will be in the same format as the | ||||
| 	// query-param syntax. If the target type only supports map-based selectors, both this | ||||
| 	// field and map-based selector field are populated. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	// +optional | ||||
| 	TargetSelector string `json:"targetSelector,omitempty" protobuf:"bytes,3,opt,name=targetSelector"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| type Scale struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec ScaleSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only. | ||||
| 	// +optional | ||||
| 	Status ScaleStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of StatefulSet is deprecated by apps/v1beta2/StatefulSet. See the release notes for | ||||
| // more information. | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| type StatefulSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec defines the desired identities of pods in this set. | ||||
| 	// +optional | ||||
| 	Spec StatefulSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is the current status of Pods in this StatefulSet. This data | ||||
| 	// may be out of date by some window of time. | ||||
| 	// +optional | ||||
| 	Status StatefulSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // PodManagementPolicyType defines the policy for creating pods under a stateful set. | ||||
| type PodManagementPolicyType string | ||||
|  | ||||
| const ( | ||||
| 	// OrderedReadyPodManagement will create pods in strictly increasing order on | ||||
| 	// scale up and strictly decreasing order on scale down, progressing only when | ||||
| 	// the previous pod is ready or terminated. At most one pod will be changed | ||||
| 	// at any time. | ||||
| 	OrderedReadyPodManagement PodManagementPolicyType = "OrderedReady" | ||||
| 	// ParallelPodManagement will create and delete pods as soon as the stateful set | ||||
| 	// replica count is changed, and will not wait for pods to be ready or complete | ||||
| 	// termination. | ||||
| 	ParallelPodManagement PodManagementPolicyType = "Parallel" | ||||
| ) | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| type StatefulSetUpdateStrategy struct { | ||||
| 	// Type indicates the type of the StatefulSetUpdateStrategy. | ||||
| 	Type StatefulSetUpdateStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetStrategyType"` | ||||
| 	// RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
| 	RollingUpdate *RollingUpdateStatefulSetStrategy `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategyType is a string enumeration type that enumerates | ||||
| // all possible update strategies for the StatefulSet controller. | ||||
| type StatefulSetUpdateStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// RollingUpdateStatefulSetStrategyType indicates that update will be | ||||
| 	// applied to all Pods in the StatefulSet with respect to the StatefulSet | ||||
| 	// ordering constraints. When a scale operation is performed with this | ||||
| 	// strategy, new Pods will be created from the specification version indicated | ||||
| 	// by the StatefulSet's updateRevision. | ||||
| 	RollingUpdateStatefulSetStrategyType = "RollingUpdate" | ||||
| 	// OnDeleteStatefulSetStrategyType triggers the legacy behavior. Version | ||||
| 	// tracking and ordered rolling restarts are disabled. Pods are recreated | ||||
| 	// from the StatefulSetSpec when they are manually deleted. When a scale | ||||
| 	// operation is performed with this strategy,specification version indicated | ||||
| 	// by the StatefulSet's currentRevision. | ||||
| 	OnDeleteStatefulSetStrategyType = "OnDelete" | ||||
| ) | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| type RollingUpdateStatefulSetStrategy struct { | ||||
| 	// Partition indicates the ordinal at which the StatefulSet should be | ||||
| 	// partitioned. | ||||
| 	Partition *int32 `json:"partition,omitempty" protobuf:"varint,1,opt,name=partition"` | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| type StatefulSetSpec struct { | ||||
| 	// replicas is the desired number of replicas of the given Template. | ||||
| 	// These are replicas in the sense that they are instantiations of the | ||||
| 	// same Template, but individual replicas also have a consistent identity. | ||||
| 	// If unspecified, defaults to 1. | ||||
| 	// TODO: Consider a rename of this field. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// selector is a label query over pods that should match the replica count. | ||||
| 	// If empty, defaulted to labels on the pod template. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// template is the object that describes the pod that will be created if | ||||
| 	// insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
| 	// will fulfill this Template, but have a unique identity from the rest | ||||
| 	// of the StatefulSet. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
| 	// The StatefulSet controller is responsible for mapping network identities to | ||||
| 	// claims in a way that maintains the identity of a pod. Every claim in | ||||
| 	// this list must have at least one matching (by name) volumeMount in one | ||||
| 	// container in the template. A claim in this list takes precedence over | ||||
| 	// any volumes in the template, with the same name. | ||||
| 	// TODO: Define the behavior if a claim already exists with the same name. | ||||
| 	// +optional | ||||
| 	VolumeClaimTemplates []v1.PersistentVolumeClaim `json:"volumeClaimTemplates,omitempty" protobuf:"bytes,4,rep,name=volumeClaimTemplates"` | ||||
|  | ||||
| 	// serviceName is the name of the service that governs this StatefulSet. | ||||
| 	// This service must exist before the StatefulSet, and is responsible for | ||||
| 	// the network identity of the set. Pods get DNS/hostnames that follow the | ||||
| 	// pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
| 	// where "pod-specific-string" is managed by the StatefulSet controller. | ||||
| 	ServiceName string `json:"serviceName" protobuf:"bytes,5,opt,name=serviceName"` | ||||
|  | ||||
| 	// podManagementPolicy controls how pods are created during initial scale up, | ||||
| 	// when replacing pods on nodes, or when scaling down. The default policy is | ||||
| 	// `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
| 	// pod-1, etc) and the controller will wait until each pod is ready before | ||||
| 	// continuing. When scaling down, the pods are removed in the opposite order. | ||||
| 	// The alternative policy is `Parallel` which will create pods in parallel | ||||
| 	// to match the desired scale without waiting, and on scale down will delete | ||||
| 	// all pods at once. | ||||
| 	// +optional | ||||
| 	PodManagementPolicy PodManagementPolicyType `json:"podManagementPolicy,omitempty" protobuf:"bytes,6,opt,name=podManagementPolicy,casttype=PodManagementPolicyType"` | ||||
|  | ||||
| 	// updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
| 	// employed to update Pods in the StatefulSet when a revision is made to | ||||
| 	// Template. | ||||
| 	UpdateStrategy StatefulSetUpdateStrategy `json:"updateStrategy,omitempty" protobuf:"bytes,7,opt,name=updateStrategy"` | ||||
|  | ||||
| 	// revisionHistoryLimit is the maximum number of revisions that will | ||||
| 	// be maintained in the StatefulSet's revision history. The revision history | ||||
| 	// consists of all revisions not represented by a currently applied | ||||
| 	// StatefulSetSpec version. The default value is 10. | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,8,opt,name=revisionHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| type StatefulSetStatus struct { | ||||
| 	// observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
| 	// StatefulSet's generation, which is updated on mutation by the API Server. | ||||
| 	// +optional | ||||
| 	ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// replicas is the number of Pods created by the StatefulSet controller. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,3,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by currentRevision. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas,omitempty" protobuf:"varint,4,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by updateRevision. | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,5,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
| 	// sequence [0,currentReplicas). | ||||
| 	CurrentRevision string `json:"currentRevision,omitempty" protobuf:"bytes,6,opt,name=currentRevision"` | ||||
|  | ||||
| 	// updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
| 	// [replicas-updatedReplicas,replicas) | ||||
| 	UpdateRevision string `json:"updateRevision,omitempty" protobuf:"bytes,7,opt,name=updateRevision"` | ||||
|  | ||||
| 	// collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
| 	// uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ControllerRevision. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,9,opt,name=collisionCount"` | ||||
|  | ||||
| 	// Represents the latest available observations of a statefulset's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []StatefulSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,10,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type StatefulSetConditionType string | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| type StatefulSetCondition struct { | ||||
| 	// Type of statefulset condition. | ||||
| 	Type StatefulSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| type StatefulSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	Items           []StatefulSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of Deployment is deprecated by apps/v1beta2/Deployment. See the release notes for | ||||
| // more information. | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| type Deployment struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of the Deployment. | ||||
| 	// +optional | ||||
| 	Spec DeploymentSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Most recently observed status of the Deployment. | ||||
| 	// +optional | ||||
| 	Status DeploymentStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| type DeploymentSpec struct { | ||||
| 	// Number of desired pods. This is a pointer to distinguish between explicit | ||||
| 	// zero and not specified. Defaults to 1. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// Label selector for pods. Existing ReplicaSets whose pods are | ||||
| 	// selected by this will be the ones affected by this deployment. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// Template describes the pods that will be created. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// The deployment strategy to use to replace existing pods with new ones. | ||||
| 	// +optional | ||||
| 	// +patchStrategy=retainKeys | ||||
| 	Strategy DeploymentStrategy `json:"strategy,omitempty" patchStrategy:"retainKeys" protobuf:"bytes,4,opt,name=strategy"` | ||||
|  | ||||
| 	// Minimum number of seconds for which a newly created pod should be ready | ||||
| 	// without any of its container crashing, for it to be considered available. | ||||
| 	// Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,5,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// The number of old ReplicaSets to retain to allow rollback. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 2. | ||||
| 	// +optional | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` | ||||
|  | ||||
| 	// Indicates that the deployment is paused. | ||||
| 	// +optional | ||||
| 	Paused bool `json:"paused,omitempty" protobuf:"varint,7,opt,name=paused"` | ||||
|  | ||||
| 	// DEPRECATED. | ||||
| 	// The config this deployment is rolling back to. Will be cleared after rollback is done. | ||||
| 	// +optional | ||||
| 	RollbackTo *RollbackConfig `json:"rollbackTo,omitempty" protobuf:"bytes,8,opt,name=rollbackTo"` | ||||
|  | ||||
| 	// The maximum time in seconds for a deployment to make progress before it | ||||
| 	// is considered to be failed. The deployment controller will continue to | ||||
| 	// process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
| 	// reason will be surfaced in the deployment status. Note that progress will | ||||
| 	// not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
| 	// +optional | ||||
| 	ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty" protobuf:"varint,9,opt,name=progressDeadlineSeconds"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED. | ||||
| // DeploymentRollback stores the information required to rollback a deployment. | ||||
| type DeploymentRollback struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Required: This must match the Name of a deployment. | ||||
| 	Name string `json:"name" protobuf:"bytes,1,opt,name=name"` | ||||
| 	// The annotations to be updated to a deployment | ||||
| 	// +optional | ||||
| 	UpdatedAnnotations map[string]string `json:"updatedAnnotations,omitempty" protobuf:"bytes,2,rep,name=updatedAnnotations"` | ||||
| 	// The config of this deployment rollback. | ||||
| 	RollbackTo RollbackConfig `json:"rollbackTo" protobuf:"bytes,3,opt,name=rollbackTo"` | ||||
| } | ||||
|  | ||||
| // DEPRECATED. | ||||
| type RollbackConfig struct { | ||||
| 	// The revision to rollback to. If set to 0, rollback to the last revision. | ||||
| 	// +optional | ||||
| 	Revision int64 `json:"revision,omitempty" protobuf:"varint,1,opt,name=revision"` | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	// DefaultDeploymentUniqueLabelKey is the default key of the selector that is added | ||||
| 	// to existing ReplicaSets (and label key that is added to its pods) to prevent the existing ReplicaSets | ||||
| 	// to select new pods (and old pods being select by new ReplicaSet). | ||||
| 	DefaultDeploymentUniqueLabelKey string = "pod-template-hash" | ||||
| ) | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| type DeploymentStrategy struct { | ||||
| 	// Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type DeploymentStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=DeploymentStrategyType"` | ||||
|  | ||||
| 	// Rolling update config params. Present only if DeploymentStrategyType = | ||||
| 	// RollingUpdate. | ||||
| 	//--- | ||||
| 	// TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
| 	// to be. | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateDeployment `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| type DeploymentStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// Kill all existing pods before creating new ones. | ||||
| 	RecreateDeploymentStrategyType DeploymentStrategyType = "Recreate" | ||||
|  | ||||
| 	// Replace the old ReplicaSets by new one using rolling update i.e gradually scale down the old ReplicaSets and scale up the new one. | ||||
| 	RollingUpdateDeploymentStrategyType DeploymentStrategyType = "RollingUpdate" | ||||
| ) | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| type RollingUpdateDeployment struct { | ||||
| 	// The maximum number of pods that can be unavailable during the update. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// Absolute number is calculated from percentage by rounding down. | ||||
| 	// This can not be 0 if MaxSurge is 0. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
| 	// immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
| 	// can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
| 	// that the total number of pods available at all times during the update is at | ||||
| 	// least 70% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` | ||||
|  | ||||
| 	// The maximum number of pods that can be scheduled above the desired number of | ||||
| 	// pods. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// This can not be 0 if MaxUnavailable is 0. | ||||
| 	// Absolute number is calculated from percentage by rounding up. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
| 	// the rolling update starts, such that the total number of old and new pods do not exceed | ||||
| 	// 130% of desired pods. Once old pods have been killed, | ||||
| 	// new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
| 	// at any time during the update is at most 130% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty" protobuf:"bytes,2,opt,name=maxSurge"` | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| type DeploymentStatus struct { | ||||
| 	// The generation observed by the deployment controller. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
| 	// +optional | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,3,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// Total number of ready pods targeted by this deployment. | ||||
| 	// +optional | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,7,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
| 	// +optional | ||||
| 	AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,4,opt,name=availableReplicas"` | ||||
|  | ||||
| 	// Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
| 	// pods that are still required for the deployment to have 100% available capacity. They may | ||||
| 	// either be pods that are running but not yet available or pods that still have not been created. | ||||
| 	// +optional | ||||
| 	UnavailableReplicas int32 `json:"unavailableReplicas,omitempty" protobuf:"varint,5,opt,name=unavailableReplicas"` | ||||
|  | ||||
| 	// Represents the latest available observations of a deployment's current state. | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []DeploymentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,6,rep,name=conditions"` | ||||
|  | ||||
| 	// Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
| 	// field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ReplicaSet. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,8,opt,name=collisionCount"` | ||||
| } | ||||
|  | ||||
| type DeploymentConditionType string | ||||
|  | ||||
| // These are valid conditions of a deployment. | ||||
| const ( | ||||
| 	// Available means the deployment is available, ie. at least the minimum available | ||||
| 	// replicas required are up and running for at least minReadySeconds. | ||||
| 	DeploymentAvailable DeploymentConditionType = "Available" | ||||
| 	// Progressing means the deployment is progressing. Progress for a deployment is | ||||
| 	// considered when a new replica set is created or adopted, and when new pods scale | ||||
| 	// up or old pods scale down. Progress is not estimated for paused deployments or | ||||
| 	// when progressDeadlineSeconds is not specified. | ||||
| 	DeploymentProgressing DeploymentConditionType = "Progressing" | ||||
| 	// ReplicaFailure is added in a deployment when one of its pods fails to be created | ||||
| 	// or deleted. | ||||
| 	DeploymentReplicaFailure DeploymentConditionType = "ReplicaFailure" | ||||
| ) | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| type DeploymentCondition struct { | ||||
| 	// Type of deployment condition. | ||||
| 	Type DeploymentConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DeploymentConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// The last time this condition was updated. | ||||
| 	LastUpdateTime metav1.Time `json:"lastUpdateTime,omitempty" protobuf:"bytes,6,opt,name=lastUpdateTime"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,7,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| type DeploymentList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is the list of Deployments. | ||||
| 	Items []Deployment `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1beta2/ControllerRevision. See the | ||||
| // release notes for more information. | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| type ControllerRevision struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Data is the serialized representation of the state. | ||||
| 	Data runtime.RawExtension `json:"data,omitempty" protobuf:"bytes,2,opt,name=data"` | ||||
|  | ||||
| 	// Revision indicates the revision of the state represented by Data. | ||||
| 	Revision int64 `json:"revision" protobuf:"varint,3,opt,name=revision"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| type ControllerRevisionList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is the list of ControllerRevisions | ||||
| 	Items []ControllerRevision `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										273
									
								
								vendor/k8s.io/api/apps/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										273
									
								
								vendor/k8s.io/api/apps/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,273 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_ControllerRevision = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1beta2/ControllerRevision. See the release notes for more information. ControllerRevision implements an immutable snapshot of state data. Clients are responsible for serializing and deserializing the objects that contain their internal state. Once a ControllerRevision has been successfully created, it can not be updated. The API Server will fail validation of all requests that attempt to mutate the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, it may be subject to name and representation changes in future releases, and clients should not depend on its stability. It is primarily for internal use by controllers.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"data":     "Data is the serialized representation of the state.", | ||||
| 	"revision": "Revision indicates the revision of the state represented by Data.", | ||||
| } | ||||
|  | ||||
| func (ControllerRevision) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevision | ||||
| } | ||||
|  | ||||
| var map_ControllerRevisionList = map[string]string{ | ||||
| 	"":         "ControllerRevisionList is a resource containing a list of ControllerRevision objects.", | ||||
| 	"metadata": "More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"items":    "Items is the list of ControllerRevisions", | ||||
| } | ||||
|  | ||||
| func (ControllerRevisionList) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevisionList | ||||
| } | ||||
|  | ||||
| var map_Deployment = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of Deployment is deprecated by apps/v1beta2/Deployment. See the release notes for more information. Deployment enables declarative updates for Pods and ReplicaSets.", | ||||
| 	"metadata": "Standard object metadata.", | ||||
| 	"spec":     "Specification of the desired behavior of the Deployment.", | ||||
| 	"status":   "Most recently observed status of the Deployment.", | ||||
| } | ||||
|  | ||||
| func (Deployment) SwaggerDoc() map[string]string { | ||||
| 	return map_Deployment | ||||
| } | ||||
|  | ||||
| var map_DeploymentCondition = map[string]string{ | ||||
| 	"":                   "DeploymentCondition describes the state of a deployment at a certain point.", | ||||
| 	"type":               "Type of deployment condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastUpdateTime":     "The last time this condition was updated.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (DeploymentCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentCondition | ||||
| } | ||||
|  | ||||
| var map_DeploymentList = map[string]string{ | ||||
| 	"":         "DeploymentList is a list of Deployments.", | ||||
| 	"metadata": "Standard list metadata.", | ||||
| 	"items":    "Items is the list of Deployments.", | ||||
| } | ||||
|  | ||||
| func (DeploymentList) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentList | ||||
| } | ||||
|  | ||||
| var map_DeploymentRollback = map[string]string{ | ||||
| 	"":                   "DEPRECATED. DeploymentRollback stores the information required to rollback a deployment.", | ||||
| 	"name":               "Required: This must match the Name of a deployment.", | ||||
| 	"updatedAnnotations": "The annotations to be updated to a deployment", | ||||
| 	"rollbackTo":         "The config of this deployment rollback.", | ||||
| } | ||||
|  | ||||
| func (DeploymentRollback) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentRollback | ||||
| } | ||||
|  | ||||
| var map_DeploymentSpec = map[string]string{ | ||||
| 	"":                        "DeploymentSpec is the specification of the desired behavior of the Deployment.", | ||||
| 	"replicas":                "Number of desired pods. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", | ||||
| 	"selector":                "Label selector for pods. Existing ReplicaSets whose pods are selected by this will be the ones affected by this deployment.", | ||||
| 	"template":                "Template describes the pods that will be created.", | ||||
| 	"strategy":                "The deployment strategy to use to replace existing pods with new ones.", | ||||
| 	"minReadySeconds":         "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", | ||||
| 	"revisionHistoryLimit":    "The number of old ReplicaSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 2.", | ||||
| 	"paused":                  "Indicates that the deployment is paused.", | ||||
| 	"rollbackTo":              "DEPRECATED. The config this deployment is rolling back to. Will be cleared after rollback is done.", | ||||
| 	"progressDeadlineSeconds": "The maximum time in seconds for a deployment to make progress before it is considered to be failed. The deployment controller will continue to process failed deployments and a condition with a ProgressDeadlineExceeded reason will be surfaced in the deployment status. Note that progress will not be estimated during the time a deployment is paused. Defaults to 600s.", | ||||
| } | ||||
|  | ||||
| func (DeploymentSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentSpec | ||||
| } | ||||
|  | ||||
| var map_DeploymentStatus = map[string]string{ | ||||
| 	"":                    "DeploymentStatus is the most recently observed status of the Deployment.", | ||||
| 	"observedGeneration":  "The generation observed by the deployment controller.", | ||||
| 	"replicas":            "Total number of non-terminated pods targeted by this deployment (their labels match the selector).", | ||||
| 	"updatedReplicas":     "Total number of non-terminated pods targeted by this deployment that have the desired template spec.", | ||||
| 	"readyReplicas":       "Total number of ready pods targeted by this deployment.", | ||||
| 	"availableReplicas":   "Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.", | ||||
| 	"unavailableReplicas": "Total number of unavailable pods targeted by this deployment. This is the total number of pods that are still required for the deployment to have 100% available capacity. They may either be pods that are running but not yet available or pods that still have not been created.", | ||||
| 	"conditions":          "Represents the latest available observations of a deployment's current state.", | ||||
| 	"collisionCount":      "Count of hash collisions for the Deployment. The Deployment controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ReplicaSet.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStatus | ||||
| } | ||||
|  | ||||
| var map_DeploymentStrategy = map[string]string{ | ||||
| 	"":              "DeploymentStrategy describes how to replace existing pods with new ones.", | ||||
| 	"type":          "Type of deployment. Can be \"Recreate\" or \"RollingUpdate\". Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "Rolling update config params. Present only if DeploymentStrategyType = RollingUpdate.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStrategy | ||||
| } | ||||
|  | ||||
| var map_RollbackConfig = map[string]string{ | ||||
| 	"":         "DEPRECATED.", | ||||
| 	"revision": "The revision to rollback to. If set to 0, rollback to the last revision.", | ||||
| } | ||||
|  | ||||
| func (RollbackConfig) SwaggerDoc() map[string]string { | ||||
| 	return map_RollbackConfig | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateDeployment = map[string]string{ | ||||
| 	"":               "Spec to control the desired behavior of rolling update.", | ||||
| 	"maxUnavailable": "The maximum number of pods that can be unavailable during the update. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). Absolute number is calculated from percentage by rounding down. This can not be 0 if MaxSurge is 0. Defaults to 25%. Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods immediately when the rolling update starts. Once new pods are ready, old ReplicaSet can be scaled down further, followed by scaling up the new ReplicaSet, ensuring that the total number of pods available at all times during the update is at least 70% of desired pods.", | ||||
| 	"maxSurge":       "The maximum number of pods that can be scheduled above the desired number of pods. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). This can not be 0 if MaxUnavailable is 0. Absolute number is calculated from percentage by rounding up. Defaults to 25%. Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when the rolling update starts, such that the total number of old and new pods do not exceed 130% of desired pods. Once old pods have been killed, new ReplicaSet can be scaled up further, ensuring that total number of pods running at any time during the update is at most 130% of desired pods.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateDeployment) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateDeployment | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateStatefulSetStrategy = map[string]string{ | ||||
| 	"":          "RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType.", | ||||
| 	"partition": "Partition indicates the ordinal at which the StatefulSet should be partitioned.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateStatefulSetStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateStatefulSetStrategy | ||||
| } | ||||
|  | ||||
| var map_Scale = map[string]string{ | ||||
| 	"":         "Scale represents a scaling request for a resource.", | ||||
| 	"metadata": "Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata.", | ||||
| 	"spec":     "defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only.", | ||||
| } | ||||
|  | ||||
| func (Scale) SwaggerDoc() map[string]string { | ||||
| 	return map_Scale | ||||
| } | ||||
|  | ||||
| var map_ScaleSpec = map[string]string{ | ||||
| 	"":         "ScaleSpec describes the attributes of a scale subresource", | ||||
| 	"replicas": "desired number of instances for the scaled object.", | ||||
| } | ||||
|  | ||||
| func (ScaleSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleSpec | ||||
| } | ||||
|  | ||||
| var map_ScaleStatus = map[string]string{ | ||||
| 	"":               "ScaleStatus represents the current status of a scale subresource.", | ||||
| 	"replicas":       "actual number of observed instances of the scaled object.", | ||||
| 	"selector":       "label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors", | ||||
| 	"targetSelector": "label selector for pods that should match the replicas count. This is a serializated version of both map-based and more expressive set-based selectors. This is done to avoid introspection in the clients. The string will be in the same format as the query-param syntax. If the target type only supports map-based selectors, both this field and map-based selector field are populated. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| } | ||||
|  | ||||
| func (ScaleStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleStatus | ||||
| } | ||||
|  | ||||
| var map_StatefulSet = map[string]string{ | ||||
| 	"":       "DEPRECATED - This group version of StatefulSet is deprecated by apps/v1beta2/StatefulSet. See the release notes for more information. StatefulSet represents a set of pods with consistent identities. Identities are defined as:\n - Network: A single stable DNS and hostname.\n - Storage: As many VolumeClaims as requested.\nThe StatefulSet guarantees that a given network identity will always map to the same storage identity.", | ||||
| 	"spec":   "Spec defines the desired identities of pods in this set.", | ||||
| 	"status": "Status is the current status of Pods in this StatefulSet. This data may be out of date by some window of time.", | ||||
| } | ||||
|  | ||||
| func (StatefulSet) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSet | ||||
| } | ||||
|  | ||||
| var map_StatefulSetCondition = map[string]string{ | ||||
| 	"":                   "StatefulSetCondition describes the state of a statefulset at a certain point.", | ||||
| 	"type":               "Type of statefulset condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetCondition | ||||
| } | ||||
|  | ||||
| var map_StatefulSetList = map[string]string{ | ||||
| 	"": "StatefulSetList is a collection of StatefulSets.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetList | ||||
| } | ||||
|  | ||||
| var map_StatefulSetSpec = map[string]string{ | ||||
| 	"":                     "A StatefulSetSpec is the specification of a StatefulSet.", | ||||
| 	"replicas":             "replicas is the desired number of replicas of the given Template. These are replicas in the sense that they are instantiations of the same Template, but individual replicas also have a consistent identity. If unspecified, defaults to 1.", | ||||
| 	"selector":             "selector is a label query over pods that should match the replica count. If empty, defaulted to labels on the pod template. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":             "template is the object that describes the pod that will be created if insufficient replicas are detected. Each pod stamped out by the StatefulSet will fulfill this Template, but have a unique identity from the rest of the StatefulSet.", | ||||
| 	"volumeClaimTemplates": "volumeClaimTemplates is a list of claims that pods are allowed to reference. The StatefulSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pod. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.", | ||||
| 	"serviceName":          "serviceName is the name of the service that governs this StatefulSet. This service must exist before the StatefulSet, and is responsible for the network identity of the set. Pods get DNS/hostnames that follow the pattern: pod-specific-string.serviceName.default.svc.cluster.local where \"pod-specific-string\" is managed by the StatefulSet controller.", | ||||
| 	"podManagementPolicy":  "podManagementPolicy controls how pods are created during initial scale up, when replacing pods on nodes, or when scaling down. The default policy is `OrderedReady`, where pods are created in increasing order (pod-0, then pod-1, etc) and the controller will wait until each pod is ready before continuing. When scaling down, the pods are removed in the opposite order. The alternative policy is `Parallel` which will create pods in parallel to match the desired scale without waiting, and on scale down will delete all pods at once.", | ||||
| 	"updateStrategy":       "updateStrategy indicates the StatefulSetUpdateStrategy that will be employed to update Pods in the StatefulSet when a revision is made to Template.", | ||||
| 	"revisionHistoryLimit": "revisionHistoryLimit is the maximum number of revisions that will be maintained in the StatefulSet's revision history. The revision history consists of all revisions not represented by a currently applied StatefulSetSpec version. The default value is 10.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetSpec | ||||
| } | ||||
|  | ||||
| var map_StatefulSetStatus = map[string]string{ | ||||
| 	"":                   "StatefulSetStatus represents the current state of a StatefulSet.", | ||||
| 	"observedGeneration": "observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the StatefulSet's generation, which is updated on mutation by the API Server.", | ||||
| 	"replicas":           "replicas is the number of Pods created by the StatefulSet controller.", | ||||
| 	"readyReplicas":      "readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition.", | ||||
| 	"currentReplicas":    "currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by currentRevision.", | ||||
| 	"updatedReplicas":    "updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by updateRevision.", | ||||
| 	"currentRevision":    "currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [0,currentReplicas).", | ||||
| 	"updateRevision":     "updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [replicas-updatedReplicas,replicas)", | ||||
| 	"collisionCount":     "collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ControllerRevision.", | ||||
| 	"conditions":         "Represents the latest available observations of a statefulset's current state.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetStatus | ||||
| } | ||||
|  | ||||
| var map_StatefulSetUpdateStrategy = map[string]string{ | ||||
| 	"":              "StatefulSetUpdateStrategy indicates the strategy that the StatefulSet controller will use to perform updates. It includes any additional parameters necessary to perform the update for the indicated strategy.", | ||||
| 	"type":          "Type indicates the type of the StatefulSetUpdateStrategy.", | ||||
| 	"rollingUpdate": "RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetUpdateStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetUpdateStrategy | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										594
									
								
								vendor/k8s.io/api/apps/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										594
									
								
								vendor/k8s.io/api/apps/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,594 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	corev1 "k8s.io/api/core/v1" | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevision) DeepCopyInto(out *ControllerRevision) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Data.DeepCopyInto(&out.Data) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevision. | ||||
| func (in *ControllerRevision) DeepCopy() *ControllerRevision { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevision) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevision) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevisionList) DeepCopyInto(out *ControllerRevisionList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ControllerRevision, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevisionList. | ||||
| func (in *ControllerRevisionList) DeepCopy() *ControllerRevisionList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevisionList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevisionList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Deployment) DeepCopyInto(out *Deployment) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Deployment. | ||||
| func (in *Deployment) DeepCopy() *Deployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Deployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Deployment) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentCondition) DeepCopyInto(out *DeploymentCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastUpdateTime.DeepCopyInto(&out.LastUpdateTime) | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentCondition. | ||||
| func (in *DeploymentCondition) DeepCopy() *DeploymentCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentList) DeepCopyInto(out *DeploymentList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]Deployment, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentList. | ||||
| func (in *DeploymentList) DeepCopy() *DeploymentList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DeploymentList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentRollback) DeepCopyInto(out *DeploymentRollback) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	if in.UpdatedAnnotations != nil { | ||||
| 		in, out := &in.UpdatedAnnotations, &out.UpdatedAnnotations | ||||
| 		*out = make(map[string]string, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			(*out)[key] = val | ||||
| 		} | ||||
| 	} | ||||
| 	out.RollbackTo = in.RollbackTo | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentRollback. | ||||
| func (in *DeploymentRollback) DeepCopy() *DeploymentRollback { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentRollback) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DeploymentRollback) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentSpec) DeepCopyInto(out *DeploymentSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	in.Strategy.DeepCopyInto(&out.Strategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.RollbackTo != nil { | ||||
| 		in, out := &in.RollbackTo, &out.RollbackTo | ||||
| 		*out = new(RollbackConfig) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.ProgressDeadlineSeconds != nil { | ||||
| 		in, out := &in.ProgressDeadlineSeconds, &out.ProgressDeadlineSeconds | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentSpec. | ||||
| func (in *DeploymentSpec) DeepCopy() *DeploymentSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStatus) DeepCopyInto(out *DeploymentStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]DeploymentCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStatus. | ||||
| func (in *DeploymentStatus) DeepCopy() *DeploymentStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStrategy) DeepCopyInto(out *DeploymentStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateDeployment) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStrategy. | ||||
| func (in *DeploymentStrategy) DeepCopy() *DeploymentStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollbackConfig) DeepCopyInto(out *RollbackConfig) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollbackConfig. | ||||
| func (in *RollbackConfig) DeepCopy() *RollbackConfig { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollbackConfig) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateDeployment) DeepCopyInto(out *RollingUpdateDeployment) { | ||||
| 	*out = *in | ||||
| 	if in.MaxUnavailable != nil { | ||||
| 		in, out := &in.MaxUnavailable, &out.MaxUnavailable | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.MaxSurge != nil { | ||||
| 		in, out := &in.MaxSurge, &out.MaxSurge | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateDeployment. | ||||
| func (in *RollingUpdateDeployment) DeepCopy() *RollingUpdateDeployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateDeployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopyInto(out *RollingUpdateStatefulSetStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.Partition != nil { | ||||
| 		in, out := &in.Partition, &out.Partition | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateStatefulSetStrategy. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopy() *RollingUpdateStatefulSetStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateStatefulSetStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Scale) DeepCopyInto(out *Scale) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	out.Spec = in.Spec | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Scale. | ||||
| func (in *Scale) DeepCopy() *Scale { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Scale) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Scale) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleSpec) DeepCopyInto(out *ScaleSpec) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleSpec. | ||||
| func (in *ScaleSpec) DeepCopy() *ScaleSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleStatus) DeepCopyInto(out *ScaleStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = make(map[string]string, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			(*out)[key] = val | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleStatus. | ||||
| func (in *ScaleStatus) DeepCopy() *ScaleStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSet) DeepCopyInto(out *StatefulSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSet. | ||||
| func (in *StatefulSet) DeepCopy() *StatefulSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetCondition) DeepCopyInto(out *StatefulSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetCondition. | ||||
| func (in *StatefulSetCondition) DeepCopy() *StatefulSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetList) DeepCopyInto(out *StatefulSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]StatefulSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetList. | ||||
| func (in *StatefulSetList) DeepCopy() *StatefulSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetSpec) DeepCopyInto(out *StatefulSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	if in.VolumeClaimTemplates != nil { | ||||
| 		in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates | ||||
| 		*out = make([]corev1.PersistentVolumeClaim, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	in.UpdateStrategy.DeepCopyInto(&out.UpdateStrategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetSpec. | ||||
| func (in *StatefulSetSpec) DeepCopy() *StatefulSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetStatus) DeepCopyInto(out *StatefulSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ObservedGeneration != nil { | ||||
| 		in, out := &in.ObservedGeneration, &out.ObservedGeneration | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]StatefulSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetStatus. | ||||
| func (in *StatefulSetStatus) DeepCopy() *StatefulSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopyInto(out *StatefulSetUpdateStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateStatefulSetStrategy) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetUpdateStrategy. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopy() *StatefulSetUpdateStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetUpdateStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/apps/v1beta2/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/apps/v1beta2/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1beta2 // import "k8s.io/api/apps/v1beta2" | ||||
							
								
								
									
										7573
									
								
								vendor/k8s.io/api/apps/v1beta2/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7573
									
								
								vendor/k8s.io/api/apps/v1beta2/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										752
									
								
								vendor/k8s.io/api/apps/v1beta2/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										752
									
								
								vendor/k8s.io/api/apps/v1beta2/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,752 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.apps.v1beta2; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/util/intstr/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta2"; | ||||
|  | ||||
| // DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1/ControllerRevision. See the | ||||
| // release notes for more information. | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| message ControllerRevision { | ||||
|   // 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; | ||||
|  | ||||
|   // Data is the serialized representation of the state. | ||||
|   optional k8s.io.apimachinery.pkg.runtime.RawExtension data = 2; | ||||
|  | ||||
|   // Revision indicates the revision of the state represented by Data. | ||||
|   optional int64 revision = 3; | ||||
| } | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| message ControllerRevisionList { | ||||
|   // 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; | ||||
|  | ||||
|   // Items is the list of ControllerRevisions | ||||
|   repeated ControllerRevision items = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of DaemonSet is deprecated by apps/v1/DaemonSet. See the release notes for | ||||
| // more information. | ||||
| // DaemonSet represents the configuration of a daemon set. | ||||
| message DaemonSet { | ||||
|   // 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; | ||||
|  | ||||
|   // The desired behavior of this daemon set. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional DaemonSetSpec spec = 2; | ||||
|  | ||||
|   // The current status of this daemon set. 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 | ||||
|   // +optional | ||||
|   optional DaemonSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // DaemonSetCondition describes the state of a DaemonSet at a certain point. | ||||
| message DaemonSetCondition { | ||||
|   // Type of DaemonSet condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // DaemonSetList is a collection of daemon sets. | ||||
| message DaemonSetList { | ||||
|   // Standard list 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; | ||||
|  | ||||
|   // A list of daemon sets. | ||||
|   repeated DaemonSet items = 2; | ||||
| } | ||||
|  | ||||
| // DaemonSetSpec is the specification of a daemon set. | ||||
| message DaemonSetSpec { | ||||
|   // A label query over pods that are managed by the daemon set. | ||||
|   // Must match in order to be controlled. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 1; | ||||
|  | ||||
|   // An object that describes the pod that will be created. | ||||
|   // The DaemonSet will create exactly one copy of this pod on every node | ||||
|   // that matches the template's node selector (or on every node if no node | ||||
|   // selector is specified). | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 2; | ||||
|  | ||||
|   // An update strategy to replace existing DaemonSet pods with new pods. | ||||
|   // +optional | ||||
|   optional DaemonSetUpdateStrategy updateStrategy = 3; | ||||
|  | ||||
|   // The minimum number of seconds for which a newly created DaemonSet pod should | ||||
|   // be ready without any of its container crashing, for it to be considered | ||||
|   // available. Defaults to 0 (pod will be considered available as soon as it | ||||
|   // is ready). | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 4; | ||||
|  | ||||
|   // The number of old history to retain to allow rollback. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 10. | ||||
|   // +optional | ||||
|   optional int32 revisionHistoryLimit = 6; | ||||
| } | ||||
|  | ||||
| // DaemonSetStatus represents the current status of a daemon set. | ||||
| message DaemonSetStatus { | ||||
|   // The number of nodes that are running at least 1 | ||||
|   // daemon pod and are supposed to run the daemon pod. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 currentNumberScheduled = 1; | ||||
|  | ||||
|   // The number of nodes that are running the daemon pod, but are | ||||
|   // not supposed to run the daemon pod. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 numberMisscheduled = 2; | ||||
|  | ||||
|   // The total number of nodes that should be running the daemon | ||||
|   // pod (including nodes correctly running the daemon pod). | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
|   optional int32 desiredNumberScheduled = 3; | ||||
|  | ||||
|   // The number of nodes that should be running the daemon pod and have one | ||||
|   // or more of the daemon pod running and ready. | ||||
|   optional int32 numberReady = 4; | ||||
|  | ||||
|   // The most recent generation observed by the daemon set controller. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 5; | ||||
|  | ||||
|   // The total number of nodes that are running updated daemon pod | ||||
|   // +optional | ||||
|   optional int32 updatedNumberScheduled = 6; | ||||
|  | ||||
|   // The number of nodes that should be running the | ||||
|   // daemon pod and have one or more of the daemon pod running and | ||||
|   // available (ready for at least spec.minReadySeconds) | ||||
|   // +optional | ||||
|   optional int32 numberAvailable = 7; | ||||
|  | ||||
|   // The number of nodes that should be running the | ||||
|   // daemon pod and have none of the daemon pod running and available | ||||
|   // (ready for at least spec.minReadySeconds) | ||||
|   // +optional | ||||
|   optional int32 numberUnavailable = 8; | ||||
|  | ||||
|   // Count of hash collisions for the DaemonSet. The DaemonSet controller | ||||
|   // uses this field as a collision avoidance mechanism when it needs to | ||||
|   // create the name for the newest ControllerRevision. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 9; | ||||
|  | ||||
|   // Represents the latest available observations of a DaemonSet's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated DaemonSetCondition conditions = 10; | ||||
| } | ||||
|  | ||||
| // DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet. | ||||
| message DaemonSetUpdateStrategy { | ||||
|   // Type of daemon set update. Can be "RollingUpdate" or "OnDelete". Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Rolling update config params. Present only if type = "RollingUpdate". | ||||
|   // --- | ||||
|   // TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
|   // to be. Same as Deployment `strategy.rollingUpdate`. | ||||
|   // See https://github.com/kubernetes/kubernetes/issues/35345 | ||||
|   // +optional | ||||
|   optional RollingUpdateDaemonSet rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of Deployment is deprecated by apps/v1/Deployment. See the release notes for | ||||
| // more information. | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| message Deployment { | ||||
|   // Standard object metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentSpec spec = 2; | ||||
|  | ||||
|   // Most recently observed status of the Deployment. | ||||
|   // +optional | ||||
|   optional DeploymentStatus status = 3; | ||||
| } | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| message DeploymentCondition { | ||||
|   // Type of deployment condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // The last time this condition was updated. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastUpdateTime = 6; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 7; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| message DeploymentList { | ||||
|   // Standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is the list of Deployments. | ||||
|   repeated Deployment items = 2; | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| message DeploymentSpec { | ||||
|   // Number of desired pods. This is a pointer to distinguish between explicit | ||||
|   // zero and not specified. Defaults to 1. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // Label selector for pods. Existing ReplicaSets whose pods are | ||||
|   // selected by this will be the ones affected by this deployment. | ||||
|   // It must match the pod template's labels. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // Template describes the pods that will be created. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // The deployment strategy to use to replace existing pods with new ones. | ||||
|   // +optional | ||||
|   // +patchStrategy=retainKeys | ||||
|   optional DeploymentStrategy strategy = 4; | ||||
|  | ||||
|   // Minimum number of seconds for which a newly created pod should be ready | ||||
|   // without any of its container crashing, for it to be considered available. | ||||
|   // Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 5; | ||||
|  | ||||
|   // The number of old ReplicaSets to retain to allow rollback. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 10. | ||||
|   // +optional | ||||
|   optional int32 revisionHistoryLimit = 6; | ||||
|  | ||||
|   // Indicates that the deployment is paused. | ||||
|   // +optional | ||||
|   optional bool paused = 7; | ||||
|  | ||||
|   // The maximum time in seconds for a deployment to make progress before it | ||||
|   // is considered to be failed. The deployment controller will continue to | ||||
|   // process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
|   // reason will be surfaced in the deployment status. Note that progress will | ||||
|   // not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
|   optional int32 progressDeadlineSeconds = 9; | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| message DeploymentStatus { | ||||
|   // The generation observed by the deployment controller. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
|   // +optional | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
|   // +optional | ||||
|   optional int32 updatedReplicas = 3; | ||||
|  | ||||
|   // Total number of ready pods targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 readyReplicas = 7; | ||||
|  | ||||
|   // Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
|   // +optional | ||||
|   optional int32 availableReplicas = 4; | ||||
|  | ||||
|   // Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
|   // pods that are still required for the deployment to have 100% available capacity. They may | ||||
|   // either be pods that are running but not yet available or pods that still have not been created. | ||||
|   // +optional | ||||
|   optional int32 unavailableReplicas = 5; | ||||
|  | ||||
|   // Represents the latest available observations of a deployment's current state. | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated DeploymentCondition conditions = 6; | ||||
|  | ||||
|   // Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
|   // field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ReplicaSet. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 8; | ||||
| } | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| message DeploymentStrategy { | ||||
|   // Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Rolling update config params. Present only if DeploymentStrategyType = | ||||
|   // RollingUpdate. | ||||
|   // --- | ||||
|   // TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
|   // to be. | ||||
|   // +optional | ||||
|   optional RollingUpdateDeployment rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of ReplicaSet is deprecated by apps/v1/ReplicaSet. See the release notes for | ||||
| // more information. | ||||
| // ReplicaSet ensures that a specified number of pod replicas are running at any given time. | ||||
| message ReplicaSet { | ||||
|   // If the Labels of a ReplicaSet are empty, they are defaulted to | ||||
|   // be the same as the Pod(s) that the ReplicaSet manages. | ||||
|   // 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 ReplicaSet. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional ReplicaSetSpec spec = 2; | ||||
|  | ||||
|   // Status is the most recently observed status of the ReplicaSet. | ||||
|   // 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 | ||||
|   // +optional | ||||
|   optional ReplicaSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // ReplicaSetCondition describes the state of a replica set at a certain point. | ||||
| message ReplicaSetCondition { | ||||
|   // Type of replica set condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // The last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // ReplicaSetList is a collection of ReplicaSets. | ||||
| message ReplicaSetList { | ||||
|   // Standard list metadata. | ||||
|   // 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 ReplicaSets. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller | ||||
|   repeated ReplicaSet items = 2; | ||||
| } | ||||
|  | ||||
| // ReplicaSetSpec is the specification of a ReplicaSet. | ||||
| message ReplicaSetSpec { | ||||
|   // Replicas is the number of desired replicas. | ||||
|   // This is a pointer to distinguish between explicit zero and unspecified. | ||||
|   // Defaults to 1. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // Minimum number of seconds for which a newly created pod should be ready | ||||
|   // without any of its container crashing, for it to be considered available. | ||||
|   // Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
|   // +optional | ||||
|   optional int32 minReadySeconds = 4; | ||||
|  | ||||
|   // Selector is a label query over pods that should match the replica count. | ||||
|   // Label keys and values that must match in order to be controlled by this replica set. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // Template is the object that describes the pod that will be created if | ||||
|   // insufficient replicas are detected. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
|   // +optional | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
| } | ||||
|  | ||||
| // ReplicaSetStatus represents the current status of a ReplicaSet. | ||||
| message ReplicaSetStatus { | ||||
|   // Replicas is the most recently oberved number of replicas. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // The number of pods that have labels matching the labels of the pod template of the replicaset. | ||||
|   // +optional | ||||
|   optional int32 fullyLabeledReplicas = 2; | ||||
|  | ||||
|   // The number of ready replicas for this replica set. | ||||
|   // +optional | ||||
|   optional int32 readyReplicas = 4; | ||||
|  | ||||
|   // The number of available replicas (ready for at least minReadySeconds) for this replica set. | ||||
|   // +optional | ||||
|   optional int32 availableReplicas = 5; | ||||
|  | ||||
|   // ObservedGeneration reflects the generation of the most recently observed ReplicaSet. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 3; | ||||
|  | ||||
|   // Represents the latest available observations of a replica set's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated ReplicaSetCondition conditions = 6; | ||||
| } | ||||
|  | ||||
| // Spec to control the desired behavior of daemon set rolling update. | ||||
| message RollingUpdateDaemonSet { | ||||
|   // The maximum number of DaemonSet pods that can be unavailable during the | ||||
|   // update. Value can be an absolute number (ex: 5) or a percentage of total | ||||
|   // number of DaemonSet pods at the start of the update (ex: 10%). Absolute | ||||
|   // number is calculated from percentage by rounding up. | ||||
|   // This cannot be 0. | ||||
|   // Default value is 1. | ||||
|   // Example: when this is set to 30%, at most 30% of the total number of nodes | ||||
|   // that should be running the daemon pod (i.e. status.desiredNumberScheduled) | ||||
|   // can have their pods stopped for an update at any given | ||||
|   // time. The update starts by stopping at most 30% of those DaemonSet pods | ||||
|   // and then brings up new DaemonSet pods in their place. Once the new pods | ||||
|   // are available, it then proceeds onto other DaemonSet pods, thus ensuring | ||||
|   // that at least 70% of original number of DaemonSet pods are available at | ||||
|   // all times during the update. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 1; | ||||
| } | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| message RollingUpdateDeployment { | ||||
|   // The maximum number of pods that can be unavailable during the update. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // Absolute number is calculated from percentage by rounding down. | ||||
|   // This can not be 0 if MaxSurge is 0. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
|   // immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
|   // can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
|   // that the total number of pods available at all times during the update is at | ||||
|   // least 70% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxUnavailable = 1; | ||||
|  | ||||
|   // The maximum number of pods that can be scheduled above the desired number of | ||||
|   // pods. | ||||
|   // Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
|   // This can not be 0 if MaxUnavailable is 0. | ||||
|   // Absolute number is calculated from percentage by rounding up. | ||||
|   // Defaults to 25%. | ||||
|   // Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
|   // the rolling update starts, such that the total number of old and new pods do not exceed | ||||
|   // 130% of desired pods. Once old pods have been killed, | ||||
|   // new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
|   // at any time during the update is at most 130% of desired pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.util.intstr.IntOrString maxSurge = 2; | ||||
| } | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| message RollingUpdateStatefulSetStrategy { | ||||
|   // Partition indicates the ordinal at which the StatefulSet should be | ||||
|   // partitioned. | ||||
|   // Default value is 0. | ||||
|   // +optional | ||||
|   optional int32 partition = 1; | ||||
| } | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| message Scale { | ||||
|   // Standard object 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; | ||||
|  | ||||
|   // defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional ScaleSpec spec = 2; | ||||
|  | ||||
|   // current status of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status. Read-only. | ||||
|   // +optional | ||||
|   optional ScaleStatus status = 3; | ||||
| } | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource | ||||
| message ScaleSpec { | ||||
|   // desired number of instances for the scaled object. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| message ScaleStatus { | ||||
|   // actual number of observed instances of the scaled object. | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
|   // +optional | ||||
|   map<string, string> selector = 2; | ||||
|  | ||||
|   // label selector for pods that should match the replicas count. This is a serializated | ||||
|   // version of both map-based and more expressive set-based selectors. This is done to | ||||
|   // avoid introspection in the clients. The string will be in the same format as the | ||||
|   // query-param syntax. If the target type only supports map-based selectors, both this | ||||
|   // field and map-based selector field are populated. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   // +optional | ||||
|   optional string targetSelector = 3; | ||||
| } | ||||
|  | ||||
| // DEPRECATED - This group version of StatefulSet is deprecated by apps/v1/StatefulSet. See the release notes for | ||||
| // more information. | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| message StatefulSet { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec defines the desired identities of pods in this set. | ||||
|   // +optional | ||||
|   optional StatefulSetSpec spec = 2; | ||||
|  | ||||
|   // Status is the current status of Pods in this StatefulSet. This data | ||||
|   // may be out of date by some window of time. | ||||
|   // +optional | ||||
|   optional StatefulSetStatus status = 3; | ||||
| } | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| message StatefulSetCondition { | ||||
|   // Type of statefulset condition. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition transitioned from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // The reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // A human readable message indicating details about the transition. | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| message StatefulSetList { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   repeated StatefulSet items = 2; | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| message StatefulSetSpec { | ||||
|   // replicas is the desired number of replicas of the given Template. | ||||
|   // These are replicas in the sense that they are instantiations of the | ||||
|   // same Template, but individual replicas also have a consistent identity. | ||||
|   // If unspecified, defaults to 1. | ||||
|   // TODO: Consider a rename of this field. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // selector is a label query over pods that should match the replica count. | ||||
|   // It must match the pod template's labels. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
|  | ||||
|   // template is the object that describes the pod that will be created if | ||||
|   // insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
|   // will fulfill this Template, but have a unique identity from the rest | ||||
|   // of the StatefulSet. | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 3; | ||||
|  | ||||
|   // volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
|   // The StatefulSet controller is responsible for mapping network identities to | ||||
|   // claims in a way that maintains the identity of a pod. Every claim in | ||||
|   // this list must have at least one matching (by name) volumeMount in one | ||||
|   // container in the template. A claim in this list takes precedence over | ||||
|   // any volumes in the template, with the same name. | ||||
|   // TODO: Define the behavior if a claim already exists with the same name. | ||||
|   // +optional | ||||
|   repeated k8s.io.api.core.v1.PersistentVolumeClaim volumeClaimTemplates = 4; | ||||
|  | ||||
|   // serviceName is the name of the service that governs this StatefulSet. | ||||
|   // This service must exist before the StatefulSet, and is responsible for | ||||
|   // the network identity of the set. Pods get DNS/hostnames that follow the | ||||
|   // pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
|   // where "pod-specific-string" is managed by the StatefulSet controller. | ||||
|   optional string serviceName = 5; | ||||
|  | ||||
|   // podManagementPolicy controls how pods are created during initial scale up, | ||||
|   // when replacing pods on nodes, or when scaling down. The default policy is | ||||
|   // `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
|   // pod-1, etc) and the controller will wait until each pod is ready before | ||||
|   // continuing. When scaling down, the pods are removed in the opposite order. | ||||
|   // The alternative policy is `Parallel` which will create pods in parallel | ||||
|   // to match the desired scale without waiting, and on scale down will delete | ||||
|   // all pods at once. | ||||
|   // +optional | ||||
|   optional string podManagementPolicy = 6; | ||||
|  | ||||
|   // updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
|   // employed to update Pods in the StatefulSet when a revision is made to | ||||
|   // Template. | ||||
|   optional StatefulSetUpdateStrategy updateStrategy = 7; | ||||
|  | ||||
|   // revisionHistoryLimit is the maximum number of revisions that will | ||||
|   // be maintained in the StatefulSet's revision history. The revision history | ||||
|   // consists of all revisions not represented by a currently applied | ||||
|   // StatefulSetSpec version. The default value is 10. | ||||
|   optional int32 revisionHistoryLimit = 8; | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| message StatefulSetStatus { | ||||
|   // observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
|   // StatefulSet's generation, which is updated on mutation by the API Server. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // replicas is the number of Pods created by the StatefulSet controller. | ||||
|   optional int32 replicas = 2; | ||||
|  | ||||
|   // readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
|   optional int32 readyReplicas = 3; | ||||
|  | ||||
|   // currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by currentRevision. | ||||
|   optional int32 currentReplicas = 4; | ||||
|  | ||||
|   // updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
|   // indicated by updateRevision. | ||||
|   optional int32 updatedReplicas = 5; | ||||
|  | ||||
|   // currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
|   // sequence [0,currentReplicas). | ||||
|   optional string currentRevision = 6; | ||||
|  | ||||
|   // updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
|   // [replicas-updatedReplicas,replicas) | ||||
|   optional string updateRevision = 7; | ||||
|  | ||||
|   // collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
|   // uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
|   // newest ControllerRevision. | ||||
|   // +optional | ||||
|   optional int32 collisionCount = 9; | ||||
|  | ||||
|   // Represents the latest available observations of a statefulset's current state. | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated StatefulSetCondition conditions = 10; | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| message StatefulSetUpdateStrategy { | ||||
|   // Type indicates the type of the StatefulSetUpdateStrategy. | ||||
|   // Default is RollingUpdate. | ||||
|   // +optional | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
|   // +optional | ||||
|   optional RollingUpdateStatefulSetStrategy rollingUpdate = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										61
									
								
								vendor/k8s.io/api/apps/v1beta2/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								vendor/k8s.io/api/apps/v1beta2/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,61 @@ | ||||
| /* | ||||
| Copyright 2016 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 v1beta2 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "apps" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta2"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Deployment{}, | ||||
| 		&DeploymentList{}, | ||||
| 		&Scale{}, | ||||
| 		&StatefulSet{}, | ||||
| 		&StatefulSetList{}, | ||||
| 		&DaemonSet{}, | ||||
| 		&DaemonSetList{}, | ||||
| 		&ReplicaSet{}, | ||||
| 		&ReplicaSetList{}, | ||||
| 		&ControllerRevision{}, | ||||
| 		&ControllerRevisionList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										876
									
								
								vendor/k8s.io/api/apps/v1beta2/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										876
									
								
								vendor/k8s.io/api/apps/v1beta2/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,876 @@ | ||||
| /* | ||||
| Copyright 2017 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 v1beta2 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	ControllerRevisionHashLabelKey = "controller-revision-hash" | ||||
| 	StatefulSetRevisionLabel       = ControllerRevisionHashLabelKey | ||||
| 	DeprecatedRollbackTo           = "deprecated.deployment.rollback.to" | ||||
| 	DeprecatedTemplateGeneration   = "deprecated.daemonset.template.generation" | ||||
| 	StatefulSetPodNameLabel        = "statefulset.kubernetes.io/pod-name" | ||||
| ) | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource | ||||
| type ScaleSpec struct { | ||||
| 	// desired number of instances for the scaled object. | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| type ScaleStatus struct { | ||||
| 	// actual number of observed instances of the scaled object. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
| 	// +optional | ||||
| 	Selector map[string]string `json:"selector,omitempty" protobuf:"bytes,2,rep,name=selector"` | ||||
|  | ||||
| 	// label selector for pods that should match the replicas count. This is a serializated | ||||
| 	// version of both map-based and more expressive set-based selectors. This is done to | ||||
| 	// avoid introspection in the clients. The string will be in the same format as the | ||||
| 	// query-param syntax. If the target type only supports map-based selectors, both this | ||||
| 	// field and map-based selector field are populated. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	// +optional | ||||
| 	TargetSelector string `json:"targetSelector,omitempty" protobuf:"bytes,3,opt,name=targetSelector"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| type Scale struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object 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"` | ||||
|  | ||||
| 	// defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec ScaleSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// current status of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status. Read-only. | ||||
| 	// +optional | ||||
| 	Status ScaleStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:method=GetScale,verb=get,subresource=scale,result=Scale | ||||
| // +genclient:method=UpdateScale,verb=update,subresource=scale,input=Scale,result=Scale | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of StatefulSet is deprecated by apps/v1/StatefulSet. See the release notes for | ||||
| // more information. | ||||
| // StatefulSet represents a set of pods with consistent identities. | ||||
| // Identities are defined as: | ||||
| //  - Network: A single stable DNS and hostname. | ||||
| //  - Storage: As many VolumeClaims as requested. | ||||
| // The StatefulSet guarantees that a given network identity will always | ||||
| // map to the same storage identity. | ||||
| type StatefulSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec defines the desired identities of pods in this set. | ||||
| 	// +optional | ||||
| 	Spec StatefulSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is the current status of Pods in this StatefulSet. This data | ||||
| 	// may be out of date by some window of time. | ||||
| 	// +optional | ||||
| 	Status StatefulSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // PodManagementPolicyType defines the policy for creating pods under a stateful set. | ||||
| type PodManagementPolicyType string | ||||
|  | ||||
| const ( | ||||
| 	// OrderedReadyPodManagement will create pods in strictly increasing order on | ||||
| 	// scale up and strictly decreasing order on scale down, progressing only when | ||||
| 	// the previous pod is ready or terminated. At most one pod will be changed | ||||
| 	// at any time. | ||||
| 	OrderedReadyPodManagement PodManagementPolicyType = "OrderedReady" | ||||
| 	// ParallelPodManagement will create and delete pods as soon as the stateful set | ||||
| 	// replica count is changed, and will not wait for pods to be ready or complete | ||||
| 	// termination. | ||||
| 	ParallelPodManagement PodManagementPolicyType = "Parallel" | ||||
| ) | ||||
|  | ||||
| // StatefulSetUpdateStrategy indicates the strategy that the StatefulSet | ||||
| // controller will use to perform updates. It includes any additional parameters | ||||
| // necessary to perform the update for the indicated strategy. | ||||
| type StatefulSetUpdateStrategy struct { | ||||
| 	// Type indicates the type of the StatefulSetUpdateStrategy. | ||||
| 	// Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type StatefulSetUpdateStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetStrategyType"` | ||||
| 	// RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType. | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateStatefulSetStrategy `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| // StatefulSetUpdateStrategyType is a string enumeration type that enumerates | ||||
| // all possible update strategies for the StatefulSet controller. | ||||
| type StatefulSetUpdateStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// RollingUpdateStatefulSetStrategyType indicates that update will be | ||||
| 	// applied to all Pods in the StatefulSet with respect to the StatefulSet | ||||
| 	// ordering constraints. When a scale operation is performed with this | ||||
| 	// strategy, new Pods will be created from the specification version indicated | ||||
| 	// by the StatefulSet's updateRevision. | ||||
| 	RollingUpdateStatefulSetStrategyType = "RollingUpdate" | ||||
| 	// OnDeleteStatefulSetStrategyType triggers the legacy behavior. Version | ||||
| 	// tracking and ordered rolling restarts are disabled. Pods are recreated | ||||
| 	// from the StatefulSetSpec when they are manually deleted. When a scale | ||||
| 	// operation is performed with this strategy,specification version indicated | ||||
| 	// by the StatefulSet's currentRevision. | ||||
| 	OnDeleteStatefulSetStrategyType = "OnDelete" | ||||
| ) | ||||
|  | ||||
| // RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType. | ||||
| type RollingUpdateStatefulSetStrategy struct { | ||||
| 	// Partition indicates the ordinal at which the StatefulSet should be | ||||
| 	// partitioned. | ||||
| 	// Default value is 0. | ||||
| 	// +optional | ||||
| 	Partition *int32 `json:"partition,omitempty" protobuf:"varint,1,opt,name=partition"` | ||||
| } | ||||
|  | ||||
| // A StatefulSetSpec is the specification of a StatefulSet. | ||||
| type StatefulSetSpec struct { | ||||
| 	// replicas is the desired number of replicas of the given Template. | ||||
| 	// These are replicas in the sense that they are instantiations of the | ||||
| 	// same Template, but individual replicas also have a consistent identity. | ||||
| 	// If unspecified, defaults to 1. | ||||
| 	// TODO: Consider a rename of this field. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// selector is a label query over pods that should match the replica count. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// template is the object that describes the pod that will be created if | ||||
| 	// insufficient replicas are detected. Each pod stamped out by the StatefulSet | ||||
| 	// will fulfill this Template, but have a unique identity from the rest | ||||
| 	// of the StatefulSet. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// volumeClaimTemplates is a list of claims that pods are allowed to reference. | ||||
| 	// The StatefulSet controller is responsible for mapping network identities to | ||||
| 	// claims in a way that maintains the identity of a pod. Every claim in | ||||
| 	// this list must have at least one matching (by name) volumeMount in one | ||||
| 	// container in the template. A claim in this list takes precedence over | ||||
| 	// any volumes in the template, with the same name. | ||||
| 	// TODO: Define the behavior if a claim already exists with the same name. | ||||
| 	// +optional | ||||
| 	VolumeClaimTemplates []v1.PersistentVolumeClaim `json:"volumeClaimTemplates,omitempty" protobuf:"bytes,4,rep,name=volumeClaimTemplates"` | ||||
|  | ||||
| 	// serviceName is the name of the service that governs this StatefulSet. | ||||
| 	// This service must exist before the StatefulSet, and is responsible for | ||||
| 	// the network identity of the set. Pods get DNS/hostnames that follow the | ||||
| 	// pattern: pod-specific-string.serviceName.default.svc.cluster.local | ||||
| 	// where "pod-specific-string" is managed by the StatefulSet controller. | ||||
| 	ServiceName string `json:"serviceName" protobuf:"bytes,5,opt,name=serviceName"` | ||||
|  | ||||
| 	// podManagementPolicy controls how pods are created during initial scale up, | ||||
| 	// when replacing pods on nodes, or when scaling down. The default policy is | ||||
| 	// `OrderedReady`, where pods are created in increasing order (pod-0, then | ||||
| 	// pod-1, etc) and the controller will wait until each pod is ready before | ||||
| 	// continuing. When scaling down, the pods are removed in the opposite order. | ||||
| 	// The alternative policy is `Parallel` which will create pods in parallel | ||||
| 	// to match the desired scale without waiting, and on scale down will delete | ||||
| 	// all pods at once. | ||||
| 	// +optional | ||||
| 	PodManagementPolicy PodManagementPolicyType `json:"podManagementPolicy,omitempty" protobuf:"bytes,6,opt,name=podManagementPolicy,casttype=PodManagementPolicyType"` | ||||
|  | ||||
| 	// updateStrategy indicates the StatefulSetUpdateStrategy that will be | ||||
| 	// employed to update Pods in the StatefulSet when a revision is made to | ||||
| 	// Template. | ||||
| 	UpdateStrategy StatefulSetUpdateStrategy `json:"updateStrategy,omitempty" protobuf:"bytes,7,opt,name=updateStrategy"` | ||||
|  | ||||
| 	// revisionHistoryLimit is the maximum number of revisions that will | ||||
| 	// be maintained in the StatefulSet's revision history. The revision history | ||||
| 	// consists of all revisions not represented by a currently applied | ||||
| 	// StatefulSetSpec version. The default value is 10. | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,8,opt,name=revisionHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // StatefulSetStatus represents the current state of a StatefulSet. | ||||
| type StatefulSetStatus struct { | ||||
| 	// observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the | ||||
| 	// StatefulSet's generation, which is updated on mutation by the API Server. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// replicas is the number of Pods created by the StatefulSet controller. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition. | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,3,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by currentRevision. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas,omitempty" protobuf:"varint,4,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version | ||||
| 	// indicated by updateRevision. | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,5,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the | ||||
| 	// sequence [0,currentReplicas). | ||||
| 	CurrentRevision string `json:"currentRevision,omitempty" protobuf:"bytes,6,opt,name=currentRevision"` | ||||
|  | ||||
| 	// updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence | ||||
| 	// [replicas-updatedReplicas,replicas) | ||||
| 	UpdateRevision string `json:"updateRevision,omitempty" protobuf:"bytes,7,opt,name=updateRevision"` | ||||
|  | ||||
| 	// collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller | ||||
| 	// uses this field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ControllerRevision. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,9,opt,name=collisionCount"` | ||||
|  | ||||
| 	// Represents the latest available observations of a statefulset's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []StatefulSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,10,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type StatefulSetConditionType string | ||||
|  | ||||
| // StatefulSetCondition describes the state of a statefulset at a certain point. | ||||
| type StatefulSetCondition struct { | ||||
| 	// Type of statefulset condition. | ||||
| 	Type StatefulSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=StatefulSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // StatefulSetList is a collection of StatefulSets. | ||||
| type StatefulSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
| 	Items           []StatefulSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of Deployment is deprecated by apps/v1/Deployment. See the release notes for | ||||
| // more information. | ||||
| // Deployment enables declarative updates for Pods and ReplicaSets. | ||||
| type Deployment struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of the Deployment. | ||||
| 	// +optional | ||||
| 	Spec DeploymentSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Most recently observed status of the Deployment. | ||||
| 	// +optional | ||||
| 	Status DeploymentStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // DeploymentSpec is the specification of the desired behavior of the Deployment. | ||||
| type DeploymentSpec struct { | ||||
| 	// Number of desired pods. This is a pointer to distinguish between explicit | ||||
| 	// zero and not specified. Defaults to 1. | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// Label selector for pods. Existing ReplicaSets whose pods are | ||||
| 	// selected by this will be the ones affected by this deployment. | ||||
| 	// It must match the pod template's labels. | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// Template describes the pods that will be created. | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,3,opt,name=template"` | ||||
|  | ||||
| 	// The deployment strategy to use to replace existing pods with new ones. | ||||
| 	// +optional | ||||
| 	// +patchStrategy=retainKeys | ||||
| 	Strategy DeploymentStrategy `json:"strategy,omitempty" patchStrategy:"retainKeys" protobuf:"bytes,4,opt,name=strategy"` | ||||
|  | ||||
| 	// Minimum number of seconds for which a newly created pod should be ready | ||||
| 	// without any of its container crashing, for it to be considered available. | ||||
| 	// Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,5,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// The number of old ReplicaSets to retain to allow rollback. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 10. | ||||
| 	// +optional | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` | ||||
|  | ||||
| 	// Indicates that the deployment is paused. | ||||
| 	// +optional | ||||
| 	Paused bool `json:"paused,omitempty" protobuf:"varint,7,opt,name=paused"` | ||||
|  | ||||
| 	// The maximum time in seconds for a deployment to make progress before it | ||||
| 	// is considered to be failed. The deployment controller will continue to | ||||
| 	// process failed deployments and a condition with a ProgressDeadlineExceeded | ||||
| 	// reason will be surfaced in the deployment status. Note that progress will | ||||
| 	// not be estimated during the time a deployment is paused. Defaults to 600s. | ||||
| 	ProgressDeadlineSeconds *int32 `json:"progressDeadlineSeconds,omitempty" protobuf:"varint,9,opt,name=progressDeadlineSeconds"` | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	// DefaultDeploymentUniqueLabelKey is the default key of the selector that is added | ||||
| 	// to existing ReplicaSets (and label key that is added to its pods) to prevent the existing ReplicaSets | ||||
| 	// to select new pods (and old pods being select by new ReplicaSet). | ||||
| 	DefaultDeploymentUniqueLabelKey string = "pod-template-hash" | ||||
| ) | ||||
|  | ||||
| // DeploymentStrategy describes how to replace existing pods with new ones. | ||||
| type DeploymentStrategy struct { | ||||
| 	// Type of deployment. Can be "Recreate" or "RollingUpdate". Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type DeploymentStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type,casttype=DeploymentStrategyType"` | ||||
|  | ||||
| 	// Rolling update config params. Present only if DeploymentStrategyType = | ||||
| 	// RollingUpdate. | ||||
| 	//--- | ||||
| 	// TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
| 	// to be. | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateDeployment `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| type DeploymentStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// Kill all existing pods before creating new ones. | ||||
| 	RecreateDeploymentStrategyType DeploymentStrategyType = "Recreate" | ||||
|  | ||||
| 	// Replace the old ReplicaSets by new one using rolling update i.e gradually scale down the old ReplicaSets and scale up the new one. | ||||
| 	RollingUpdateDeploymentStrategyType DeploymentStrategyType = "RollingUpdate" | ||||
| ) | ||||
|  | ||||
| // Spec to control the desired behavior of rolling update. | ||||
| type RollingUpdateDeployment struct { | ||||
| 	// The maximum number of pods that can be unavailable during the update. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// Absolute number is calculated from percentage by rounding down. | ||||
| 	// This can not be 0 if MaxSurge is 0. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods | ||||
| 	// immediately when the rolling update starts. Once new pods are ready, old ReplicaSet | ||||
| 	// can be scaled down further, followed by scaling up the new ReplicaSet, ensuring | ||||
| 	// that the total number of pods available at all times during the update is at | ||||
| 	// least 70% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` | ||||
|  | ||||
| 	// The maximum number of pods that can be scheduled above the desired number of | ||||
| 	// pods. | ||||
| 	// Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). | ||||
| 	// This can not be 0 if MaxUnavailable is 0. | ||||
| 	// Absolute number is calculated from percentage by rounding up. | ||||
| 	// Defaults to 25%. | ||||
| 	// Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when | ||||
| 	// the rolling update starts, such that the total number of old and new pods do not exceed | ||||
| 	// 130% of desired pods. Once old pods have been killed, | ||||
| 	// new ReplicaSet can be scaled up further, ensuring that total number of pods running | ||||
| 	// at any time during the update is at most 130% of desired pods. | ||||
| 	// +optional | ||||
| 	MaxSurge *intstr.IntOrString `json:"maxSurge,omitempty" protobuf:"bytes,2,opt,name=maxSurge"` | ||||
| } | ||||
|  | ||||
| // DeploymentStatus is the most recently observed status of the Deployment. | ||||
| type DeploymentStatus struct { | ||||
| 	// The generation observed by the deployment controller. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment (their labels match the selector). | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,2,opt,name=replicas"` | ||||
|  | ||||
| 	// Total number of non-terminated pods targeted by this deployment that have the desired template spec. | ||||
| 	// +optional | ||||
| 	UpdatedReplicas int32 `json:"updatedReplicas,omitempty" protobuf:"varint,3,opt,name=updatedReplicas"` | ||||
|  | ||||
| 	// Total number of ready pods targeted by this deployment. | ||||
| 	// +optional | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,7,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// Total number of available pods (ready for at least minReadySeconds) targeted by this deployment. | ||||
| 	// +optional | ||||
| 	AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,4,opt,name=availableReplicas"` | ||||
|  | ||||
| 	// Total number of unavailable pods targeted by this deployment. This is the total number of | ||||
| 	// pods that are still required for the deployment to have 100% available capacity. They may | ||||
| 	// either be pods that are running but not yet available or pods that still have not been created. | ||||
| 	// +optional | ||||
| 	UnavailableReplicas int32 `json:"unavailableReplicas,omitempty" protobuf:"varint,5,opt,name=unavailableReplicas"` | ||||
|  | ||||
| 	// Represents the latest available observations of a deployment's current state. | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []DeploymentCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,6,rep,name=conditions"` | ||||
|  | ||||
| 	// Count of hash collisions for the Deployment. The Deployment controller uses this | ||||
| 	// field as a collision avoidance mechanism when it needs to create the name for the | ||||
| 	// newest ReplicaSet. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,8,opt,name=collisionCount"` | ||||
| } | ||||
|  | ||||
| type DeploymentConditionType string | ||||
|  | ||||
| // These are valid conditions of a deployment. | ||||
| const ( | ||||
| 	// Available means the deployment is available, ie. at least the minimum available | ||||
| 	// replicas required are up and running for at least minReadySeconds. | ||||
| 	DeploymentAvailable DeploymentConditionType = "Available" | ||||
| 	// Progressing means the deployment is progressing. Progress for a deployment is | ||||
| 	// considered when a new replica set is created or adopted, and when new pods scale | ||||
| 	// up or old pods scale down. Progress is not estimated for paused deployments or | ||||
| 	// when progressDeadlineSeconds is not specified. | ||||
| 	DeploymentProgressing DeploymentConditionType = "Progressing" | ||||
| 	// ReplicaFailure is added in a deployment when one of its pods fails to be created | ||||
| 	// or deleted. | ||||
| 	DeploymentReplicaFailure DeploymentConditionType = "ReplicaFailure" | ||||
| ) | ||||
|  | ||||
| // DeploymentCondition describes the state of a deployment at a certain point. | ||||
| type DeploymentCondition struct { | ||||
| 	// Type of deployment condition. | ||||
| 	Type DeploymentConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DeploymentConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// The last time this condition was updated. | ||||
| 	LastUpdateTime metav1.Time `json:"lastUpdateTime,omitempty" protobuf:"bytes,6,opt,name=lastUpdateTime"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,7,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DeploymentList is a list of Deployments. | ||||
| type DeploymentList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is the list of Deployments. | ||||
| 	Items []Deployment `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet. | ||||
| type DaemonSetUpdateStrategy struct { | ||||
| 	// Type of daemon set update. Can be "RollingUpdate" or "OnDelete". Default is RollingUpdate. | ||||
| 	// +optional | ||||
| 	Type DaemonSetUpdateStrategyType `json:"type,omitempty" protobuf:"bytes,1,opt,name=type"` | ||||
|  | ||||
| 	// Rolling update config params. Present only if type = "RollingUpdate". | ||||
| 	//--- | ||||
| 	// TODO: Update this to follow our convention for oneOf, whatever we decide it | ||||
| 	// to be. Same as Deployment `strategy.rollingUpdate`. | ||||
| 	// See https://github.com/kubernetes/kubernetes/issues/35345 | ||||
| 	// +optional | ||||
| 	RollingUpdate *RollingUpdateDaemonSet `json:"rollingUpdate,omitempty" protobuf:"bytes,2,opt,name=rollingUpdate"` | ||||
| } | ||||
|  | ||||
| type DaemonSetUpdateStrategyType string | ||||
|  | ||||
| const ( | ||||
| 	// Replace the old daemons by new ones using rolling update i.e replace them on each node one after the other. | ||||
| 	RollingUpdateDaemonSetStrategyType DaemonSetUpdateStrategyType = "RollingUpdate" | ||||
|  | ||||
| 	// Replace the old daemons only when it's killed | ||||
| 	OnDeleteDaemonSetStrategyType DaemonSetUpdateStrategyType = "OnDelete" | ||||
| ) | ||||
|  | ||||
| // Spec to control the desired behavior of daemon set rolling update. | ||||
| type RollingUpdateDaemonSet struct { | ||||
| 	// The maximum number of DaemonSet pods that can be unavailable during the | ||||
| 	// update. Value can be an absolute number (ex: 5) or a percentage of total | ||||
| 	// number of DaemonSet pods at the start of the update (ex: 10%). Absolute | ||||
| 	// number is calculated from percentage by rounding up. | ||||
| 	// This cannot be 0. | ||||
| 	// Default value is 1. | ||||
| 	// Example: when this is set to 30%, at most 30% of the total number of nodes | ||||
| 	// that should be running the daemon pod (i.e. status.desiredNumberScheduled) | ||||
| 	// can have their pods stopped for an update at any given | ||||
| 	// time. The update starts by stopping at most 30% of those DaemonSet pods | ||||
| 	// and then brings up new DaemonSet pods in their place. Once the new pods | ||||
| 	// are available, it then proceeds onto other DaemonSet pods, thus ensuring | ||||
| 	// that at least 70% of original number of DaemonSet pods are available at | ||||
| 	// all times during the update. | ||||
| 	// +optional | ||||
| 	MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty" protobuf:"bytes,1,opt,name=maxUnavailable"` | ||||
| } | ||||
|  | ||||
| // DaemonSetSpec is the specification of a daemon set. | ||||
| type DaemonSetSpec struct { | ||||
| 	// A label query over pods that are managed by the daemon set. | ||||
| 	// Must match in order to be controlled. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,1,opt,name=selector"` | ||||
|  | ||||
| 	// An object that describes the pod that will be created. | ||||
| 	// The DaemonSet will create exactly one copy of this pod on every node | ||||
| 	// that matches the template's node selector (or on every node if no node | ||||
| 	// selector is specified). | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,2,opt,name=template"` | ||||
|  | ||||
| 	// An update strategy to replace existing DaemonSet pods with new pods. | ||||
| 	// +optional | ||||
| 	UpdateStrategy DaemonSetUpdateStrategy `json:"updateStrategy,omitempty" protobuf:"bytes,3,opt,name=updateStrategy"` | ||||
|  | ||||
| 	// The minimum number of seconds for which a newly created DaemonSet pod should | ||||
| 	// be ready without any of its container crashing, for it to be considered | ||||
| 	// available. Defaults to 0 (pod will be considered available as soon as it | ||||
| 	// is ready). | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// The number of old history to retain to allow rollback. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 10. | ||||
| 	// +optional | ||||
| 	RevisionHistoryLimit *int32 `json:"revisionHistoryLimit,omitempty" protobuf:"varint,6,opt,name=revisionHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // DaemonSetStatus represents the current status of a daemon set. | ||||
| type DaemonSetStatus struct { | ||||
| 	// The number of nodes that are running at least 1 | ||||
| 	// daemon pod and are supposed to run the daemon pod. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	CurrentNumberScheduled int32 `json:"currentNumberScheduled" protobuf:"varint,1,opt,name=currentNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that are running the daemon pod, but are | ||||
| 	// not supposed to run the daemon pod. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	NumberMisscheduled int32 `json:"numberMisscheduled" protobuf:"varint,2,opt,name=numberMisscheduled"` | ||||
|  | ||||
| 	// The total number of nodes that should be running the daemon | ||||
| 	// pod (including nodes correctly running the daemon pod). | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/ | ||||
| 	DesiredNumberScheduled int32 `json:"desiredNumberScheduled" protobuf:"varint,3,opt,name=desiredNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that should be running the daemon pod and have one | ||||
| 	// or more of the daemon pod running and ready. | ||||
| 	NumberReady int32 `json:"numberReady" protobuf:"varint,4,opt,name=numberReady"` | ||||
|  | ||||
| 	// The most recent generation observed by the daemon set controller. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,5,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// The total number of nodes that are running updated daemon pod | ||||
| 	// +optional | ||||
| 	UpdatedNumberScheduled int32 `json:"updatedNumberScheduled,omitempty" protobuf:"varint,6,opt,name=updatedNumberScheduled"` | ||||
|  | ||||
| 	// The number of nodes that should be running the | ||||
| 	// daemon pod and have one or more of the daemon pod running and | ||||
| 	// available (ready for at least spec.minReadySeconds) | ||||
| 	// +optional | ||||
| 	NumberAvailable int32 `json:"numberAvailable,omitempty" protobuf:"varint,7,opt,name=numberAvailable"` | ||||
|  | ||||
| 	// The number of nodes that should be running the | ||||
| 	// daemon pod and have none of the daemon pod running and available | ||||
| 	// (ready for at least spec.minReadySeconds) | ||||
| 	// +optional | ||||
| 	NumberUnavailable int32 `json:"numberUnavailable,omitempty" protobuf:"varint,8,opt,name=numberUnavailable"` | ||||
|  | ||||
| 	// Count of hash collisions for the DaemonSet. The DaemonSet controller | ||||
| 	// uses this field as a collision avoidance mechanism when it needs to | ||||
| 	// create the name for the newest ControllerRevision. | ||||
| 	// +optional | ||||
| 	CollisionCount *int32 `json:"collisionCount,omitempty" protobuf:"varint,9,opt,name=collisionCount"` | ||||
|  | ||||
| 	// Represents the latest available observations of a DaemonSet's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []DaemonSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,10,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type DaemonSetConditionType string | ||||
|  | ||||
| // TODO: Add valid condition types of a DaemonSet. | ||||
|  | ||||
| // DaemonSetCondition describes the state of a DaemonSet at a certain point. | ||||
| type DaemonSetCondition struct { | ||||
| 	// Type of DaemonSet condition. | ||||
| 	Type DaemonSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=DaemonSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of DaemonSet is deprecated by apps/v1/DaemonSet. See the release notes for | ||||
| // more information. | ||||
| // DaemonSet represents the configuration of a daemon set. | ||||
| type DaemonSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// 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"` | ||||
|  | ||||
| 	// The desired behavior of this daemon set. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec DaemonSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// The current status of this daemon set. 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 | ||||
| 	// +optional | ||||
| 	Status DaemonSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| const ( | ||||
| 	// DefaultDaemonSetUniqueLabelKey is the default label key that is added | ||||
| 	// to existing DaemonSet pods to distinguish between old and new | ||||
| 	// DaemonSet pods during DaemonSet template updates. | ||||
| 	DefaultDaemonSetUniqueLabelKey = ControllerRevisionHashLabelKey | ||||
| ) | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DaemonSetList is a collection of daemon sets. | ||||
| type DaemonSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list 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"` | ||||
|  | ||||
| 	// A list of daemon sets. | ||||
| 	Items []DaemonSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of ReplicaSet is deprecated by apps/v1/ReplicaSet. See the release notes for | ||||
| // more information. | ||||
| // ReplicaSet ensures that a specified number of pod replicas are running at any given time. | ||||
| type ReplicaSet struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// If the Labels of a ReplicaSet are empty, they are defaulted to | ||||
| 	// be the same as the Pod(s) that the ReplicaSet manages. | ||||
| 	// 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 ReplicaSet. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec ReplicaSetSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is the most recently observed status of the ReplicaSet. | ||||
| 	// 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 | ||||
| 	// +optional | ||||
| 	Status ReplicaSetStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ReplicaSetList is a collection of ReplicaSets. | ||||
| type ReplicaSetList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// 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 ReplicaSets. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller | ||||
| 	Items []ReplicaSet `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // ReplicaSetSpec is the specification of a ReplicaSet. | ||||
| type ReplicaSetSpec struct { | ||||
| 	// Replicas is the number of desired replicas. | ||||
| 	// This is a pointer to distinguish between explicit zero and unspecified. | ||||
| 	// Defaults to 1. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
| 	// +optional | ||||
| 	Replicas *int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// Minimum number of seconds for which a newly created pod should be ready | ||||
| 	// without any of its container crashing, for it to be considered available. | ||||
| 	// Defaults to 0 (pod will be considered available as soon as it is ready) | ||||
| 	// +optional | ||||
| 	MinReadySeconds int32 `json:"minReadySeconds,omitempty" protobuf:"varint,4,opt,name=minReadySeconds"` | ||||
|  | ||||
| 	// Selector is a label query over pods that should match the replica count. | ||||
| 	// Label keys and values that must match in order to be controlled by this replica set. | ||||
| 	// It must match the pod template's labels. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	Selector *metav1.LabelSelector `json:"selector" protobuf:"bytes,2,opt,name=selector"` | ||||
|  | ||||
| 	// Template is the object that describes the pod that will be created if | ||||
| 	// insufficient replicas are detected. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template | ||||
| 	// +optional | ||||
| 	Template v1.PodTemplateSpec `json:"template,omitempty" protobuf:"bytes,3,opt,name=template"` | ||||
| } | ||||
|  | ||||
| // ReplicaSetStatus represents the current status of a ReplicaSet. | ||||
| type ReplicaSetStatus struct { | ||||
| 	// Replicas is the most recently oberved number of replicas. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// The number of pods that have labels matching the labels of the pod template of the replicaset. | ||||
| 	// +optional | ||||
| 	FullyLabeledReplicas int32 `json:"fullyLabeledReplicas,omitempty" protobuf:"varint,2,opt,name=fullyLabeledReplicas"` | ||||
|  | ||||
| 	// The number of ready replicas for this replica set. | ||||
| 	// +optional | ||||
| 	ReadyReplicas int32 `json:"readyReplicas,omitempty" protobuf:"varint,4,opt,name=readyReplicas"` | ||||
|  | ||||
| 	// The number of available replicas (ready for at least minReadySeconds) for this replica set. | ||||
| 	// +optional | ||||
| 	AvailableReplicas int32 `json:"availableReplicas,omitempty" protobuf:"varint,5,opt,name=availableReplicas"` | ||||
|  | ||||
| 	// ObservedGeneration reflects the generation of the most recently observed ReplicaSet. | ||||
| 	// +optional | ||||
| 	ObservedGeneration int64 `json:"observedGeneration,omitempty" protobuf:"varint,3,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// Represents the latest available observations of a replica set's current state. | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []ReplicaSetCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,6,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| type ReplicaSetConditionType string | ||||
|  | ||||
| // These are valid conditions of a replica set. | ||||
| const ( | ||||
| 	// ReplicaSetReplicaFailure is added in a replica set when one of its pods fails to be created | ||||
| 	// due to insufficient quota, limit ranges, pod security policy, node selectors, etc. or deleted | ||||
| 	// due to kubelet being down or finalizers are failing. | ||||
| 	ReplicaSetReplicaFailure ReplicaSetConditionType = "ReplicaFailure" | ||||
| ) | ||||
|  | ||||
| // ReplicaSetCondition describes the state of a replica set at a certain point. | ||||
| type ReplicaSetCondition struct { | ||||
| 	// Type of replica set condition. | ||||
| 	Type ReplicaSetConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=ReplicaSetConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// The last time the condition transitioned from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// The reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// A human readable message indicating details about the transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1/ControllerRevision. See the | ||||
| // release notes for more information. | ||||
| // ControllerRevision implements an immutable snapshot of state data. Clients | ||||
| // are responsible for serializing and deserializing the objects that contain | ||||
| // their internal state. | ||||
| // Once a ControllerRevision has been successfully created, it can not be updated. | ||||
| // The API Server will fail validation of all requests that attempt to mutate | ||||
| // the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both | ||||
| // the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, | ||||
| // it may be subject to name and representation changes in future releases, and clients should not | ||||
| // depend on its stability. It is primarily for internal use by controllers. | ||||
| type ControllerRevision struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// 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"` | ||||
|  | ||||
| 	// Data is the serialized representation of the state. | ||||
| 	Data runtime.RawExtension `json:"data,omitempty" protobuf:"bytes,2,opt,name=data"` | ||||
|  | ||||
| 	// Revision indicates the revision of the state represented by Data. | ||||
| 	Revision int64 `json:"revision" protobuf:"varint,3,opt,name=revision"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ControllerRevisionList is a resource containing a list of ControllerRevision objects. | ||||
| type ControllerRevisionList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// 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"` | ||||
|  | ||||
| 	// Items is the list of ControllerRevisions | ||||
| 	Items []ControllerRevision `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										396
									
								
								vendor/k8s.io/api/apps/v1beta2/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										396
									
								
								vendor/k8s.io/api/apps/v1beta2/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,396 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta2 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_ControllerRevision = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of ControllerRevision is deprecated by apps/v1/ControllerRevision. See the release notes for more information. ControllerRevision implements an immutable snapshot of state data. Clients are responsible for serializing and deserializing the objects that contain their internal state. Once a ControllerRevision has been successfully created, it can not be updated. The API Server will fail validation of all requests that attempt to mutate the Data field. ControllerRevisions may, however, be deleted. Note that, due to its use by both the DaemonSet and StatefulSet controllers for update and rollback, this object is beta. However, it may be subject to name and representation changes in future releases, and clients should not depend on its stability. It is primarily for internal use by controllers.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"data":     "Data is the serialized representation of the state.", | ||||
| 	"revision": "Revision indicates the revision of the state represented by Data.", | ||||
| } | ||||
|  | ||||
| func (ControllerRevision) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevision | ||||
| } | ||||
|  | ||||
| var map_ControllerRevisionList = map[string]string{ | ||||
| 	"":         "ControllerRevisionList is a resource containing a list of ControllerRevision objects.", | ||||
| 	"metadata": "More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"items":    "Items is the list of ControllerRevisions", | ||||
| } | ||||
|  | ||||
| func (ControllerRevisionList) SwaggerDoc() map[string]string { | ||||
| 	return map_ControllerRevisionList | ||||
| } | ||||
|  | ||||
| var map_DaemonSet = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of DaemonSet is deprecated by apps/v1/DaemonSet. See the release notes for more information. DaemonSet represents the configuration of a daemon set.", | ||||
| 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"spec":     "The desired behavior of this daemon set. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status", | ||||
| 	"status":   "The current status of this daemon set. 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 (DaemonSet) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSet | ||||
| } | ||||
|  | ||||
| var map_DaemonSetCondition = map[string]string{ | ||||
| 	"":                   "DaemonSetCondition describes the state of a DaemonSet at a certain point.", | ||||
| 	"type":               "Type of DaemonSet condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetCondition | ||||
| } | ||||
|  | ||||
| var map_DaemonSetList = map[string]string{ | ||||
| 	"":         "DaemonSetList is a collection of daemon sets.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata", | ||||
| 	"items":    "A list of daemon sets.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetList | ||||
| } | ||||
|  | ||||
| var map_DaemonSetSpec = map[string]string{ | ||||
| 	"":                     "DaemonSetSpec is the specification of a daemon set.", | ||||
| 	"selector":             "A label query over pods that are managed by the daemon set. Must match in order to be controlled. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":             "An object that describes the pod that will be created. The DaemonSet will create exactly one copy of this pod on every node that matches the template's node selector (or on every node if no node selector is specified). More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template", | ||||
| 	"updateStrategy":       "An update strategy to replace existing DaemonSet pods with new pods.", | ||||
| 	"minReadySeconds":      "The minimum number of seconds for which a newly created DaemonSet pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready).", | ||||
| 	"revisionHistoryLimit": "The number of old history to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetSpec | ||||
| } | ||||
|  | ||||
| var map_DaemonSetStatus = map[string]string{ | ||||
| 	"":                       "DaemonSetStatus represents the current status of a daemon set.", | ||||
| 	"currentNumberScheduled": "The number of nodes that are running at least 1 daemon pod and are supposed to run the daemon pod. More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"numberMisscheduled":     "The number of nodes that are running the daemon pod, but are not supposed to run the daemon pod. More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"desiredNumberScheduled": "The total number of nodes that should be running the daemon pod (including nodes correctly running the daemon pod). More info: https://kubernetes.io/docs/concepts/workloads/controllers/daemonset/", | ||||
| 	"numberReady":            "The number of nodes that should be running the daemon pod and have one or more of the daemon pod running and ready.", | ||||
| 	"observedGeneration":     "The most recent generation observed by the daemon set controller.", | ||||
| 	"updatedNumberScheduled": "The total number of nodes that are running updated daemon pod", | ||||
| 	"numberAvailable":        "The number of nodes that should be running the daemon pod and have one or more of the daemon pod running and available (ready for at least spec.minReadySeconds)", | ||||
| 	"numberUnavailable":      "The number of nodes that should be running the daemon pod and have none of the daemon pod running and available (ready for at least spec.minReadySeconds)", | ||||
| 	"collisionCount":         "Count of hash collisions for the DaemonSet. The DaemonSet controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ControllerRevision.", | ||||
| 	"conditions":             "Represents the latest available observations of a DaemonSet's current state.", | ||||
| } | ||||
|  | ||||
| func (DaemonSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetStatus | ||||
| } | ||||
|  | ||||
| var map_DaemonSetUpdateStrategy = map[string]string{ | ||||
| 	"":              "DaemonSetUpdateStrategy is a struct used to control the update strategy for a DaemonSet.", | ||||
| 	"type":          "Type of daemon set update. Can be \"RollingUpdate\" or \"OnDelete\". Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "Rolling update config params. Present only if type = \"RollingUpdate\".", | ||||
| } | ||||
|  | ||||
| func (DaemonSetUpdateStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_DaemonSetUpdateStrategy | ||||
| } | ||||
|  | ||||
| var map_Deployment = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of Deployment is deprecated by apps/v1/Deployment. See the release notes for more information. Deployment enables declarative updates for Pods and ReplicaSets.", | ||||
| 	"metadata": "Standard object metadata.", | ||||
| 	"spec":     "Specification of the desired behavior of the Deployment.", | ||||
| 	"status":   "Most recently observed status of the Deployment.", | ||||
| } | ||||
|  | ||||
| func (Deployment) SwaggerDoc() map[string]string { | ||||
| 	return map_Deployment | ||||
| } | ||||
|  | ||||
| var map_DeploymentCondition = map[string]string{ | ||||
| 	"":                   "DeploymentCondition describes the state of a deployment at a certain point.", | ||||
| 	"type":               "Type of deployment condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastUpdateTime":     "The last time this condition was updated.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (DeploymentCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentCondition | ||||
| } | ||||
|  | ||||
| var map_DeploymentList = map[string]string{ | ||||
| 	"":         "DeploymentList is a list of Deployments.", | ||||
| 	"metadata": "Standard list metadata.", | ||||
| 	"items":    "Items is the list of Deployments.", | ||||
| } | ||||
|  | ||||
| func (DeploymentList) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentList | ||||
| } | ||||
|  | ||||
| var map_DeploymentSpec = map[string]string{ | ||||
| 	"":                        "DeploymentSpec is the specification of the desired behavior of the Deployment.", | ||||
| 	"replicas":                "Number of desired pods. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", | ||||
| 	"selector":                "Label selector for pods. Existing ReplicaSets whose pods are selected by this will be the ones affected by this deployment. It must match the pod template's labels.", | ||||
| 	"template":                "Template describes the pods that will be created.", | ||||
| 	"strategy":                "The deployment strategy to use to replace existing pods with new ones.", | ||||
| 	"minReadySeconds":         "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", | ||||
| 	"revisionHistoryLimit":    "The number of old ReplicaSets to retain to allow rollback. This is a pointer to distinguish between explicit zero and not specified. Defaults to 10.", | ||||
| 	"paused":                  "Indicates that the deployment is paused.", | ||||
| 	"progressDeadlineSeconds": "The maximum time in seconds for a deployment to make progress before it is considered to be failed. The deployment controller will continue to process failed deployments and a condition with a ProgressDeadlineExceeded reason will be surfaced in the deployment status. Note that progress will not be estimated during the time a deployment is paused. Defaults to 600s.", | ||||
| } | ||||
|  | ||||
| func (DeploymentSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentSpec | ||||
| } | ||||
|  | ||||
| var map_DeploymentStatus = map[string]string{ | ||||
| 	"":                    "DeploymentStatus is the most recently observed status of the Deployment.", | ||||
| 	"observedGeneration":  "The generation observed by the deployment controller.", | ||||
| 	"replicas":            "Total number of non-terminated pods targeted by this deployment (their labels match the selector).", | ||||
| 	"updatedReplicas":     "Total number of non-terminated pods targeted by this deployment that have the desired template spec.", | ||||
| 	"readyReplicas":       "Total number of ready pods targeted by this deployment.", | ||||
| 	"availableReplicas":   "Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.", | ||||
| 	"unavailableReplicas": "Total number of unavailable pods targeted by this deployment. This is the total number of pods that are still required for the deployment to have 100% available capacity. They may either be pods that are running but not yet available or pods that still have not been created.", | ||||
| 	"conditions":          "Represents the latest available observations of a deployment's current state.", | ||||
| 	"collisionCount":      "Count of hash collisions for the Deployment. The Deployment controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ReplicaSet.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStatus | ||||
| } | ||||
|  | ||||
| var map_DeploymentStrategy = map[string]string{ | ||||
| 	"":              "DeploymentStrategy describes how to replace existing pods with new ones.", | ||||
| 	"type":          "Type of deployment. Can be \"Recreate\" or \"RollingUpdate\". Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "Rolling update config params. Present only if DeploymentStrategyType = RollingUpdate.", | ||||
| } | ||||
|  | ||||
| func (DeploymentStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_DeploymentStrategy | ||||
| } | ||||
|  | ||||
| var map_ReplicaSet = map[string]string{ | ||||
| 	"":         "DEPRECATED - This group version of ReplicaSet is deprecated by apps/v1/ReplicaSet. See the release notes for more information. ReplicaSet ensures that a specified number of pod replicas are running at any given time.", | ||||
| 	"metadata": "If the Labels of a ReplicaSet are empty, they are defaulted to be the same as the Pod(s) that the ReplicaSet 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 ReplicaSet. 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 ReplicaSet. 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 (ReplicaSet) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSet | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetCondition = map[string]string{ | ||||
| 	"":                   "ReplicaSetCondition describes the state of a replica set at a certain point.", | ||||
| 	"type":               "Type of replica set condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "The last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetCondition | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetList = map[string]string{ | ||||
| 	"":         "ReplicaSetList is a collection of ReplicaSets.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", | ||||
| 	"items":    "List of ReplicaSets. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetList | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetSpec = map[string]string{ | ||||
| 	"":                "ReplicaSetSpec is the specification of a ReplicaSet.", | ||||
| 	"replicas":        "Replicas is the number of desired replicas. This is a pointer to distinguish between explicit zero and unspecified. Defaults to 1. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller", | ||||
| 	"minReadySeconds": "Minimum number of seconds for which a newly created pod should be ready without any of its container crashing, for it to be considered available. Defaults to 0 (pod will be considered available as soon as it is ready)", | ||||
| 	"selector":        "Selector is a label query over pods that should match the replica count. Label keys and values that must match in order to be controlled by this replica set. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":        "Template is the object that describes the pod that will be created if insufficient replicas are detected. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller#pod-template", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetSpec | ||||
| } | ||||
|  | ||||
| var map_ReplicaSetStatus = map[string]string{ | ||||
| 	"":                     "ReplicaSetStatus represents the current status of a ReplicaSet.", | ||||
| 	"replicas":             "Replicas is the most recently oberved number of replicas. More info: https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/#what-is-a-replicationcontroller", | ||||
| 	"fullyLabeledReplicas": "The number of pods that have labels matching the labels of the pod template of the replicaset.", | ||||
| 	"readyReplicas":        "The number of ready replicas for this replica set.", | ||||
| 	"availableReplicas":    "The number of available replicas (ready for at least minReadySeconds) for this replica set.", | ||||
| 	"observedGeneration":   "ObservedGeneration reflects the generation of the most recently observed ReplicaSet.", | ||||
| 	"conditions":           "Represents the latest available observations of a replica set's current state.", | ||||
| } | ||||
|  | ||||
| func (ReplicaSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ReplicaSetStatus | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateDaemonSet = map[string]string{ | ||||
| 	"":               "Spec to control the desired behavior of daemon set rolling update.", | ||||
| 	"maxUnavailable": "The maximum number of DaemonSet pods that can be unavailable during the update. Value can be an absolute number (ex: 5) or a percentage of total number of DaemonSet pods at the start of the update (ex: 10%). Absolute number is calculated from percentage by rounding up. This cannot be 0. Default value is 1. Example: when this is set to 30%, at most 30% of the total number of nodes that should be running the daemon pod (i.e. status.desiredNumberScheduled) can have their pods stopped for an update at any given time. The update starts by stopping at most 30% of those DaemonSet pods and then brings up new DaemonSet pods in their place. Once the new pods are available, it then proceeds onto other DaemonSet pods, thus ensuring that at least 70% of original number of DaemonSet pods are available at all times during the update.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateDaemonSet) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateDaemonSet | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateDeployment = map[string]string{ | ||||
| 	"":               "Spec to control the desired behavior of rolling update.", | ||||
| 	"maxUnavailable": "The maximum number of pods that can be unavailable during the update. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). Absolute number is calculated from percentage by rounding down. This can not be 0 if MaxSurge is 0. Defaults to 25%. Example: when this is set to 30%, the old ReplicaSet can be scaled down to 70% of desired pods immediately when the rolling update starts. Once new pods are ready, old ReplicaSet can be scaled down further, followed by scaling up the new ReplicaSet, ensuring that the total number of pods available at all times during the update is at least 70% of desired pods.", | ||||
| 	"maxSurge":       "The maximum number of pods that can be scheduled above the desired number of pods. Value can be an absolute number (ex: 5) or a percentage of desired pods (ex: 10%). This can not be 0 if MaxUnavailable is 0. Absolute number is calculated from percentage by rounding up. Defaults to 25%. Example: when this is set to 30%, the new ReplicaSet can be scaled up immediately when the rolling update starts, such that the total number of old and new pods do not exceed 130% of desired pods. Once old pods have been killed, new ReplicaSet can be scaled up further, ensuring that total number of pods running at any time during the update is at most 130% of desired pods.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateDeployment) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateDeployment | ||||
| } | ||||
|  | ||||
| var map_RollingUpdateStatefulSetStrategy = map[string]string{ | ||||
| 	"":          "RollingUpdateStatefulSetStrategy is used to communicate parameter for RollingUpdateStatefulSetStrategyType.", | ||||
| 	"partition": "Partition indicates the ordinal at which the StatefulSet should be partitioned. Default value is 0.", | ||||
| } | ||||
|  | ||||
| func (RollingUpdateStatefulSetStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_RollingUpdateStatefulSetStrategy | ||||
| } | ||||
|  | ||||
| var map_Scale = map[string]string{ | ||||
| 	"":         "Scale represents a scaling request for a resource.", | ||||
| 	"metadata": "Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata.", | ||||
| 	"spec":     "defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "current status of the scale. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status. Read-only.", | ||||
| } | ||||
|  | ||||
| func (Scale) SwaggerDoc() map[string]string { | ||||
| 	return map_Scale | ||||
| } | ||||
|  | ||||
| var map_ScaleSpec = map[string]string{ | ||||
| 	"":         "ScaleSpec describes the attributes of a scale subresource", | ||||
| 	"replicas": "desired number of instances for the scaled object.", | ||||
| } | ||||
|  | ||||
| func (ScaleSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleSpec | ||||
| } | ||||
|  | ||||
| var map_ScaleStatus = map[string]string{ | ||||
| 	"":               "ScaleStatus represents the current status of a scale subresource.", | ||||
| 	"replicas":       "actual number of observed instances of the scaled object.", | ||||
| 	"selector":       "label query over pods that should match the replicas count. More info: http://kubernetes.io/docs/user-guide/labels#label-selectors", | ||||
| 	"targetSelector": "label selector for pods that should match the replicas count. This is a serializated version of both map-based and more expressive set-based selectors. This is done to avoid introspection in the clients. The string will be in the same format as the query-param syntax. If the target type only supports map-based selectors, both this field and map-based selector field are populated. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| } | ||||
|  | ||||
| func (ScaleStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleStatus | ||||
| } | ||||
|  | ||||
| var map_StatefulSet = map[string]string{ | ||||
| 	"":       "DEPRECATED - This group version of StatefulSet is deprecated by apps/v1/StatefulSet. See the release notes for more information. StatefulSet represents a set of pods with consistent identities. Identities are defined as:\n - Network: A single stable DNS and hostname.\n - Storage: As many VolumeClaims as requested.\nThe StatefulSet guarantees that a given network identity will always map to the same storage identity.", | ||||
| 	"spec":   "Spec defines the desired identities of pods in this set.", | ||||
| 	"status": "Status is the current status of Pods in this StatefulSet. This data may be out of date by some window of time.", | ||||
| } | ||||
|  | ||||
| func (StatefulSet) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSet | ||||
| } | ||||
|  | ||||
| var map_StatefulSetCondition = map[string]string{ | ||||
| 	"":                   "StatefulSetCondition describes the state of a statefulset at a certain point.", | ||||
| 	"type":               "Type of statefulset condition.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastTransitionTime": "Last time the condition transitioned from one status to another.", | ||||
| 	"reason":             "The reason for the condition's last transition.", | ||||
| 	"message":            "A human readable message indicating details about the transition.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetCondition | ||||
| } | ||||
|  | ||||
| var map_StatefulSetList = map[string]string{ | ||||
| 	"": "StatefulSetList is a collection of StatefulSets.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetList) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetList | ||||
| } | ||||
|  | ||||
| var map_StatefulSetSpec = map[string]string{ | ||||
| 	"":                     "A StatefulSetSpec is the specification of a StatefulSet.", | ||||
| 	"replicas":             "replicas is the desired number of replicas of the given Template. These are replicas in the sense that they are instantiations of the same Template, but individual replicas also have a consistent identity. If unspecified, defaults to 1.", | ||||
| 	"selector":             "selector is a label query over pods that should match the replica count. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"template":             "template is the object that describes the pod that will be created if insufficient replicas are detected. Each pod stamped out by the StatefulSet will fulfill this Template, but have a unique identity from the rest of the StatefulSet.", | ||||
| 	"volumeClaimTemplates": "volumeClaimTemplates is a list of claims that pods are allowed to reference. The StatefulSet controller is responsible for mapping network identities to claims in a way that maintains the identity of a pod. Every claim in this list must have at least one matching (by name) volumeMount in one container in the template. A claim in this list takes precedence over any volumes in the template, with the same name.", | ||||
| 	"serviceName":          "serviceName is the name of the service that governs this StatefulSet. This service must exist before the StatefulSet, and is responsible for the network identity of the set. Pods get DNS/hostnames that follow the pattern: pod-specific-string.serviceName.default.svc.cluster.local where \"pod-specific-string\" is managed by the StatefulSet controller.", | ||||
| 	"podManagementPolicy":  "podManagementPolicy controls how pods are created during initial scale up, when replacing pods on nodes, or when scaling down. The default policy is `OrderedReady`, where pods are created in increasing order (pod-0, then pod-1, etc) and the controller will wait until each pod is ready before continuing. When scaling down, the pods are removed in the opposite order. The alternative policy is `Parallel` which will create pods in parallel to match the desired scale without waiting, and on scale down will delete all pods at once.", | ||||
| 	"updateStrategy":       "updateStrategy indicates the StatefulSetUpdateStrategy that will be employed to update Pods in the StatefulSet when a revision is made to Template.", | ||||
| 	"revisionHistoryLimit": "revisionHistoryLimit is the maximum number of revisions that will be maintained in the StatefulSet's revision history. The revision history consists of all revisions not represented by a currently applied StatefulSetSpec version. The default value is 10.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetSpec | ||||
| } | ||||
|  | ||||
| var map_StatefulSetStatus = map[string]string{ | ||||
| 	"":                   "StatefulSetStatus represents the current state of a StatefulSet.", | ||||
| 	"observedGeneration": "observedGeneration is the most recent generation observed for this StatefulSet. It corresponds to the StatefulSet's generation, which is updated on mutation by the API Server.", | ||||
| 	"replicas":           "replicas is the number of Pods created by the StatefulSet controller.", | ||||
| 	"readyReplicas":      "readyReplicas is the number of Pods created by the StatefulSet controller that have a Ready Condition.", | ||||
| 	"currentReplicas":    "currentReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by currentRevision.", | ||||
| 	"updatedReplicas":    "updatedReplicas is the number of Pods created by the StatefulSet controller from the StatefulSet version indicated by updateRevision.", | ||||
| 	"currentRevision":    "currentRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [0,currentReplicas).", | ||||
| 	"updateRevision":     "updateRevision, if not empty, indicates the version of the StatefulSet used to generate Pods in the sequence [replicas-updatedReplicas,replicas)", | ||||
| 	"collisionCount":     "collisionCount is the count of hash collisions for the StatefulSet. The StatefulSet controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ControllerRevision.", | ||||
| 	"conditions":         "Represents the latest available observations of a statefulset's current state.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetStatus | ||||
| } | ||||
|  | ||||
| var map_StatefulSetUpdateStrategy = map[string]string{ | ||||
| 	"":              "StatefulSetUpdateStrategy indicates the strategy that the StatefulSet controller will use to perform updates. It includes any additional parameters necessary to perform the update for the indicated strategy.", | ||||
| 	"type":          "Type indicates the type of the StatefulSetUpdateStrategy. Default is RollingUpdate.", | ||||
| 	"rollingUpdate": "RollingUpdate is used to communicate parameters when Type is RollingUpdateStatefulSetStrategyType.", | ||||
| } | ||||
|  | ||||
| func (StatefulSetUpdateStrategy) SwaggerDoc() map[string]string { | ||||
| 	return map_StatefulSetUpdateStrategy | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										839
									
								
								vendor/k8s.io/api/apps/v1beta2/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										839
									
								
								vendor/k8s.io/api/apps/v1beta2/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,839 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta2 | ||||
|  | ||||
| import ( | ||||
| 	corev1 "k8s.io/api/core/v1" | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevision) DeepCopyInto(out *ControllerRevision) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Data.DeepCopyInto(&out.Data) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevision. | ||||
| func (in *ControllerRevision) DeepCopy() *ControllerRevision { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevision) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevision) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ControllerRevisionList) DeepCopyInto(out *ControllerRevisionList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ControllerRevision, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ControllerRevisionList. | ||||
| func (in *ControllerRevisionList) DeepCopy() *ControllerRevisionList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ControllerRevisionList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ControllerRevisionList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSet) DeepCopyInto(out *DaemonSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSet. | ||||
| func (in *DaemonSet) DeepCopy() *DaemonSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DaemonSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetCondition) DeepCopyInto(out *DaemonSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetCondition. | ||||
| func (in *DaemonSetCondition) DeepCopy() *DaemonSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetList) DeepCopyInto(out *DaemonSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]DaemonSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetList. | ||||
| func (in *DaemonSetList) DeepCopy() *DaemonSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DaemonSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetSpec) DeepCopyInto(out *DaemonSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	in.UpdateStrategy.DeepCopyInto(&out.UpdateStrategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetSpec. | ||||
| func (in *DaemonSetSpec) DeepCopy() *DaemonSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetStatus) DeepCopyInto(out *DaemonSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]DaemonSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetStatus. | ||||
| func (in *DaemonSetStatus) DeepCopy() *DaemonSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DaemonSetUpdateStrategy) DeepCopyInto(out *DaemonSetUpdateStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateDaemonSet) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DaemonSetUpdateStrategy. | ||||
| func (in *DaemonSetUpdateStrategy) DeepCopy() *DaemonSetUpdateStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DaemonSetUpdateStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Deployment) DeepCopyInto(out *Deployment) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Deployment. | ||||
| func (in *Deployment) DeepCopy() *Deployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Deployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Deployment) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentCondition) DeepCopyInto(out *DeploymentCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastUpdateTime.DeepCopyInto(&out.LastUpdateTime) | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentCondition. | ||||
| func (in *DeploymentCondition) DeepCopy() *DeploymentCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentList) DeepCopyInto(out *DeploymentList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]Deployment, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentList. | ||||
| func (in *DeploymentList) DeepCopy() *DeploymentList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *DeploymentList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentSpec) DeepCopyInto(out *DeploymentSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	in.Strategy.DeepCopyInto(&out.Strategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.ProgressDeadlineSeconds != nil { | ||||
| 		in, out := &in.ProgressDeadlineSeconds, &out.ProgressDeadlineSeconds | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentSpec. | ||||
| func (in *DeploymentSpec) DeepCopy() *DeploymentSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStatus) DeepCopyInto(out *DeploymentStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]DeploymentCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStatus. | ||||
| func (in *DeploymentStatus) DeepCopy() *DeploymentStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *DeploymentStrategy) DeepCopyInto(out *DeploymentStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateDeployment) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new DeploymentStrategy. | ||||
| func (in *DeploymentStrategy) DeepCopy() *DeploymentStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(DeploymentStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSet) DeepCopyInto(out *ReplicaSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSet. | ||||
| func (in *ReplicaSet) DeepCopy() *ReplicaSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ReplicaSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetCondition) DeepCopyInto(out *ReplicaSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetCondition. | ||||
| func (in *ReplicaSetCondition) DeepCopy() *ReplicaSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetList) DeepCopyInto(out *ReplicaSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ReplicaSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetList. | ||||
| func (in *ReplicaSetList) DeepCopy() *ReplicaSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ReplicaSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetSpec) DeepCopyInto(out *ReplicaSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetSpec. | ||||
| func (in *ReplicaSetSpec) DeepCopy() *ReplicaSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ReplicaSetStatus) DeepCopyInto(out *ReplicaSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]ReplicaSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ReplicaSetStatus. | ||||
| func (in *ReplicaSetStatus) DeepCopy() *ReplicaSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ReplicaSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateDaemonSet) DeepCopyInto(out *RollingUpdateDaemonSet) { | ||||
| 	*out = *in | ||||
| 	if in.MaxUnavailable != nil { | ||||
| 		in, out := &in.MaxUnavailable, &out.MaxUnavailable | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateDaemonSet. | ||||
| func (in *RollingUpdateDaemonSet) DeepCopy() *RollingUpdateDaemonSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateDaemonSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateDeployment) DeepCopyInto(out *RollingUpdateDeployment) { | ||||
| 	*out = *in | ||||
| 	if in.MaxUnavailable != nil { | ||||
| 		in, out := &in.MaxUnavailable, &out.MaxUnavailable | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.MaxSurge != nil { | ||||
| 		in, out := &in.MaxSurge, &out.MaxSurge | ||||
| 		*out = new(intstr.IntOrString) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateDeployment. | ||||
| func (in *RollingUpdateDeployment) DeepCopy() *RollingUpdateDeployment { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateDeployment) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopyInto(out *RollingUpdateStatefulSetStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.Partition != nil { | ||||
| 		in, out := &in.Partition, &out.Partition | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RollingUpdateStatefulSetStrategy. | ||||
| func (in *RollingUpdateStatefulSetStrategy) DeepCopy() *RollingUpdateStatefulSetStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RollingUpdateStatefulSetStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Scale) DeepCopyInto(out *Scale) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	out.Spec = in.Spec | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Scale. | ||||
| func (in *Scale) DeepCopy() *Scale { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Scale) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Scale) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleSpec) DeepCopyInto(out *ScaleSpec) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleSpec. | ||||
| func (in *ScaleSpec) DeepCopy() *ScaleSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleStatus) DeepCopyInto(out *ScaleStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = make(map[string]string, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			(*out)[key] = val | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleStatus. | ||||
| func (in *ScaleStatus) DeepCopy() *ScaleStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSet) DeepCopyInto(out *StatefulSet) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSet. | ||||
| func (in *StatefulSet) DeepCopy() *StatefulSet { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSet) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSet) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetCondition) DeepCopyInto(out *StatefulSetCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetCondition. | ||||
| func (in *StatefulSetCondition) DeepCopy() *StatefulSetCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetList) DeepCopyInto(out *StatefulSetList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]StatefulSet, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetList. | ||||
| func (in *StatefulSetList) DeepCopy() *StatefulSetList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *StatefulSetList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetSpec) DeepCopyInto(out *StatefulSetSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Replicas != nil { | ||||
| 		in, out := &in.Replicas, &out.Replicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	if in.VolumeClaimTemplates != nil { | ||||
| 		in, out := &in.VolumeClaimTemplates, &out.VolumeClaimTemplates | ||||
| 		*out = make([]corev1.PersistentVolumeClaim, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	in.UpdateStrategy.DeepCopyInto(&out.UpdateStrategy) | ||||
| 	if in.RevisionHistoryLimit != nil { | ||||
| 		in, out := &in.RevisionHistoryLimit, &out.RevisionHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetSpec. | ||||
| func (in *StatefulSetSpec) DeepCopy() *StatefulSetSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetStatus) DeepCopyInto(out *StatefulSetStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CollisionCount != nil { | ||||
| 		in, out := &in.CollisionCount, &out.CollisionCount | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]StatefulSetCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetStatus. | ||||
| func (in *StatefulSetStatus) DeepCopy() *StatefulSetStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopyInto(out *StatefulSetUpdateStrategy) { | ||||
| 	*out = *in | ||||
| 	if in.RollingUpdate != nil { | ||||
| 		in, out := &in.RollingUpdate, &out.RollingUpdate | ||||
| 		*out = new(RollingUpdateStatefulSetStrategy) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetUpdateStrategy. | ||||
| func (in *StatefulSetUpdateStrategy) DeepCopy() *StatefulSetUpdateStrategy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(StatefulSetUpdateStrategy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										23
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| /* | ||||
| Copyright 2018 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| // +groupName=auditregistration.k8s.io | ||||
|  | ||||
| package v1alpha1 // import "k8s.io/api/auditregistration/v1alpha1" | ||||
							
								
								
									
										1690
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1690
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										158
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,158 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.auditregistration.v1alpha1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1alpha1"; | ||||
|  | ||||
| // AuditSink represents a cluster level audit sink | ||||
| message AuditSink { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec defines the audit configuration spec | ||||
|   optional AuditSinkSpec spec = 2; | ||||
| } | ||||
|  | ||||
| // AuditSinkList is a list of AuditSink items. | ||||
| message AuditSinkList { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // List of audit configurations. | ||||
|   repeated AuditSink items = 2; | ||||
| } | ||||
|  | ||||
| // AuditSinkSpec holds the spec for the audit sink | ||||
| message AuditSinkSpec { | ||||
|   // Policy defines the policy for selecting which events should be sent to the webhook | ||||
|   // required | ||||
|   optional Policy policy = 1; | ||||
|  | ||||
|   // Webhook to send events | ||||
|   // required | ||||
|   optional Webhook webhook = 2; | ||||
| } | ||||
|  | ||||
| // Policy defines the configuration of how audit events are logged | ||||
| message Policy { | ||||
|   // The Level that all requests are recorded at. | ||||
|   // available options: None, Metadata, Request, RequestResponse | ||||
|   // required | ||||
|   optional string level = 1; | ||||
|  | ||||
|   // Stages is a list of stages for which events are created. | ||||
|   // +optional | ||||
|   repeated string stages = 2; | ||||
| } | ||||
|  | ||||
| // ServiceReference holds a reference to Service.legacy.k8s.io | ||||
| message ServiceReference { | ||||
|   // `namespace` is the namespace of the service. | ||||
|   // Required | ||||
|   optional string namespace = 1; | ||||
|  | ||||
|   // `name` is the name of the service. | ||||
|   // Required | ||||
|   optional string name = 2; | ||||
|  | ||||
|   // `path` is an optional URL path which will be sent in any request to | ||||
|   // this service. | ||||
|   // +optional | ||||
|   optional string path = 3; | ||||
| } | ||||
|  | ||||
| // Webhook holds the configuration of the webhook | ||||
| message Webhook { | ||||
|   // Throttle holds the options for throttling the webhook | ||||
|   // +optional | ||||
|   optional WebhookThrottleConfig throttle = 1; | ||||
|  | ||||
|   // ClientConfig holds the connection parameters for the webhook | ||||
|   // required | ||||
|   optional WebhookClientConfig clientConfig = 2; | ||||
| } | ||||
|  | ||||
| // WebhookClientConfig contains the information to make a connection with the webhook | ||||
| message WebhookClientConfig { | ||||
|   // `url` gives the location of the webhook, in standard URL form | ||||
|   // (`scheme://host:port/path`). Exactly one of `url` or `service` | ||||
|   // must be specified. | ||||
|   // | ||||
|   // The `host` should not refer to a service running in the cluster; use | ||||
|   // the `service` field instead. The host might be resolved via external | ||||
|   // DNS in some apiservers (e.g., `kube-apiserver` cannot resolve | ||||
|   // in-cluster DNS as that would be a layering violation). `host` may | ||||
|   // also be an IP address. | ||||
|   // | ||||
|   // Please note that using `localhost` or `127.0.0.1` as a `host` is | ||||
|   // risky unless you take great care to run this webhook on all hosts | ||||
|   // which run an apiserver which might need to make calls to this | ||||
|   // webhook. Such installs are likely to be non-portable, i.e., not easy | ||||
|   // to turn up in a new cluster. | ||||
|   // | ||||
|   // The scheme must be "https"; the URL must begin with "https://". | ||||
|   // | ||||
|   // A path is optional, and if present may be any string permissible in | ||||
|   // a URL. You may use the path to pass an arbitrary string to the | ||||
|   // webhook, for example, a cluster identifier. | ||||
|   // | ||||
|   // Attempting to use a user or basic auth e.g. "user:password@" is not | ||||
|   // allowed. Fragments ("#...") and query parameters ("?...") are not | ||||
|   // allowed, either. | ||||
|   // | ||||
|   // +optional | ||||
|   optional string url = 1; | ||||
|  | ||||
|   // `service` is a reference to the service for this webhook. Either | ||||
|   // `service` or `url` must be specified. | ||||
|   // | ||||
|   // If the webhook is running within the cluster, then you should use `service`. | ||||
|   // | ||||
|   // Port 443 will be used if it is open, otherwise it is an error. | ||||
|   // | ||||
|   // +optional | ||||
|   optional ServiceReference service = 2; | ||||
|  | ||||
|   // `caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. | ||||
|   // If unspecified, system trust roots on the apiserver are used. | ||||
|   // +optional | ||||
|   optional bytes caBundle = 3; | ||||
| } | ||||
|  | ||||
| // WebhookThrottleConfig holds the configuration for throttling events | ||||
| message WebhookThrottleConfig { | ||||
|   // ThrottleQPS maximum number of batches per second | ||||
|   // default 10 QPS | ||||
|   // +optional | ||||
|   optional int64 qps = 1; | ||||
|  | ||||
|   // ThrottleBurst is the maximum number of events sent at the same moment | ||||
|   // default 15 QPS | ||||
|   // +optional | ||||
|   optional int64 burst = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										56
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,56 @@ | ||||
| /* | ||||
| Copyright 2018 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 v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "auditregistration.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1alpha1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	SchemeBuilder      runtime.SchemeBuilder | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| func init() { | ||||
| 	// We only register manually written functions here. The registration of the | ||||
| 	// generated functions takes place in the generated files. The separation | ||||
| 	// makes the code compile even when the generated files are missing. | ||||
| 	localSchemeBuilder.Register(addKnownTypes) | ||||
| } | ||||
|  | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&AuditSink{}, | ||||
| 		&AuditSinkList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										194
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,194 @@ | ||||
| /* | ||||
| Copyright 2018 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // Level defines the amount of information logged during auditing | ||||
| type Level string | ||||
|  | ||||
| // Valid audit levels | ||||
| const ( | ||||
| 	// LevelNone disables auditing | ||||
| 	LevelNone Level = "None" | ||||
| 	// LevelMetadata provides the basic level of auditing. | ||||
| 	LevelMetadata Level = "Metadata" | ||||
| 	// LevelRequest provides Metadata level of auditing, and additionally | ||||
| 	// logs the request object (does not apply for non-resource requests). | ||||
| 	LevelRequest Level = "Request" | ||||
| 	// LevelRequestResponse provides Request level of auditing, and additionally | ||||
| 	// logs the response object (does not apply for non-resource requests and watches). | ||||
| 	LevelRequestResponse Level = "RequestResponse" | ||||
| ) | ||||
|  | ||||
| // Stage defines the stages in request handling during which audit events may be generated. | ||||
| type Stage string | ||||
|  | ||||
| // Valid audit stages. | ||||
| const ( | ||||
| 	// The stage for events generated after the audit handler receives the request, but before it | ||||
| 	// is delegated down the handler chain. | ||||
| 	StageRequestReceived = "RequestReceived" | ||||
| 	// The stage for events generated after the response headers are sent, but before the response body | ||||
| 	// is sent. This stage is only generated for long-running requests (e.g. watch). | ||||
| 	StageResponseStarted = "ResponseStarted" | ||||
| 	// The stage for events generated after the response body has been completed, and no more bytes | ||||
| 	// will be sent. | ||||
| 	StageResponseComplete = "ResponseComplete" | ||||
| 	// The stage for events generated when a panic occurred. | ||||
| 	StagePanic = "Panic" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // AuditSink represents a cluster level audit sink | ||||
| type AuditSink struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec defines the audit configuration spec | ||||
| 	Spec AuditSinkSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| } | ||||
|  | ||||
| // AuditSinkSpec holds the spec for the audit sink | ||||
| type AuditSinkSpec struct { | ||||
| 	// Policy defines the policy for selecting which events should be sent to the webhook | ||||
| 	// required | ||||
| 	Policy Policy `json:"policy" protobuf:"bytes,1,opt,name=policy"` | ||||
|  | ||||
| 	// Webhook to send events | ||||
| 	// required | ||||
| 	Webhook Webhook `json:"webhook" protobuf:"bytes,2,opt,name=webhook"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // AuditSinkList is a list of AuditSink items. | ||||
| type AuditSinkList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// List of audit configurations. | ||||
| 	Items []AuditSink `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // Policy defines the configuration of how audit events are logged | ||||
| type Policy struct { | ||||
| 	// The Level that all requests are recorded at. | ||||
| 	// available options: None, Metadata, Request, RequestResponse | ||||
| 	// required | ||||
| 	Level Level `json:"level" protobuf:"bytes,1,opt,name=level"` | ||||
|  | ||||
| 	// Stages is a list of stages for which events are created. | ||||
| 	// +optional | ||||
| 	Stages []Stage `json:"stages" protobuf:"bytes,2,opt,name=stages"` | ||||
| } | ||||
|  | ||||
| // Webhook holds the configuration of the webhook | ||||
| type Webhook struct { | ||||
| 	// Throttle holds the options for throttling the webhook | ||||
| 	// +optional | ||||
| 	Throttle *WebhookThrottleConfig `json:"throttle,omitempty" protobuf:"bytes,1,opt,name=throttle"` | ||||
|  | ||||
| 	// ClientConfig holds the connection parameters for the webhook | ||||
| 	// required | ||||
| 	ClientConfig WebhookClientConfig `json:"clientConfig" protobuf:"bytes,2,opt,name=clientConfig"` | ||||
| } | ||||
|  | ||||
| // WebhookThrottleConfig holds the configuration for throttling events | ||||
| type WebhookThrottleConfig struct { | ||||
| 	// ThrottleQPS maximum number of batches per second | ||||
| 	// default 10 QPS | ||||
| 	// +optional | ||||
| 	QPS *int64 `json:"qps,omitempty" protobuf:"bytes,1,opt,name=qps"` | ||||
|  | ||||
| 	// ThrottleBurst is the maximum number of events sent at the same moment | ||||
| 	// default 15 QPS | ||||
| 	// +optional | ||||
| 	Burst *int64 `json:"burst,omitempty" protobuf:"bytes,2,opt,name=burst"` | ||||
| } | ||||
|  | ||||
| // WebhookClientConfig contains the information to make a connection with the webhook | ||||
| type WebhookClientConfig struct { | ||||
| 	// `url` gives the location of the webhook, in standard URL form | ||||
| 	// (`scheme://host:port/path`). Exactly one of `url` or `service` | ||||
| 	// must be specified. | ||||
| 	// | ||||
| 	// The `host` should not refer to a service running in the cluster; use | ||||
| 	// the `service` field instead. The host might be resolved via external | ||||
| 	// DNS in some apiservers (e.g., `kube-apiserver` cannot resolve | ||||
| 	// in-cluster DNS as that would be a layering violation). `host` may | ||||
| 	// also be an IP address. | ||||
| 	// | ||||
| 	// Please note that using `localhost` or `127.0.0.1` as a `host` is | ||||
| 	// risky unless you take great care to run this webhook on all hosts | ||||
| 	// which run an apiserver which might need to make calls to this | ||||
| 	// webhook. Such installs are likely to be non-portable, i.e., not easy | ||||
| 	// to turn up in a new cluster. | ||||
| 	// | ||||
| 	// The scheme must be "https"; the URL must begin with "https://". | ||||
| 	// | ||||
| 	// A path is optional, and if present may be any string permissible in | ||||
| 	// a URL. You may use the path to pass an arbitrary string to the | ||||
| 	// webhook, for example, a cluster identifier. | ||||
| 	// | ||||
| 	// Attempting to use a user or basic auth e.g. "user:password@" is not | ||||
| 	// allowed. Fragments ("#...") and query parameters ("?...") are not | ||||
| 	// allowed, either. | ||||
| 	// | ||||
| 	// +optional | ||||
| 	URL *string `json:"url,omitempty" protobuf:"bytes,1,opt,name=url"` | ||||
|  | ||||
| 	// `service` is a reference to the service for this webhook. Either | ||||
| 	// `service` or `url` must be specified. | ||||
| 	// | ||||
| 	// If the webhook is running within the cluster, then you should use `service`. | ||||
| 	// | ||||
| 	// Port 443 will be used if it is open, otherwise it is an error. | ||||
| 	// | ||||
| 	// +optional | ||||
| 	Service *ServiceReference `json:"service,omitempty" protobuf:"bytes,2,opt,name=service"` | ||||
|  | ||||
| 	// `caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. | ||||
| 	// If unspecified, system trust roots on the apiserver are used. | ||||
| 	// +optional | ||||
| 	CABundle []byte `json:"caBundle,omitempty" protobuf:"bytes,3,opt,name=caBundle"` | ||||
| } | ||||
|  | ||||
| // ServiceReference holds a reference to Service.legacy.k8s.io | ||||
| type ServiceReference struct { | ||||
| 	// `namespace` is the namespace of the service. | ||||
| 	// Required | ||||
| 	Namespace string `json:"namespace" protobuf:"bytes,1,opt,name=namespace"` | ||||
|  | ||||
| 	// `name` is the name of the service. | ||||
| 	// Required | ||||
| 	Name string `json:"name" protobuf:"bytes,2,opt,name=name"` | ||||
|  | ||||
| 	// `path` is an optional URL path which will be sent in any request to | ||||
| 	// this service. | ||||
| 	// +optional | ||||
| 	Path *string `json:"path,omitempty" protobuf:"bytes,3,opt,name=path"` | ||||
| } | ||||
							
								
								
									
										110
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,110 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_AuditSink = map[string]string{ | ||||
| 	"":     "AuditSink represents a cluster level audit sink", | ||||
| 	"spec": "Spec defines the audit configuration spec", | ||||
| } | ||||
|  | ||||
| func (AuditSink) SwaggerDoc() map[string]string { | ||||
| 	return map_AuditSink | ||||
| } | ||||
|  | ||||
| var map_AuditSinkList = map[string]string{ | ||||
| 	"":      "AuditSinkList is a list of AuditSink items.", | ||||
| 	"items": "List of audit configurations.", | ||||
| } | ||||
|  | ||||
| func (AuditSinkList) SwaggerDoc() map[string]string { | ||||
| 	return map_AuditSinkList | ||||
| } | ||||
|  | ||||
| var map_AuditSinkSpec = map[string]string{ | ||||
| 	"":        "AuditSinkSpec holds the spec for the audit sink", | ||||
| 	"policy":  "Policy defines the policy for selecting which events should be sent to the webhook required", | ||||
| 	"webhook": "Webhook to send events required", | ||||
| } | ||||
|  | ||||
| func (AuditSinkSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_AuditSinkSpec | ||||
| } | ||||
|  | ||||
| var map_Policy = map[string]string{ | ||||
| 	"":       "Policy defines the configuration of how audit events are logged", | ||||
| 	"level":  "The Level that all requests are recorded at. available options: None, Metadata, Request, RequestResponse required", | ||||
| 	"stages": "Stages is a list of stages for which events are created.", | ||||
| } | ||||
|  | ||||
| func (Policy) SwaggerDoc() map[string]string { | ||||
| 	return map_Policy | ||||
| } | ||||
|  | ||||
| var map_ServiceReference = map[string]string{ | ||||
| 	"":          "ServiceReference holds a reference to Service.legacy.k8s.io", | ||||
| 	"namespace": "`namespace` is the namespace of the service. Required", | ||||
| 	"name":      "`name` is the name of the service. Required", | ||||
| 	"path":      "`path` is an optional URL path which will be sent in any request to this service.", | ||||
| } | ||||
|  | ||||
| func (ServiceReference) SwaggerDoc() map[string]string { | ||||
| 	return map_ServiceReference | ||||
| } | ||||
|  | ||||
| var map_Webhook = map[string]string{ | ||||
| 	"":             "Webhook holds the configuration of the webhook", | ||||
| 	"throttle":     "Throttle holds the options for throttling the webhook", | ||||
| 	"clientConfig": "ClientConfig holds the connection parameters for the webhook required", | ||||
| } | ||||
|  | ||||
| func (Webhook) SwaggerDoc() map[string]string { | ||||
| 	return map_Webhook | ||||
| } | ||||
|  | ||||
| var map_WebhookClientConfig = map[string]string{ | ||||
| 	"":         "WebhookClientConfig contains the information to make a connection with the webhook", | ||||
| 	"url":      "`url` gives the location of the webhook, in standard URL form (`scheme://host:port/path`). Exactly one of `url` or `service` must be specified.\n\nThe `host` should not refer to a service running in the cluster; use the `service` field instead. The host might be resolved via external DNS in some apiservers (e.g., `kube-apiserver` cannot resolve in-cluster DNS as that would be a layering violation). `host` may also be an IP address.\n\nPlease note that using `localhost` or `127.0.0.1` as a `host` is risky unless you take great care to run this webhook on all hosts which run an apiserver which might need to make calls to this webhook. Such installs are likely to be non-portable, i.e., not easy to turn up in a new cluster.\n\nThe scheme must be \"https\"; the URL must begin with \"https://\".\n\nA path is optional, and if present may be any string permissible in a URL. You may use the path to pass an arbitrary string to the webhook, for example, a cluster identifier.\n\nAttempting to use a user or basic auth e.g. \"user:password@\" is not allowed. Fragments (\"#...\") and query parameters (\"?...\") are not allowed, either.", | ||||
| 	"service":  "`service` is a reference to the service for this webhook. Either `service` or `url` must be specified.\n\nIf the webhook is running within the cluster, then you should use `service`.\n\nPort 443 will be used if it is open, otherwise it is an error.", | ||||
| 	"caBundle": "`caBundle` is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.", | ||||
| } | ||||
|  | ||||
| func (WebhookClientConfig) SwaggerDoc() map[string]string { | ||||
| 	return map_WebhookClientConfig | ||||
| } | ||||
|  | ||||
| var map_WebhookThrottleConfig = map[string]string{ | ||||
| 	"":      "WebhookThrottleConfig holds the configuration for throttling events", | ||||
| 	"qps":   "ThrottleQPS maximum number of batches per second default 10 QPS", | ||||
| 	"burst": "ThrottleBurst is the maximum number of events sent at the same moment default 15 QPS", | ||||
| } | ||||
|  | ||||
| func (WebhookThrottleConfig) SwaggerDoc() map[string]string { | ||||
| 	return map_WebhookThrottleConfig | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										224
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										224
									
								
								vendor/k8s.io/api/auditregistration/v1alpha1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,224 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *AuditSink) DeepCopyInto(out *AuditSink) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AuditSink. | ||||
| func (in *AuditSink) DeepCopy() *AuditSink { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(AuditSink) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *AuditSink) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *AuditSinkList) DeepCopyInto(out *AuditSinkList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]AuditSink, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AuditSinkList. | ||||
| func (in *AuditSinkList) DeepCopy() *AuditSinkList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(AuditSinkList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *AuditSinkList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *AuditSinkSpec) DeepCopyInto(out *AuditSinkSpec) { | ||||
| 	*out = *in | ||||
| 	in.Policy.DeepCopyInto(&out.Policy) | ||||
| 	in.Webhook.DeepCopyInto(&out.Webhook) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AuditSinkSpec. | ||||
| func (in *AuditSinkSpec) DeepCopy() *AuditSinkSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(AuditSinkSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Policy) DeepCopyInto(out *Policy) { | ||||
| 	*out = *in | ||||
| 	if in.Stages != nil { | ||||
| 		in, out := &in.Stages, &out.Stages | ||||
| 		*out = make([]Stage, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Policy. | ||||
| func (in *Policy) DeepCopy() *Policy { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Policy) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ServiceReference) DeepCopyInto(out *ServiceReference) { | ||||
| 	*out = *in | ||||
| 	if in.Path != nil { | ||||
| 		in, out := &in.Path, &out.Path | ||||
| 		*out = new(string) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ServiceReference. | ||||
| func (in *ServiceReference) DeepCopy() *ServiceReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ServiceReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Webhook) DeepCopyInto(out *Webhook) { | ||||
| 	*out = *in | ||||
| 	if in.Throttle != nil { | ||||
| 		in, out := &in.Throttle, &out.Throttle | ||||
| 		*out = new(WebhookThrottleConfig) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	in.ClientConfig.DeepCopyInto(&out.ClientConfig) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Webhook. | ||||
| func (in *Webhook) DeepCopy() *Webhook { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Webhook) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *WebhookClientConfig) DeepCopyInto(out *WebhookClientConfig) { | ||||
| 	*out = *in | ||||
| 	if in.URL != nil { | ||||
| 		in, out := &in.URL, &out.URL | ||||
| 		*out = new(string) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Service != nil { | ||||
| 		in, out := &in.Service, &out.Service | ||||
| 		*out = new(ServiceReference) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.CABundle != nil { | ||||
| 		in, out := &in.CABundle, &out.CABundle | ||||
| 		*out = make([]byte, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new WebhookClientConfig. | ||||
| func (in *WebhookClientConfig) DeepCopy() *WebhookClientConfig { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(WebhookClientConfig) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *WebhookThrottleConfig) DeepCopyInto(out *WebhookThrottleConfig) { | ||||
| 	*out = *in | ||||
| 	if in.QPS != nil { | ||||
| 		in, out := &in.QPS, &out.QPS | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Burst != nil { | ||||
| 		in, out := &in.Burst, &out.Burst | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new WebhookThrottleConfig. | ||||
| func (in *WebhookThrottleConfig) DeepCopy() *WebhookThrottleConfig { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(WebhookThrottleConfig) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										22
									
								
								vendor/k8s.io/api/authentication/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								vendor/k8s.io/api/authentication/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| /* | ||||
| Copyright 2017 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +groupName=authentication.k8s.io | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1 // import "k8s.io/api/authentication/v1" | ||||
							
								
								
									
										2238
									
								
								vendor/k8s.io/api/authentication/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2238
									
								
								vendor/k8s.io/api/authentication/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										182
									
								
								vendor/k8s.io/api/authentication/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								vendor/k8s.io/api/authentication/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,182 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.authentication.v1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1"; | ||||
|  | ||||
| // BoundObjectReference is a reference to an object that a token is bound to. | ||||
| message BoundObjectReference { | ||||
|   // Kind of the referent. Valid kinds are 'Pod' and 'Secret'. | ||||
|   // +optional | ||||
|   optional string kind = 1; | ||||
|  | ||||
|   // API version of the referent. | ||||
|   // +optional | ||||
|   optional string aPIVersion = 2; | ||||
|  | ||||
|   // Name of the referent. | ||||
|   // +optional | ||||
|   optional string name = 3; | ||||
|  | ||||
|   // UID of the referent. | ||||
|   // +optional | ||||
|   optional string uID = 4; | ||||
| } | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| message ExtraValue { | ||||
|   // items, if empty, will result in an empty slice | ||||
|  | ||||
|   repeated string items = 1; | ||||
| } | ||||
|  | ||||
| // TokenRequest requests a token for a given service account. | ||||
| message TokenRequest { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   optional TokenRequestSpec spec = 2; | ||||
|  | ||||
|   // +optional | ||||
|   optional TokenRequestStatus status = 3; | ||||
| } | ||||
|  | ||||
| // TokenRequestSpec contains client provided parameters of a token request. | ||||
| message TokenRequestSpec { | ||||
|   // Audiences are the intendend audiences of the token. A recipient of a | ||||
|   // token must identitfy themself with an identifier in the list of | ||||
|   // audiences of the token, and otherwise should reject the token. A | ||||
|   // token issued for multiple audiences may be used to authenticate | ||||
|   // against any of the audiences listed but implies a high degree of | ||||
|   // trust between the target audiences. | ||||
|   repeated string audiences = 1; | ||||
|  | ||||
|   // ExpirationSeconds is the requested duration of validity of the request. The | ||||
|   // token issuer may return a token with a different validity duration so a | ||||
|   // client needs to check the 'expiration' field in a response. | ||||
|   // +optional | ||||
|   optional int64 expirationSeconds = 4; | ||||
|  | ||||
|   // BoundObjectRef is a reference to an object that the token will be bound to. | ||||
|   // The token will only be valid for as long as the bound object exists. | ||||
|   // NOTE: The API server's TokenReview endpoint will validate the | ||||
|   // BoundObjectRef, but other audiences may not. Keep ExpirationSeconds | ||||
|   // small if you want prompt revocation. | ||||
|   // +optional | ||||
|   optional BoundObjectReference boundObjectRef = 3; | ||||
| } | ||||
|  | ||||
| // TokenRequestStatus is the result of a token request. | ||||
| message TokenRequestStatus { | ||||
|   // Token is the opaque bearer token. | ||||
|   optional string token = 1; | ||||
|  | ||||
|   // ExpirationTimestamp is the time of expiration of the returned token. | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time expirationTimestamp = 2; | ||||
| } | ||||
|  | ||||
| // TokenReview attempts to authenticate a token to a known user. | ||||
| // Note: TokenReview requests may be cached by the webhook token authenticator | ||||
| // plugin in the kube-apiserver. | ||||
| message TokenReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated | ||||
|   optional TokenReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request can be authenticated. | ||||
|   // +optional | ||||
|   optional TokenReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // TokenReviewSpec is a description of the token authentication request. | ||||
| message TokenReviewSpec { | ||||
|   // Token is the opaque bearer token. | ||||
|   // +optional | ||||
|   optional string token = 1; | ||||
|  | ||||
|   // Audiences is a list of the identifiers that the resource server presented | ||||
|   // with the token identifies as. Audience-aware token authenticators will | ||||
|   // verify that the token was intended for at least one of the audiences in | ||||
|   // this list. If no audiences are provided, the audience will default to the | ||||
|   // audience of the Kubernetes apiserver. | ||||
|   // +optional | ||||
|   repeated string audiences = 2; | ||||
| } | ||||
|  | ||||
| // TokenReviewStatus is the result of the token authentication request. | ||||
| message TokenReviewStatus { | ||||
|   // Authenticated indicates that the token was associated with a known user. | ||||
|   // +optional | ||||
|   optional bool authenticated = 1; | ||||
|  | ||||
|   // User is the UserInfo associated with the provided token. | ||||
|   // +optional | ||||
|   optional UserInfo user = 2; | ||||
|  | ||||
|   // Audiences are audience identifiers chosen by the authenticator that are | ||||
|   // compatible with both the TokenReview and token. An identifier is any | ||||
|   // identifier in the intersection of the TokenReviewSpec audiences and the | ||||
|   // token's audiences. A client of the TokenReview API that sets the | ||||
|   // spec.audiences field should validate that a compatible audience identifier | ||||
|   // is returned in the status.audiences field to ensure that the TokenReview | ||||
|   // server is audience aware. If a TokenReview returns an empty | ||||
|   // status.audience field where status.authenticated is "true", the token is | ||||
|   // valid against the audience of the Kubernetes API server. | ||||
|   // +optional | ||||
|   repeated string audiences = 4; | ||||
|  | ||||
|   // Error indicates that the token couldn't be checked | ||||
|   // +optional | ||||
|   optional string error = 3; | ||||
| } | ||||
|  | ||||
| // UserInfo holds the information about the user needed to implement the | ||||
| // user.Info interface. | ||||
| message UserInfo { | ||||
|   // The name that uniquely identifies this user among all active users. | ||||
|   // +optional | ||||
|   optional string username = 1; | ||||
|  | ||||
|   // A unique value that identifies this user across time. If this user is | ||||
|   // deleted and another user by the same name is added, they will have | ||||
|   // different UIDs. | ||||
|   // +optional | ||||
|   optional string uid = 2; | ||||
|  | ||||
|   // The names of groups this user is a part of. | ||||
|   // +optional | ||||
|   repeated string groups = 3; | ||||
|  | ||||
|   // Any additional information provided by the authenticator. | ||||
|   // +optional | ||||
|   map<string, ExtraValue> extra = 4; | ||||
| } | ||||
|  | ||||
							
								
								
									
										52
									
								
								vendor/k8s.io/api/authentication/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/k8s.io/api/authentication/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "authentication.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&TokenReview{}, | ||||
| 		&TokenRequest{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										189
									
								
								vendor/k8s.io/api/authentication/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										189
									
								
								vendor/k8s.io/api/authentication/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,189 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/types" | ||||
| ) | ||||
|  | ||||
| const ( | ||||
| 	// ImpersonateUserHeader is used to impersonate a particular user during an API server request | ||||
| 	ImpersonateUserHeader = "Impersonate-User" | ||||
|  | ||||
| 	// ImpersonateGroupHeader is used to impersonate a particular group during an API server request. | ||||
| 	// It can be repeated multiplied times for multiple groups. | ||||
| 	ImpersonateGroupHeader = "Impersonate-Group" | ||||
|  | ||||
| 	// ImpersonateUserExtraHeaderPrefix is a prefix for any header used to impersonate an entry in the | ||||
| 	// extra map[string][]string for user.Info.  The key will be every after the prefix. | ||||
| 	// It can be repeated multiplied times for multiple map keys and the same key can be repeated multiple | ||||
| 	// times to have multiple elements in the slice under a single key | ||||
| 	ImpersonateUserExtraHeaderPrefix = "Impersonate-Extra-" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // TokenReview attempts to authenticate a token to a known user. | ||||
| // Note: TokenReview requests may be cached by the webhook token authenticator | ||||
| // plugin in the kube-apiserver. | ||||
| type TokenReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated | ||||
| 	Spec TokenReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request can be authenticated. | ||||
| 	// +optional | ||||
| 	Status TokenReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // TokenReviewSpec is a description of the token authentication request. | ||||
| type TokenReviewSpec struct { | ||||
| 	// Token is the opaque bearer token. | ||||
| 	// +optional | ||||
| 	Token string `json:"token,omitempty" protobuf:"bytes,1,opt,name=token"` | ||||
| 	// Audiences is a list of the identifiers that the resource server presented | ||||
| 	// with the token identifies as. Audience-aware token authenticators will | ||||
| 	// verify that the token was intended for at least one of the audiences in | ||||
| 	// this list. If no audiences are provided, the audience will default to the | ||||
| 	// audience of the Kubernetes apiserver. | ||||
| 	// +optional | ||||
| 	Audiences []string `json:"audiences,omitempty" protobuf:"bytes,2,rep,name=audiences"` | ||||
| } | ||||
|  | ||||
| // TokenReviewStatus is the result of the token authentication request. | ||||
| type TokenReviewStatus struct { | ||||
| 	// Authenticated indicates that the token was associated with a known user. | ||||
| 	// +optional | ||||
| 	Authenticated bool `json:"authenticated,omitempty" protobuf:"varint,1,opt,name=authenticated"` | ||||
| 	// User is the UserInfo associated with the provided token. | ||||
| 	// +optional | ||||
| 	User UserInfo `json:"user,omitempty" protobuf:"bytes,2,opt,name=user"` | ||||
| 	// Audiences are audience identifiers chosen by the authenticator that are | ||||
| 	// compatible with both the TokenReview and token. An identifier is any | ||||
| 	// identifier in the intersection of the TokenReviewSpec audiences and the | ||||
| 	// token's audiences. A client of the TokenReview API that sets the | ||||
| 	// spec.audiences field should validate that a compatible audience identifier | ||||
| 	// is returned in the status.audiences field to ensure that the TokenReview | ||||
| 	// server is audience aware. If a TokenReview returns an empty | ||||
| 	// status.audience field where status.authenticated is "true", the token is | ||||
| 	// valid against the audience of the Kubernetes API server. | ||||
| 	// +optional | ||||
| 	Audiences []string `json:"audiences,omitempty" protobuf:"bytes,4,rep,name=audiences"` | ||||
| 	// Error indicates that the token couldn't be checked | ||||
| 	// +optional | ||||
| 	Error string `json:"error,omitempty" protobuf:"bytes,3,opt,name=error"` | ||||
| } | ||||
|  | ||||
| // UserInfo holds the information about the user needed to implement the | ||||
| // user.Info interface. | ||||
| type UserInfo struct { | ||||
| 	// The name that uniquely identifies this user among all active users. | ||||
| 	// +optional | ||||
| 	Username string `json:"username,omitempty" protobuf:"bytes,1,opt,name=username"` | ||||
| 	// A unique value that identifies this user across time. If this user is | ||||
| 	// deleted and another user by the same name is added, they will have | ||||
| 	// different UIDs. | ||||
| 	// +optional | ||||
| 	UID string `json:"uid,omitempty" protobuf:"bytes,2,opt,name=uid"` | ||||
| 	// The names of groups this user is a part of. | ||||
| 	// +optional | ||||
| 	Groups []string `json:"groups,omitempty" protobuf:"bytes,3,rep,name=groups"` | ||||
| 	// Any additional information provided by the authenticator. | ||||
| 	// +optional | ||||
| 	Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,4,rep,name=extra"` | ||||
| } | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| type ExtraValue []string | ||||
|  | ||||
| func (t ExtraValue) String() string { | ||||
| 	return fmt.Sprintf("%v", []string(t)) | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // TokenRequest requests a token for a given service account. | ||||
| type TokenRequest struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	Spec TokenRequestSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
| 	// +optional | ||||
| 	Status TokenRequestStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // TokenRequestSpec contains client provided parameters of a token request. | ||||
| type TokenRequestSpec struct { | ||||
| 	// Audiences are the intendend audiences of the token. A recipient of a | ||||
| 	// token must identitfy themself with an identifier in the list of | ||||
| 	// audiences of the token, and otherwise should reject the token. A | ||||
| 	// token issued for multiple audiences may be used to authenticate | ||||
| 	// against any of the audiences listed but implies a high degree of | ||||
| 	// trust between the target audiences. | ||||
| 	Audiences []string `json:"audiences" protobuf:"bytes,1,rep,name=audiences"` | ||||
|  | ||||
| 	// ExpirationSeconds is the requested duration of validity of the request. The | ||||
| 	// token issuer may return a token with a different validity duration so a | ||||
| 	// client needs to check the 'expiration' field in a response. | ||||
| 	// +optional | ||||
| 	ExpirationSeconds *int64 `json:"expirationSeconds" protobuf:"varint,4,opt,name=expirationSeconds"` | ||||
|  | ||||
| 	// BoundObjectRef is a reference to an object that the token will be bound to. | ||||
| 	// The token will only be valid for as long as the bound object exists. | ||||
| 	// NOTE: The API server's TokenReview endpoint will validate the | ||||
| 	// BoundObjectRef, but other audiences may not. Keep ExpirationSeconds | ||||
| 	// small if you want prompt revocation. | ||||
| 	// +optional | ||||
| 	BoundObjectRef *BoundObjectReference `json:"boundObjectRef" protobuf:"bytes,3,opt,name=boundObjectRef"` | ||||
| } | ||||
|  | ||||
| // TokenRequestStatus is the result of a token request. | ||||
| type TokenRequestStatus struct { | ||||
| 	// Token is the opaque bearer token. | ||||
| 	Token string `json:"token" protobuf:"bytes,1,opt,name=token"` | ||||
| 	// ExpirationTimestamp is the time of expiration of the returned token. | ||||
| 	ExpirationTimestamp metav1.Time `json:"expirationTimestamp" protobuf:"bytes,2,opt,name=expirationTimestamp"` | ||||
| } | ||||
|  | ||||
| // BoundObjectReference is a reference to an object that a token is bound to. | ||||
| type BoundObjectReference struct { | ||||
| 	// Kind of the referent. Valid kinds are 'Pod' and 'Secret'. | ||||
| 	// +optional | ||||
| 	Kind string `json:"kind,omitempty" protobuf:"bytes,1,opt,name=kind"` | ||||
| 	// API version of the referent. | ||||
| 	// +optional | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt,name=aPIVersion"` | ||||
|  | ||||
| 	// Name of the referent. | ||||
| 	// +optional | ||||
| 	Name string `json:"name,omitempty" protobuf:"bytes,3,opt,name=name"` | ||||
| 	// UID of the referent. | ||||
| 	// +optional | ||||
| 	UID types.UID `json:"uid,omitempty" protobuf:"bytes,4,opt,name=uID,casttype=k8s.io/apimachinery/pkg/types.UID"` | ||||
| } | ||||
							
								
								
									
										115
									
								
								vendor/k8s.io/api/authentication/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								vendor/k8s.io/api/authentication/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,115 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_BoundObjectReference = map[string]string{ | ||||
| 	"":           "BoundObjectReference is a reference to an object that a token is bound to.", | ||||
| 	"kind":       "Kind of the referent. Valid kinds are 'Pod' and 'Secret'.", | ||||
| 	"apiVersion": "API version of the referent.", | ||||
| 	"name":       "Name of the referent.", | ||||
| 	"uid":        "UID of the referent.", | ||||
| } | ||||
|  | ||||
| func (BoundObjectReference) SwaggerDoc() map[string]string { | ||||
| 	return map_BoundObjectReference | ||||
| } | ||||
|  | ||||
| var map_TokenRequest = map[string]string{ | ||||
| 	"": "TokenRequest requests a token for a given service account.", | ||||
| } | ||||
|  | ||||
| func (TokenRequest) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenRequest | ||||
| } | ||||
|  | ||||
| var map_TokenRequestSpec = map[string]string{ | ||||
| 	"":                  "TokenRequestSpec contains client provided parameters of a token request.", | ||||
| 	"audiences":         "Audiences are the intendend audiences of the token. A recipient of a token must identitfy themself with an identifier in the list of audiences of the token, and otherwise should reject the token. A token issued for multiple audiences may be used to authenticate against any of the audiences listed but implies a high degree of trust between the target audiences.", | ||||
| 	"expirationSeconds": "ExpirationSeconds is the requested duration of validity of the request. The token issuer may return a token with a different validity duration so a client needs to check the 'expiration' field in a response.", | ||||
| 	"boundObjectRef":    "BoundObjectRef is a reference to an object that the token will be bound to. The token will only be valid for as long as the bound object exists. NOTE: The API server's TokenReview endpoint will validate the BoundObjectRef, but other audiences may not. Keep ExpirationSeconds small if you want prompt revocation.", | ||||
| } | ||||
|  | ||||
| func (TokenRequestSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenRequestSpec | ||||
| } | ||||
|  | ||||
| var map_TokenRequestStatus = map[string]string{ | ||||
| 	"":                    "TokenRequestStatus is the result of a token request.", | ||||
| 	"token":               "Token is the opaque bearer token.", | ||||
| 	"expirationTimestamp": "ExpirationTimestamp is the time of expiration of the returned token.", | ||||
| } | ||||
|  | ||||
| func (TokenRequestStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenRequestStatus | ||||
| } | ||||
|  | ||||
| var map_TokenReview = map[string]string{ | ||||
| 	"":       "TokenReview attempts to authenticate a token to a known user. Note: TokenReview requests may be cached by the webhook token authenticator plugin in the kube-apiserver.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request can be authenticated.", | ||||
| } | ||||
|  | ||||
| func (TokenReview) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReview | ||||
| } | ||||
|  | ||||
| var map_TokenReviewSpec = map[string]string{ | ||||
| 	"":          "TokenReviewSpec is a description of the token authentication request.", | ||||
| 	"token":     "Token is the opaque bearer token.", | ||||
| 	"audiences": "Audiences is a list of the identifiers that the resource server presented with the token identifies as. Audience-aware token authenticators will verify that the token was intended for at least one of the audiences in this list. If no audiences are provided, the audience will default to the audience of the Kubernetes apiserver.", | ||||
| } | ||||
|  | ||||
| func (TokenReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReviewSpec | ||||
| } | ||||
|  | ||||
| var map_TokenReviewStatus = map[string]string{ | ||||
| 	"":              "TokenReviewStatus is the result of the token authentication request.", | ||||
| 	"authenticated": "Authenticated indicates that the token was associated with a known user.", | ||||
| 	"user":          "User is the UserInfo associated with the provided token.", | ||||
| 	"audiences":     "Audiences are audience identifiers chosen by the authenticator that are compatible with both the TokenReview and token. An identifier is any identifier in the intersection of the TokenReviewSpec audiences and the token's audiences. A client of the TokenReview API that sets the spec.audiences field should validate that a compatible audience identifier is returned in the status.audiences field to ensure that the TokenReview server is audience aware. If a TokenReview returns an empty status.audience field where status.authenticated is \"true\", the token is valid against the audience of the Kubernetes API server.", | ||||
| 	"error":         "Error indicates that the token couldn't be checked", | ||||
| } | ||||
|  | ||||
| func (TokenReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReviewStatus | ||||
| } | ||||
|  | ||||
| var map_UserInfo = map[string]string{ | ||||
| 	"":         "UserInfo holds the information about the user needed to implement the user.Info interface.", | ||||
| 	"username": "The name that uniquely identifies this user among all active users.", | ||||
| 	"uid":      "A unique value that identifies this user across time. If this user is deleted and another user by the same name is added, they will have different UIDs.", | ||||
| 	"groups":   "The names of groups this user is a part of.", | ||||
| 	"extra":    "Any additional information provided by the authenticator.", | ||||
| } | ||||
|  | ||||
| func (UserInfo) SwaggerDoc() map[string]string { | ||||
| 	return map_UserInfo | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										244
									
								
								vendor/k8s.io/api/authentication/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								vendor/k8s.io/api/authentication/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| import ( | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *BoundObjectReference) DeepCopyInto(out *BoundObjectReference) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new BoundObjectReference. | ||||
| func (in *BoundObjectReference) DeepCopy() *BoundObjectReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(BoundObjectReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in ExtraValue) DeepCopyInto(out *ExtraValue) { | ||||
| 	{ | ||||
| 		in := &in | ||||
| 		*out = make(ExtraValue, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExtraValue. | ||||
| func (in ExtraValue) DeepCopy() ExtraValue { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExtraValue) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return *out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenRequest) DeepCopyInto(out *TokenRequest) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenRequest. | ||||
| func (in *TokenRequest) DeepCopy() *TokenRequest { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenRequest) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *TokenRequest) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenRequestSpec) DeepCopyInto(out *TokenRequestSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Audiences != nil { | ||||
| 		in, out := &in.Audiences, &out.Audiences | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.ExpirationSeconds != nil { | ||||
| 		in, out := &in.ExpirationSeconds, &out.ExpirationSeconds | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.BoundObjectRef != nil { | ||||
| 		in, out := &in.BoundObjectRef, &out.BoundObjectRef | ||||
| 		*out = new(BoundObjectReference) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenRequestSpec. | ||||
| func (in *TokenRequestSpec) DeepCopy() *TokenRequestSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenRequestSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenRequestStatus) DeepCopyInto(out *TokenRequestStatus) { | ||||
| 	*out = *in | ||||
| 	in.ExpirationTimestamp.DeepCopyInto(&out.ExpirationTimestamp) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenRequestStatus. | ||||
| func (in *TokenRequestStatus) DeepCopy() *TokenRequestStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenRequestStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReview) DeepCopyInto(out *TokenReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReview. | ||||
| func (in *TokenReview) DeepCopy() *TokenReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *TokenReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReviewSpec) DeepCopyInto(out *TokenReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Audiences != nil { | ||||
| 		in, out := &in.Audiences, &out.Audiences | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReviewSpec. | ||||
| func (in *TokenReviewSpec) DeepCopy() *TokenReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReviewStatus) DeepCopyInto(out *TokenReviewStatus) { | ||||
| 	*out = *in | ||||
| 	in.User.DeepCopyInto(&out.User) | ||||
| 	if in.Audiences != nil { | ||||
| 		in, out := &in.Audiences, &out.Audiences | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReviewStatus. | ||||
| func (in *TokenReviewStatus) DeepCopy() *TokenReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *UserInfo) DeepCopyInto(out *UserInfo) { | ||||
| 	*out = *in | ||||
| 	if in.Groups != nil { | ||||
| 		in, out := &in.Groups, &out.Groups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Extra != nil { | ||||
| 		in, out := &in.Extra, &out.Extra | ||||
| 		*out = make(map[string]ExtraValue, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			var outVal []string | ||||
| 			if val == nil { | ||||
| 				(*out)[key] = nil | ||||
| 			} else { | ||||
| 				in, out := &val, &outVal | ||||
| 				*out = make(ExtraValue, len(*in)) | ||||
| 				copy(*out, *in) | ||||
| 			} | ||||
| 			(*out)[key] = outVal | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new UserInfo. | ||||
| func (in *UserInfo) DeepCopy() *UserInfo { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(UserInfo) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										22
									
								
								vendor/k8s.io/api/authentication/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								vendor/k8s.io/api/authentication/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +groupName=authentication.k8s.io | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1beta1 // import "k8s.io/api/authentication/v1beta1" | ||||
							
								
								
									
										1393
									
								
								vendor/k8s.io/api/authentication/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1393
									
								
								vendor/k8s.io/api/authentication/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										118
									
								
								vendor/k8s.io/api/authentication/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								vendor/k8s.io/api/authentication/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,118 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.authentication.v1beta1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta1"; | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| message ExtraValue { | ||||
|   // items, if empty, will result in an empty slice | ||||
|  | ||||
|   repeated string items = 1; | ||||
| } | ||||
|  | ||||
| // TokenReview attempts to authenticate a token to a known user. | ||||
| // Note: TokenReview requests may be cached by the webhook token authenticator | ||||
| // plugin in the kube-apiserver. | ||||
| message TokenReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated | ||||
|   optional TokenReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request can be authenticated. | ||||
|   // +optional | ||||
|   optional TokenReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // TokenReviewSpec is a description of the token authentication request. | ||||
| message TokenReviewSpec { | ||||
|   // Token is the opaque bearer token. | ||||
|   // +optional | ||||
|   optional string token = 1; | ||||
|  | ||||
|   // Audiences is a list of the identifiers that the resource server presented | ||||
|   // with the token identifies as. Audience-aware token authenticators will | ||||
|   // verify that the token was intended for at least one of the audiences in | ||||
|   // this list. If no audiences are provided, the audience will default to the | ||||
|   // audience of the Kubernetes apiserver. | ||||
|   // +optional | ||||
|   repeated string audiences = 2; | ||||
| } | ||||
|  | ||||
| // TokenReviewStatus is the result of the token authentication request. | ||||
| message TokenReviewStatus { | ||||
|   // Authenticated indicates that the token was associated with a known user. | ||||
|   // +optional | ||||
|   optional bool authenticated = 1; | ||||
|  | ||||
|   // User is the UserInfo associated with the provided token. | ||||
|   // +optional | ||||
|   optional UserInfo user = 2; | ||||
|  | ||||
|   // Audiences are audience identifiers chosen by the authenticator that are | ||||
|   // compatible with both the TokenReview and token. An identifier is any | ||||
|   // identifier in the intersection of the TokenReviewSpec audiences and the | ||||
|   // token's audiences. A client of the TokenReview API that sets the | ||||
|   // spec.audiences field should validate that a compatible audience identifier | ||||
|   // is returned in the status.audiences field to ensure that the TokenReview | ||||
|   // server is audience aware. If a TokenReview returns an empty | ||||
|   // status.audience field where status.authenticated is "true", the token is | ||||
|   // valid against the audience of the Kubernetes API server. | ||||
|   // +optional | ||||
|   repeated string audiences = 4; | ||||
|  | ||||
|   // Error indicates that the token couldn't be checked | ||||
|   // +optional | ||||
|   optional string error = 3; | ||||
| } | ||||
|  | ||||
| // UserInfo holds the information about the user needed to implement the | ||||
| // user.Info interface. | ||||
| message UserInfo { | ||||
|   // The name that uniquely identifies this user among all active users. | ||||
|   // +optional | ||||
|   optional string username = 1; | ||||
|  | ||||
|   // A unique value that identifies this user across time. If this user is | ||||
|   // deleted and another user by the same name is added, they will have | ||||
|   // different UIDs. | ||||
|   // +optional | ||||
|   optional string uid = 2; | ||||
|  | ||||
|   // The names of groups this user is a part of. | ||||
|   // +optional | ||||
|   repeated string groups = 3; | ||||
|  | ||||
|   // Any additional information provided by the authenticator. | ||||
|   // +optional | ||||
|   map<string, ExtraValue> extra = 4; | ||||
| } | ||||
|  | ||||
							
								
								
									
										51
									
								
								vendor/k8s.io/api/authentication/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								vendor/k8s.io/api/authentication/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| /* | ||||
| Copyright 2015 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "authentication.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&TokenReview{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										110
									
								
								vendor/k8s.io/api/authentication/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								vendor/k8s.io/api/authentication/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,110 @@ | ||||
| /* | ||||
| Copyright 2016 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // TokenReview attempts to authenticate a token to a known user. | ||||
| // Note: TokenReview requests may be cached by the webhook token authenticator | ||||
| // plugin in the kube-apiserver. | ||||
| type TokenReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated | ||||
| 	Spec TokenReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request can be authenticated. | ||||
| 	// +optional | ||||
| 	Status TokenReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // TokenReviewSpec is a description of the token authentication request. | ||||
| type TokenReviewSpec struct { | ||||
| 	// Token is the opaque bearer token. | ||||
| 	// +optional | ||||
| 	Token string `json:"token,omitempty" protobuf:"bytes,1,opt,name=token"` | ||||
| 	// Audiences is a list of the identifiers that the resource server presented | ||||
| 	// with the token identifies as. Audience-aware token authenticators will | ||||
| 	// verify that the token was intended for at least one of the audiences in | ||||
| 	// this list. If no audiences are provided, the audience will default to the | ||||
| 	// audience of the Kubernetes apiserver. | ||||
| 	// +optional | ||||
| 	Audiences []string `json:"audiences,omitempty" protobuf:"bytes,2,rep,name=audiences"` | ||||
| } | ||||
|  | ||||
| // TokenReviewStatus is the result of the token authentication request. | ||||
| type TokenReviewStatus struct { | ||||
| 	// Authenticated indicates that the token was associated with a known user. | ||||
| 	// +optional | ||||
| 	Authenticated bool `json:"authenticated,omitempty" protobuf:"varint,1,opt,name=authenticated"` | ||||
| 	// User is the UserInfo associated with the provided token. | ||||
| 	// +optional | ||||
| 	User UserInfo `json:"user,omitempty" protobuf:"bytes,2,opt,name=user"` | ||||
| 	// Audiences are audience identifiers chosen by the authenticator that are | ||||
| 	// compatible with both the TokenReview and token. An identifier is any | ||||
| 	// identifier in the intersection of the TokenReviewSpec audiences and the | ||||
| 	// token's audiences. A client of the TokenReview API that sets the | ||||
| 	// spec.audiences field should validate that a compatible audience identifier | ||||
| 	// is returned in the status.audiences field to ensure that the TokenReview | ||||
| 	// server is audience aware. If a TokenReview returns an empty | ||||
| 	// status.audience field where status.authenticated is "true", the token is | ||||
| 	// valid against the audience of the Kubernetes API server. | ||||
| 	// +optional | ||||
| 	Audiences []string `json:"audiences,omitempty" protobuf:"bytes,4,rep,name=audiences"` | ||||
| 	// Error indicates that the token couldn't be checked | ||||
| 	// +optional | ||||
| 	Error string `json:"error,omitempty" protobuf:"bytes,3,opt,name=error"` | ||||
| } | ||||
|  | ||||
| // UserInfo holds the information about the user needed to implement the | ||||
| // user.Info interface. | ||||
| type UserInfo struct { | ||||
| 	// The name that uniquely identifies this user among all active users. | ||||
| 	// +optional | ||||
| 	Username string `json:"username,omitempty" protobuf:"bytes,1,opt,name=username"` | ||||
| 	// A unique value that identifies this user across time. If this user is | ||||
| 	// deleted and another user by the same name is added, they will have | ||||
| 	// different UIDs. | ||||
| 	// +optional | ||||
| 	UID string `json:"uid,omitempty" protobuf:"bytes,2,opt,name=uid"` | ||||
| 	// The names of groups this user is a part of. | ||||
| 	// +optional | ||||
| 	Groups []string `json:"groups,omitempty" protobuf:"bytes,3,rep,name=groups"` | ||||
| 	// Any additional information provided by the authenticator. | ||||
| 	// +optional | ||||
| 	Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,4,rep,name=extra"` | ||||
| } | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| type ExtraValue []string | ||||
|  | ||||
| func (t ExtraValue) String() string { | ||||
| 	return fmt.Sprintf("%v", []string(t)) | ||||
| } | ||||
							
								
								
									
										74
									
								
								vendor/k8s.io/api/authentication/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								vendor/k8s.io/api/authentication/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,74 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_TokenReview = map[string]string{ | ||||
| 	"":       "TokenReview attempts to authenticate a token to a known user. Note: TokenReview requests may be cached by the webhook token authenticator plugin in the kube-apiserver.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request can be authenticated.", | ||||
| } | ||||
|  | ||||
| func (TokenReview) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReview | ||||
| } | ||||
|  | ||||
| var map_TokenReviewSpec = map[string]string{ | ||||
| 	"":          "TokenReviewSpec is a description of the token authentication request.", | ||||
| 	"token":     "Token is the opaque bearer token.", | ||||
| 	"audiences": "Audiences is a list of the identifiers that the resource server presented with the token identifies as. Audience-aware token authenticators will verify that the token was intended for at least one of the audiences in this list. If no audiences are provided, the audience will default to the audience of the Kubernetes apiserver.", | ||||
| } | ||||
|  | ||||
| func (TokenReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReviewSpec | ||||
| } | ||||
|  | ||||
| var map_TokenReviewStatus = map[string]string{ | ||||
| 	"":              "TokenReviewStatus is the result of the token authentication request.", | ||||
| 	"authenticated": "Authenticated indicates that the token was associated with a known user.", | ||||
| 	"user":          "User is the UserInfo associated with the provided token.", | ||||
| 	"audiences":     "Audiences are audience identifiers chosen by the authenticator that are compatible with both the TokenReview and token. An identifier is any identifier in the intersection of the TokenReviewSpec audiences and the token's audiences. A client of the TokenReview API that sets the spec.audiences field should validate that a compatible audience identifier is returned in the status.audiences field to ensure that the TokenReview server is audience aware. If a TokenReview returns an empty status.audience field where status.authenticated is \"true\", the token is valid against the audience of the Kubernetes API server.", | ||||
| 	"error":         "Error indicates that the token couldn't be checked", | ||||
| } | ||||
|  | ||||
| func (TokenReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_TokenReviewStatus | ||||
| } | ||||
|  | ||||
| var map_UserInfo = map[string]string{ | ||||
| 	"":         "UserInfo holds the information about the user needed to implement the user.Info interface.", | ||||
| 	"username": "The name that uniquely identifies this user among all active users.", | ||||
| 	"uid":      "A unique value that identifies this user across time. If this user is deleted and another user by the same name is added, they will have different UIDs.", | ||||
| 	"groups":   "The names of groups this user is a part of.", | ||||
| 	"extra":    "Any additional information provided by the authenticator.", | ||||
| } | ||||
|  | ||||
| func (UserInfo) SwaggerDoc() map[string]string { | ||||
| 	return map_UserInfo | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										152
									
								
								vendor/k8s.io/api/authentication/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								vendor/k8s.io/api/authentication/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,152 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in ExtraValue) DeepCopyInto(out *ExtraValue) { | ||||
| 	{ | ||||
| 		in := &in | ||||
| 		*out = make(ExtraValue, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExtraValue. | ||||
| func (in ExtraValue) DeepCopy() ExtraValue { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExtraValue) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return *out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReview) DeepCopyInto(out *TokenReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReview. | ||||
| func (in *TokenReview) DeepCopy() *TokenReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *TokenReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReviewSpec) DeepCopyInto(out *TokenReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Audiences != nil { | ||||
| 		in, out := &in.Audiences, &out.Audiences | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReviewSpec. | ||||
| func (in *TokenReviewSpec) DeepCopy() *TokenReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *TokenReviewStatus) DeepCopyInto(out *TokenReviewStatus) { | ||||
| 	*out = *in | ||||
| 	in.User.DeepCopyInto(&out.User) | ||||
| 	if in.Audiences != nil { | ||||
| 		in, out := &in.Audiences, &out.Audiences | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new TokenReviewStatus. | ||||
| func (in *TokenReviewStatus) DeepCopy() *TokenReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(TokenReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *UserInfo) DeepCopyInto(out *UserInfo) { | ||||
| 	*out = *in | ||||
| 	if in.Groups != nil { | ||||
| 		in, out := &in.Groups, &out.Groups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Extra != nil { | ||||
| 		in, out := &in.Extra, &out.Extra | ||||
| 		*out = make(map[string]ExtraValue, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			var outVal []string | ||||
| 			if val == nil { | ||||
| 				(*out)[key] = nil | ||||
| 			} else { | ||||
| 				in, out := &val, &outVal | ||||
| 				*out = make(ExtraValue, len(*in)) | ||||
| 				copy(*out, *in) | ||||
| 			} | ||||
| 			(*out)[key] = outVal | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new UserInfo. | ||||
| func (in *UserInfo) DeepCopy() *UserInfo { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(UserInfo) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										23
									
								
								vendor/k8s.io/api/authorization/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/k8s.io/api/authorization/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| /* | ||||
| Copyright 2017 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| // +groupName=authorization.k8s.io | ||||
|  | ||||
| package v1 // import "k8s.io/api/authorization/v1" | ||||
							
								
								
									
										3516
									
								
								vendor/k8s.io/api/authorization/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3516
									
								
								vendor/k8s.io/api/authorization/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										272
									
								
								vendor/k8s.io/api/authorization/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										272
									
								
								vendor/k8s.io/api/authorization/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,272 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.authorization.v1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1"; | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| message ExtraValue { | ||||
|   // items, if empty, will result in an empty slice | ||||
|  | ||||
|   repeated string items = 1; | ||||
| } | ||||
|  | ||||
| // LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. | ||||
| // Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions | ||||
| // checking. | ||||
| message LocalSubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace | ||||
|   // you made the request against.  If empty, it is defaulted. | ||||
|   optional SubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface | ||||
| message NonResourceAttributes { | ||||
|   // Path is the URL path of the request | ||||
|   // +optional | ||||
|   optional string path = 1; | ||||
|  | ||||
|   // Verb is the standard HTTP verb | ||||
|   // +optional | ||||
|   optional string verb = 2; | ||||
| } | ||||
|  | ||||
| // NonResourceRule holds information that describes a rule for the non-resource | ||||
| message NonResourceRule { | ||||
|   // Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  "*" means all. | ||||
|   repeated string verbs = 1; | ||||
|  | ||||
|   // NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, | ||||
|   // final step in the path.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string nonResourceURLs = 2; | ||||
| } | ||||
|  | ||||
| // ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface | ||||
| message ResourceAttributes { | ||||
|   // Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces | ||||
|   // "" (empty) is defaulted for LocalSubjectAccessReviews | ||||
|   // "" (empty) is empty for cluster-scoped resources | ||||
|   // "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview | ||||
|   // +optional | ||||
|   optional string namespace = 1; | ||||
|  | ||||
|   // Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
|   // +optional | ||||
|   optional string verb = 2; | ||||
|  | ||||
|   // Group is the API Group of the Resource.  "*" means all. | ||||
|   // +optional | ||||
|   optional string group = 3; | ||||
|  | ||||
|   // Version is the API Version of the Resource.  "*" means all. | ||||
|   // +optional | ||||
|   optional string version = 4; | ||||
|  | ||||
|   // Resource is one of the existing resource types.  "*" means all. | ||||
|   // +optional | ||||
|   optional string resource = 5; | ||||
|  | ||||
|   // Subresource is one of the existing resource types.  "" means none. | ||||
|   // +optional | ||||
|   optional string subresource = 6; | ||||
|  | ||||
|   // Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. | ||||
|   // +optional | ||||
|   optional string name = 7; | ||||
| } | ||||
|  | ||||
| // ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, | ||||
| // may contain duplicates, and possibly be incomplete. | ||||
| message ResourceRule { | ||||
|   // Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
|   repeated string verbs = 1; | ||||
|  | ||||
|   // APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
|   // the enumerated resources in any API group will be allowed.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string apiGroups = 2; | ||||
|  | ||||
|   // Resources is a list of resources this rule applies to.  "*" means all in the specified apiGroups. | ||||
|   //  "*/foo" represents the subresource 'foo' for all resources in the specified apiGroups. | ||||
|   // +optional | ||||
|   repeated string resources = 3; | ||||
|  | ||||
|   // ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string resourceNames = 4; | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a | ||||
| // spec.namespace means "in all namespaces".  Self is a special case, because users should always be able | ||||
| // to check whether they can perform an action | ||||
| message SelfSubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated.  user and groups must be empty | ||||
|   optional SelfSubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| message SelfSubjectAccessReviewSpec { | ||||
|   // ResourceAuthorizationAttributes describes information for a resource access request | ||||
|   // +optional | ||||
|   optional ResourceAttributes resourceAttributes = 1; | ||||
|  | ||||
|   // NonResourceAttributes describes information for a non-resource access request | ||||
|   // +optional | ||||
|   optional NonResourceAttributes nonResourceAttributes = 2; | ||||
| } | ||||
|  | ||||
| // SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. | ||||
| // The returned list of actions may be incomplete depending on the server's authorization mode, | ||||
| // and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, | ||||
| // or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to | ||||
| // drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. | ||||
| // SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server. | ||||
| message SelfSubjectRulesReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated. | ||||
|   optional SelfSubjectRulesReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates the set of actions a user can perform. | ||||
|   // +optional | ||||
|   optional SubjectRulesReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| message SelfSubjectRulesReviewSpec { | ||||
|   // Namespace to evaluate rules for. Required. | ||||
|   optional string namespace = 1; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReview checks whether or not a user or group can perform an action. | ||||
| message SubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated | ||||
|   optional SubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| message SubjectAccessReviewSpec { | ||||
|   // ResourceAuthorizationAttributes describes information for a resource access request | ||||
|   // +optional | ||||
|   optional ResourceAttributes resourceAttributes = 1; | ||||
|  | ||||
|   // NonResourceAttributes describes information for a non-resource access request | ||||
|   // +optional | ||||
|   optional NonResourceAttributes nonResourceAttributes = 2; | ||||
|  | ||||
|   // User is the user you're testing for. | ||||
|   // If you specify "User" but not "Groups", then is it interpreted as "What if User were not a member of any groups | ||||
|   // +optional | ||||
|   optional string user = 3; | ||||
|  | ||||
|   // Groups is the groups you're testing for. | ||||
|   // +optional | ||||
|   repeated string groups = 4; | ||||
|  | ||||
|   // Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer | ||||
|   // it needs a reflection here. | ||||
|   // +optional | ||||
|   map<string, ExtraValue> extra = 5; | ||||
|  | ||||
|   // UID information about the requesting user. | ||||
|   // +optional | ||||
|   optional string uid = 6; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewStatus | ||||
| message SubjectAccessReviewStatus { | ||||
|   // Allowed is required. True if the action would be allowed, false otherwise. | ||||
|   optional bool allowed = 1; | ||||
|  | ||||
|   // Denied is optional. True if the action would be denied, otherwise | ||||
|   // false. If both allowed is false and denied is false, then the | ||||
|   // authorizer has no opinion on whether to authorize the action. Denied | ||||
|   // may not be true if Allowed is true. | ||||
|   // +optional | ||||
|   optional bool denied = 4; | ||||
|  | ||||
|   // Reason is optional.  It indicates why a request was allowed or denied. | ||||
|   // +optional | ||||
|   optional string reason = 2; | ||||
|  | ||||
|   // EvaluationError is an indication that some error occurred during the authorization check. | ||||
|   // It is entirely possible to get an error and be able to continue determine authorization status in spite of it. | ||||
|   // For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. | ||||
|   // +optional | ||||
|   optional string evaluationError = 3; | ||||
| } | ||||
|  | ||||
| // SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on | ||||
| // the set of authorizers the server is configured with and any errors experienced during evaluation. | ||||
| // Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, | ||||
| // even if that list is incomplete. | ||||
| message SubjectRulesReviewStatus { | ||||
|   // ResourceRules is the list of actions the subject is allowed to perform on resources. | ||||
|   // The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
|   repeated ResourceRule resourceRules = 1; | ||||
|  | ||||
|   // NonResourceRules is the list of actions the subject is allowed to perform on non-resources. | ||||
|   // The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
|   repeated NonResourceRule nonResourceRules = 2; | ||||
|  | ||||
|   // Incomplete is true when the rules returned by this call are incomplete. This is most commonly | ||||
|   // encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation. | ||||
|   optional bool incomplete = 3; | ||||
|  | ||||
|   // EvaluationError can appear in combination with Rules. It indicates an error occurred during | ||||
|   // rule evaluation, such as an authorizer that doesn't support rule evaluation, and that | ||||
|   // ResourceRules and/or NonResourceRules may be incomplete. | ||||
|   // +optional | ||||
|   optional string evaluationError = 4; | ||||
| } | ||||
|  | ||||
							
								
								
									
										55
									
								
								vendor/k8s.io/api/authorization/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								vendor/k8s.io/api/authorization/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "authorization.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&SelfSubjectRulesReview{}, | ||||
| 		&SelfSubjectAccessReview{}, | ||||
| 		&SubjectAccessReview{}, | ||||
| 		&LocalSubjectAccessReview{}, | ||||
| 	) | ||||
|  | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										268
									
								
								vendor/k8s.io/api/authorization/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								vendor/k8s.io/api/authorization/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,268 @@ | ||||
| /* | ||||
| Copyright 2017 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 ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SubjectAccessReview checks whether or not a user or group can perform an action. | ||||
| type SubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated | ||||
| 	Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a | ||||
| // spec.namespace means "in all namespaces".  Self is a special case, because users should always be able | ||||
| // to check whether they can perform an action | ||||
| type SelfSubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated.  user and groups must be empty | ||||
| 	Spec SelfSubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. | ||||
| // Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions | ||||
| // checking. | ||||
| type LocalSubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace | ||||
| 	// you made the request against.  If empty, it is defaulted. | ||||
| 	Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface | ||||
| type ResourceAttributes struct { | ||||
| 	// Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces | ||||
| 	// "" (empty) is defaulted for LocalSubjectAccessReviews | ||||
| 	// "" (empty) is empty for cluster-scoped resources | ||||
| 	// "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview | ||||
| 	// +optional | ||||
| 	Namespace string `json:"namespace,omitempty" protobuf:"bytes,1,opt,name=namespace"` | ||||
| 	// Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
| 	// +optional | ||||
| 	Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` | ||||
| 	// Group is the API Group of the Resource.  "*" means all. | ||||
| 	// +optional | ||||
| 	Group string `json:"group,omitempty" protobuf:"bytes,3,opt,name=group"` | ||||
| 	// Version is the API Version of the Resource.  "*" means all. | ||||
| 	// +optional | ||||
| 	Version string `json:"version,omitempty" protobuf:"bytes,4,opt,name=version"` | ||||
| 	// Resource is one of the existing resource types.  "*" means all. | ||||
| 	// +optional | ||||
| 	Resource string `json:"resource,omitempty" protobuf:"bytes,5,opt,name=resource"` | ||||
| 	// Subresource is one of the existing resource types.  "" means none. | ||||
| 	// +optional | ||||
| 	Subresource string `json:"subresource,omitempty" protobuf:"bytes,6,opt,name=subresource"` | ||||
| 	// Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. | ||||
| 	// +optional | ||||
| 	Name string `json:"name,omitempty" protobuf:"bytes,7,opt,name=name"` | ||||
| } | ||||
|  | ||||
| // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface | ||||
| type NonResourceAttributes struct { | ||||
| 	// Path is the URL path of the request | ||||
| 	// +optional | ||||
| 	Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` | ||||
| 	// Verb is the standard HTTP verb | ||||
| 	// +optional | ||||
| 	Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| type SubjectAccessReviewSpec struct { | ||||
| 	// ResourceAuthorizationAttributes describes information for a resource access request | ||||
| 	// +optional | ||||
| 	ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` | ||||
| 	// NonResourceAttributes describes information for a non-resource access request | ||||
| 	// +optional | ||||
| 	NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` | ||||
|  | ||||
| 	// User is the user you're testing for. | ||||
| 	// If you specify "User" but not "Groups", then is it interpreted as "What if User were not a member of any groups | ||||
| 	// +optional | ||||
| 	User string `json:"user,omitempty" protobuf:"bytes,3,opt,name=user"` | ||||
| 	// Groups is the groups you're testing for. | ||||
| 	// +optional | ||||
| 	Groups []string `json:"groups,omitempty" protobuf:"bytes,4,rep,name=groups"` | ||||
| 	// Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer | ||||
| 	// it needs a reflection here. | ||||
| 	// +optional | ||||
| 	Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,5,rep,name=extra"` | ||||
| 	// UID information about the requesting user. | ||||
| 	// +optional | ||||
| 	UID string `json:"uid,omitempty" protobuf:"bytes,6,opt,name=uid"` | ||||
| } | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| type ExtraValue []string | ||||
|  | ||||
| func (t ExtraValue) String() string { | ||||
| 	return fmt.Sprintf("%v", []string(t)) | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| type SelfSubjectAccessReviewSpec struct { | ||||
| 	// ResourceAuthorizationAttributes describes information for a resource access request | ||||
| 	// +optional | ||||
| 	ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` | ||||
| 	// NonResourceAttributes describes information for a non-resource access request | ||||
| 	// +optional | ||||
| 	NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewStatus | ||||
| type SubjectAccessReviewStatus struct { | ||||
| 	// Allowed is required. True if the action would be allowed, false otherwise. | ||||
| 	Allowed bool `json:"allowed" protobuf:"varint,1,opt,name=allowed"` | ||||
| 	// Denied is optional. True if the action would be denied, otherwise | ||||
| 	// false. If both allowed is false and denied is false, then the | ||||
| 	// authorizer has no opinion on whether to authorize the action. Denied | ||||
| 	// may not be true if Allowed is true. | ||||
| 	// +optional | ||||
| 	Denied bool `json:"denied,omitempty" protobuf:"varint,4,opt,name=denied"` | ||||
| 	// Reason is optional.  It indicates why a request was allowed or denied. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,2,opt,name=reason"` | ||||
| 	// EvaluationError is an indication that some error occurred during the authorization check. | ||||
| 	// It is entirely possible to get an error and be able to continue determine authorization status in spite of it. | ||||
| 	// For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. | ||||
| 	// +optional | ||||
| 	EvaluationError string `json:"evaluationError,omitempty" protobuf:"bytes,3,opt,name=evaluationError"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. | ||||
| // The returned list of actions may be incomplete depending on the server's authorization mode, | ||||
| // and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, | ||||
| // or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to | ||||
| // drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. | ||||
| // SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server. | ||||
| type SelfSubjectRulesReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated. | ||||
| 	Spec SelfSubjectRulesReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates the set of actions a user can perform. | ||||
| 	// +optional | ||||
| 	Status SubjectRulesReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| type SelfSubjectRulesReviewSpec struct { | ||||
| 	// Namespace to evaluate rules for. Required. | ||||
| 	Namespace string `json:"namespace,omitempty" protobuf:"bytes,1,opt,name=namespace"` | ||||
| } | ||||
|  | ||||
| // SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on | ||||
| // the set of authorizers the server is configured with and any errors experienced during evaluation. | ||||
| // Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, | ||||
| // even if that list is incomplete. | ||||
| type SubjectRulesReviewStatus struct { | ||||
| 	// ResourceRules is the list of actions the subject is allowed to perform on resources. | ||||
| 	// The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
| 	ResourceRules []ResourceRule `json:"resourceRules" protobuf:"bytes,1,rep,name=resourceRules"` | ||||
| 	// NonResourceRules is the list of actions the subject is allowed to perform on non-resources. | ||||
| 	// The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
| 	NonResourceRules []NonResourceRule `json:"nonResourceRules" protobuf:"bytes,2,rep,name=nonResourceRules"` | ||||
| 	// Incomplete is true when the rules returned by this call are incomplete. This is most commonly | ||||
| 	// encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation. | ||||
| 	Incomplete bool `json:"incomplete" protobuf:"bytes,3,rep,name=incomplete"` | ||||
| 	// EvaluationError can appear in combination with Rules. It indicates an error occurred during | ||||
| 	// rule evaluation, such as an authorizer that doesn't support rule evaluation, and that | ||||
| 	// ResourceRules and/or NonResourceRules may be incomplete. | ||||
| 	// +optional | ||||
| 	EvaluationError string `json:"evaluationError,omitempty" protobuf:"bytes,4,opt,name=evaluationError"` | ||||
| } | ||||
|  | ||||
| // ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, | ||||
| // may contain duplicates, and possibly be incomplete. | ||||
| type ResourceRule struct { | ||||
| 	// Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
| 	Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` | ||||
|  | ||||
| 	// APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
| 	// the enumerated resources in any API group will be allowed.  "*" means all. | ||||
| 	// +optional | ||||
| 	APIGroups []string `json:"apiGroups,omitempty" protobuf:"bytes,2,rep,name=apiGroups"` | ||||
| 	// Resources is a list of resources this rule applies to.  "*" means all in the specified apiGroups. | ||||
| 	//  "*/foo" represents the subresource 'foo' for all resources in the specified apiGroups. | ||||
| 	// +optional | ||||
| 	Resources []string `json:"resources,omitempty" protobuf:"bytes,3,rep,name=resources"` | ||||
| 	// ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  "*" means all. | ||||
| 	// +optional | ||||
| 	ResourceNames []string `json:"resourceNames,omitempty" protobuf:"bytes,4,rep,name=resourceNames"` | ||||
| } | ||||
|  | ||||
| // NonResourceRule holds information that describes a rule for the non-resource | ||||
| type NonResourceRule struct { | ||||
| 	// Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  "*" means all. | ||||
| 	Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` | ||||
|  | ||||
| 	// NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, | ||||
| 	// final step in the path.  "*" means all. | ||||
| 	// +optional | ||||
| 	NonResourceURLs []string `json:"nonResourceURLs,omitempty" protobuf:"bytes,2,rep,name=nonResourceURLs"` | ||||
| } | ||||
							
								
								
									
										173
									
								
								vendor/k8s.io/api/authorization/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								vendor/k8s.io/api/authorization/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,173 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_LocalSubjectAccessReview = map[string]string{ | ||||
| 	"":       "LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions checking.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace you made the request against.  If empty, it is defaulted.", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (LocalSubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_LocalSubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_NonResourceAttributes = map[string]string{ | ||||
| 	"":     "NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface", | ||||
| 	"path": "Path is the URL path of the request", | ||||
| 	"verb": "Verb is the standard HTTP verb", | ||||
| } | ||||
|  | ||||
| func (NonResourceAttributes) SwaggerDoc() map[string]string { | ||||
| 	return map_NonResourceAttributes | ||||
| } | ||||
|  | ||||
| var map_NonResourceRule = map[string]string{ | ||||
| 	"":                "NonResourceRule holds information that describes a rule for the non-resource", | ||||
| 	"verbs":           "Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  \"*\" means all.", | ||||
| 	"nonResourceURLs": "NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path.  \"*\" means all.", | ||||
| } | ||||
|  | ||||
| func (NonResourceRule) SwaggerDoc() map[string]string { | ||||
| 	return map_NonResourceRule | ||||
| } | ||||
|  | ||||
| var map_ResourceAttributes = map[string]string{ | ||||
| 	"":            "ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface", | ||||
| 	"namespace":   "Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces \"\" (empty) is defaulted for LocalSubjectAccessReviews \"\" (empty) is empty for cluster-scoped resources \"\" (empty) means \"all\" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview", | ||||
| 	"verb":        "Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  \"*\" means all.", | ||||
| 	"group":       "Group is the API Group of the Resource.  \"*\" means all.", | ||||
| 	"version":     "Version is the API Version of the Resource.  \"*\" means all.", | ||||
| 	"resource":    "Resource is one of the existing resource types.  \"*\" means all.", | ||||
| 	"subresource": "Subresource is one of the existing resource types.  \"\" means none.", | ||||
| 	"name":        "Name is the name of the resource being requested for a \"get\" or deleted for a \"delete\". \"\" (empty) means all.", | ||||
| } | ||||
|  | ||||
| func (ResourceAttributes) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceAttributes | ||||
| } | ||||
|  | ||||
| var map_ResourceRule = map[string]string{ | ||||
| 	"":              "ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"verbs":         "Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  \"*\" means all.", | ||||
| 	"apiGroups":     "APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.  \"*\" means all.", | ||||
| 	"resources":     "Resources is a list of resources this rule applies to.  \"*\" means all in the specified apiGroups.\n \"*/foo\" represents the subresource 'foo' for all resources in the specified apiGroups.", | ||||
| 	"resourceNames": "ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  \"*\" means all.", | ||||
| } | ||||
|  | ||||
| func (ResourceRule) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceRule | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectAccessReview = map[string]string{ | ||||
| 	"":       "SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a spec.namespace means \"in all namespaces\".  Self is a special case, because users should always be able to check whether they can perform an action", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.  user and groups must be empty", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectAccessReviewSpec = map[string]string{ | ||||
| 	"":                      "SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes and NonResourceAuthorizationAttributes must be set", | ||||
| 	"resourceAttributes":    "ResourceAuthorizationAttributes describes information for a resource access request", | ||||
| 	"nonResourceAttributes": "NonResourceAttributes describes information for a non-resource access request", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectAccessReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectAccessReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectRulesReview = map[string]string{ | ||||
| 	"":       "SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. The returned list of actions may be incomplete depending on the server's authorization mode, and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.", | ||||
| 	"status": "Status is filled in by the server and indicates the set of actions a user can perform.", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectRulesReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectRulesReview | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectRulesReviewSpec = map[string]string{ | ||||
| 	"namespace": "Namespace to evaluate rules for. Required.", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectRulesReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectRulesReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReview = map[string]string{ | ||||
| 	"":       "SubjectAccessReview checks whether or not a user or group can perform an action.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReviewSpec = map[string]string{ | ||||
| 	"":                      "SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes and NonResourceAuthorizationAttributes must be set", | ||||
| 	"resourceAttributes":    "ResourceAuthorizationAttributes describes information for a resource access request", | ||||
| 	"nonResourceAttributes": "NonResourceAttributes describes information for a non-resource access request", | ||||
| 	"user":                  "User is the user you're testing for. If you specify \"User\" but not \"Groups\", then is it interpreted as \"What if User were not a member of any groups", | ||||
| 	"groups":                "Groups is the groups you're testing for.", | ||||
| 	"extra":                 "Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer it needs a reflection here.", | ||||
| 	"uid":                   "UID information about the requesting user.", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReviewStatus = map[string]string{ | ||||
| 	"":                "SubjectAccessReviewStatus", | ||||
| 	"allowed":         "Allowed is required. True if the action would be allowed, false otherwise.", | ||||
| 	"denied":          "Denied is optional. True if the action would be denied, otherwise false. If both allowed is false and denied is false, then the authorizer has no opinion on whether to authorize the action. Denied may not be true if Allowed is true.", | ||||
| 	"reason":          "Reason is optional.  It indicates why a request was allowed or denied.", | ||||
| 	"evaluationError": "EvaluationError is an indication that some error occurred during the authorization check. It is entirely possible to get an error and be able to continue determine authorization status in spite of it. For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request.", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReviewStatus | ||||
| } | ||||
|  | ||||
| var map_SubjectRulesReviewStatus = map[string]string{ | ||||
| 	"":                 "SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on the set of authorizers the server is configured with and any errors experienced during evaluation. Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, even if that list is incomplete.", | ||||
| 	"resourceRules":    "ResourceRules is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"nonResourceRules": "NonResourceRules is the list of actions the subject is allowed to perform on non-resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"incomplete":       "Incomplete is true when the rules returned by this call are incomplete. This is most commonly encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation.", | ||||
| 	"evaluationError":  "EvaluationError can appear in combination with Rules. It indicates an error occurred during rule evaluation, such as an authorizer that doesn't support rule evaluation, and that ResourceRules and/or NonResourceRules may be incomplete.", | ||||
| } | ||||
|  | ||||
| func (SubjectRulesReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectRulesReviewStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										385
									
								
								vendor/k8s.io/api/authorization/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										385
									
								
								vendor/k8s.io/api/authorization/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,385 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| import ( | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in ExtraValue) DeepCopyInto(out *ExtraValue) { | ||||
| 	{ | ||||
| 		in := &in | ||||
| 		*out = make(ExtraValue, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExtraValue. | ||||
| func (in ExtraValue) DeepCopy() ExtraValue { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExtraValue) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return *out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *LocalSubjectAccessReview) DeepCopyInto(out *LocalSubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new LocalSubjectAccessReview. | ||||
| func (in *LocalSubjectAccessReview) DeepCopy() *LocalSubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(LocalSubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *LocalSubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *NonResourceAttributes) DeepCopyInto(out *NonResourceAttributes) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new NonResourceAttributes. | ||||
| func (in *NonResourceAttributes) DeepCopy() *NonResourceAttributes { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(NonResourceAttributes) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *NonResourceRule) DeepCopyInto(out *NonResourceRule) { | ||||
| 	*out = *in | ||||
| 	if in.Verbs != nil { | ||||
| 		in, out := &in.Verbs, &out.Verbs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.NonResourceURLs != nil { | ||||
| 		in, out := &in.NonResourceURLs, &out.NonResourceURLs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new NonResourceRule. | ||||
| func (in *NonResourceRule) DeepCopy() *NonResourceRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(NonResourceRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceAttributes) DeepCopyInto(out *ResourceAttributes) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceAttributes. | ||||
| func (in *ResourceAttributes) DeepCopy() *ResourceAttributes { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceAttributes) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceRule) DeepCopyInto(out *ResourceRule) { | ||||
| 	*out = *in | ||||
| 	if in.Verbs != nil { | ||||
| 		in, out := &in.Verbs, &out.Verbs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.APIGroups != nil { | ||||
| 		in, out := &in.APIGroups, &out.APIGroups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Resources != nil { | ||||
| 		in, out := &in.Resources, &out.Resources | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.ResourceNames != nil { | ||||
| 		in, out := &in.ResourceNames, &out.ResourceNames | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceRule. | ||||
| func (in *ResourceRule) DeepCopy() *ResourceRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectAccessReview) DeepCopyInto(out *SelfSubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectAccessReview. | ||||
| func (in *SelfSubjectAccessReview) DeepCopy() *SelfSubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SelfSubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectAccessReviewSpec) DeepCopyInto(out *SelfSubjectAccessReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceAttributes != nil { | ||||
| 		in, out := &in.ResourceAttributes, &out.ResourceAttributes | ||||
| 		*out = new(ResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.NonResourceAttributes != nil { | ||||
| 		in, out := &in.NonResourceAttributes, &out.NonResourceAttributes | ||||
| 		*out = new(NonResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectAccessReviewSpec. | ||||
| func (in *SelfSubjectAccessReviewSpec) DeepCopy() *SelfSubjectAccessReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectAccessReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectRulesReview) DeepCopyInto(out *SelfSubjectRulesReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	out.Spec = in.Spec | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectRulesReview. | ||||
| func (in *SelfSubjectRulesReview) DeepCopy() *SelfSubjectRulesReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectRulesReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SelfSubjectRulesReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectRulesReviewSpec) DeepCopyInto(out *SelfSubjectRulesReviewSpec) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectRulesReviewSpec. | ||||
| func (in *SelfSubjectRulesReviewSpec) DeepCopy() *SelfSubjectRulesReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectRulesReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReview) DeepCopyInto(out *SubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReview. | ||||
| func (in *SubjectAccessReview) DeepCopy() *SubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReviewSpec) DeepCopyInto(out *SubjectAccessReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceAttributes != nil { | ||||
| 		in, out := &in.ResourceAttributes, &out.ResourceAttributes | ||||
| 		*out = new(ResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.NonResourceAttributes != nil { | ||||
| 		in, out := &in.NonResourceAttributes, &out.NonResourceAttributes | ||||
| 		*out = new(NonResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Groups != nil { | ||||
| 		in, out := &in.Groups, &out.Groups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Extra != nil { | ||||
| 		in, out := &in.Extra, &out.Extra | ||||
| 		*out = make(map[string]ExtraValue, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			var outVal []string | ||||
| 			if val == nil { | ||||
| 				(*out)[key] = nil | ||||
| 			} else { | ||||
| 				in, out := &val, &outVal | ||||
| 				*out = make(ExtraValue, len(*in)) | ||||
| 				copy(*out, *in) | ||||
| 			} | ||||
| 			(*out)[key] = outVal | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReviewSpec. | ||||
| func (in *SubjectAccessReviewSpec) DeepCopy() *SubjectAccessReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReviewStatus) DeepCopyInto(out *SubjectAccessReviewStatus) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReviewStatus. | ||||
| func (in *SubjectAccessReviewStatus) DeepCopy() *SubjectAccessReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectRulesReviewStatus) DeepCopyInto(out *SubjectRulesReviewStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceRules != nil { | ||||
| 		in, out := &in.ResourceRules, &out.ResourceRules | ||||
| 		*out = make([]ResourceRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.NonResourceRules != nil { | ||||
| 		in, out := &in.NonResourceRules, &out.NonResourceRules | ||||
| 		*out = make([]NonResourceRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectRulesReviewStatus. | ||||
| func (in *SubjectRulesReviewStatus) DeepCopy() *SubjectRulesReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectRulesReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										23
									
								
								vendor/k8s.io/api/authorization/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/k8s.io/api/authorization/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| // +groupName=authorization.k8s.io | ||||
|  | ||||
| package v1beta1 // import "k8s.io/api/authorization/v1beta1" | ||||
							
								
								
									
										3516
									
								
								vendor/k8s.io/api/authorization/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3516
									
								
								vendor/k8s.io/api/authorization/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										272
									
								
								vendor/k8s.io/api/authorization/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										272
									
								
								vendor/k8s.io/api/authorization/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,272 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.authorization.v1beta1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta1"; | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| message ExtraValue { | ||||
|   // items, if empty, will result in an empty slice | ||||
|  | ||||
|   repeated string items = 1; | ||||
| } | ||||
|  | ||||
| // LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. | ||||
| // Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions | ||||
| // checking. | ||||
| message LocalSubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace | ||||
|   // you made the request against.  If empty, it is defaulted. | ||||
|   optional SubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface | ||||
| message NonResourceAttributes { | ||||
|   // Path is the URL path of the request | ||||
|   // +optional | ||||
|   optional string path = 1; | ||||
|  | ||||
|   // Verb is the standard HTTP verb | ||||
|   // +optional | ||||
|   optional string verb = 2; | ||||
| } | ||||
|  | ||||
| // NonResourceRule holds information that describes a rule for the non-resource | ||||
| message NonResourceRule { | ||||
|   // Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  "*" means all. | ||||
|   repeated string verbs = 1; | ||||
|  | ||||
|   // NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, | ||||
|   // final step in the path.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string nonResourceURLs = 2; | ||||
| } | ||||
|  | ||||
| // ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface | ||||
| message ResourceAttributes { | ||||
|   // Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces | ||||
|   // "" (empty) is defaulted for LocalSubjectAccessReviews | ||||
|   // "" (empty) is empty for cluster-scoped resources | ||||
|   // "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview | ||||
|   // +optional | ||||
|   optional string namespace = 1; | ||||
|  | ||||
|   // Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
|   // +optional | ||||
|   optional string verb = 2; | ||||
|  | ||||
|   // Group is the API Group of the Resource.  "*" means all. | ||||
|   // +optional | ||||
|   optional string group = 3; | ||||
|  | ||||
|   // Version is the API Version of the Resource.  "*" means all. | ||||
|   // +optional | ||||
|   optional string version = 4; | ||||
|  | ||||
|   // Resource is one of the existing resource types.  "*" means all. | ||||
|   // +optional | ||||
|   optional string resource = 5; | ||||
|  | ||||
|   // Subresource is one of the existing resource types.  "" means none. | ||||
|   // +optional | ||||
|   optional string subresource = 6; | ||||
|  | ||||
|   // Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. | ||||
|   // +optional | ||||
|   optional string name = 7; | ||||
| } | ||||
|  | ||||
| // ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, | ||||
| // may contain duplicates, and possibly be incomplete. | ||||
| message ResourceRule { | ||||
|   // Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
|   repeated string verbs = 1; | ||||
|  | ||||
|   // APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
|   // the enumerated resources in any API group will be allowed.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string apiGroups = 2; | ||||
|  | ||||
|   // Resources is a list of resources this rule applies to.  "*" means all in the specified apiGroups. | ||||
|   //  "*/foo" represents the subresource 'foo' for all resources in the specified apiGroups. | ||||
|   // +optional | ||||
|   repeated string resources = 3; | ||||
|  | ||||
|   // ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  "*" means all. | ||||
|   // +optional | ||||
|   repeated string resourceNames = 4; | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a | ||||
| // spec.namespace means "in all namespaces".  Self is a special case, because users should always be able | ||||
| // to check whether they can perform an action | ||||
| message SelfSubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated.  user and groups must be empty | ||||
|   optional SelfSubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| message SelfSubjectAccessReviewSpec { | ||||
|   // ResourceAuthorizationAttributes describes information for a resource access request | ||||
|   // +optional | ||||
|   optional ResourceAttributes resourceAttributes = 1; | ||||
|  | ||||
|   // NonResourceAttributes describes information for a non-resource access request | ||||
|   // +optional | ||||
|   optional NonResourceAttributes nonResourceAttributes = 2; | ||||
| } | ||||
|  | ||||
| // SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. | ||||
| // The returned list of actions may be incomplete depending on the server's authorization mode, | ||||
| // and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, | ||||
| // or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to | ||||
| // drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. | ||||
| // SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server. | ||||
| message SelfSubjectRulesReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated. | ||||
|   optional SelfSubjectRulesReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates the set of actions a user can perform. | ||||
|   // +optional | ||||
|   optional SubjectRulesReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| message SelfSubjectRulesReviewSpec { | ||||
|   // Namespace to evaluate rules for. Required. | ||||
|   optional string namespace = 1; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReview checks whether or not a user or group can perform an action. | ||||
| message SubjectAccessReview { | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Spec holds information about the request being evaluated | ||||
|   optional SubjectAccessReviewSpec spec = 2; | ||||
|  | ||||
|   // Status is filled in by the server and indicates whether the request is allowed or not | ||||
|   // +optional | ||||
|   optional SubjectAccessReviewStatus status = 3; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| message SubjectAccessReviewSpec { | ||||
|   // ResourceAuthorizationAttributes describes information for a resource access request | ||||
|   // +optional | ||||
|   optional ResourceAttributes resourceAttributes = 1; | ||||
|  | ||||
|   // NonResourceAttributes describes information for a non-resource access request | ||||
|   // +optional | ||||
|   optional NonResourceAttributes nonResourceAttributes = 2; | ||||
|  | ||||
|   // User is the user you're testing for. | ||||
|   // If you specify "User" but not "Group", then is it interpreted as "What if User were not a member of any groups | ||||
|   // +optional | ||||
|   optional string user = 3; | ||||
|  | ||||
|   // Groups is the groups you're testing for. | ||||
|   // +optional | ||||
|   repeated string group = 4; | ||||
|  | ||||
|   // Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer | ||||
|   // it needs a reflection here. | ||||
|   // +optional | ||||
|   map<string, ExtraValue> extra = 5; | ||||
|  | ||||
|   // UID information about the requesting user. | ||||
|   // +optional | ||||
|   optional string uid = 6; | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewStatus | ||||
| message SubjectAccessReviewStatus { | ||||
|   // Allowed is required. True if the action would be allowed, false otherwise. | ||||
|   optional bool allowed = 1; | ||||
|  | ||||
|   // Denied is optional. True if the action would be denied, otherwise | ||||
|   // false. If both allowed is false and denied is false, then the | ||||
|   // authorizer has no opinion on whether to authorize the action. Denied | ||||
|   // may not be true if Allowed is true. | ||||
|   // +optional | ||||
|   optional bool denied = 4; | ||||
|  | ||||
|   // Reason is optional.  It indicates why a request was allowed or denied. | ||||
|   // +optional | ||||
|   optional string reason = 2; | ||||
|  | ||||
|   // EvaluationError is an indication that some error occurred during the authorization check. | ||||
|   // It is entirely possible to get an error and be able to continue determine authorization status in spite of it. | ||||
|   // For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. | ||||
|   // +optional | ||||
|   optional string evaluationError = 3; | ||||
| } | ||||
|  | ||||
| // SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on | ||||
| // the set of authorizers the server is configured with and any errors experienced during evaluation. | ||||
| // Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, | ||||
| // even if that list is incomplete. | ||||
| message SubjectRulesReviewStatus { | ||||
|   // ResourceRules is the list of actions the subject is allowed to perform on resources. | ||||
|   // The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
|   repeated ResourceRule resourceRules = 1; | ||||
|  | ||||
|   // NonResourceRules is the list of actions the subject is allowed to perform on non-resources. | ||||
|   // The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
|   repeated NonResourceRule nonResourceRules = 2; | ||||
|  | ||||
|   // Incomplete is true when the rules returned by this call are incomplete. This is most commonly | ||||
|   // encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation. | ||||
|   optional bool incomplete = 3; | ||||
|  | ||||
|   // EvaluationError can appear in combination with Rules. It indicates an error occurred during | ||||
|   // rule evaluation, such as an authorizer that doesn't support rule evaluation, and that | ||||
|   // ResourceRules and/or NonResourceRules may be incomplete. | ||||
|   // +optional | ||||
|   optional string evaluationError = 4; | ||||
| } | ||||
|  | ||||
							
								
								
									
										55
									
								
								vendor/k8s.io/api/authorization/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								vendor/k8s.io/api/authorization/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| /* | ||||
| Copyright 2015 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "authorization.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&SelfSubjectRulesReview{}, | ||||
| 		&SelfSubjectAccessReview{}, | ||||
| 		&SubjectAccessReview{}, | ||||
| 		&LocalSubjectAccessReview{}, | ||||
| 	) | ||||
|  | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										268
									
								
								vendor/k8s.io/api/authorization/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								vendor/k8s.io/api/authorization/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,268 @@ | ||||
| /* | ||||
| Copyright 2015 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SubjectAccessReview checks whether or not a user or group can perform an action. | ||||
| type SubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated | ||||
| 	Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a | ||||
| // spec.namespace means "in all namespaces".  Self is a special case, because users should always be able | ||||
| // to check whether they can perform an action | ||||
| type SelfSubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated.  user and groups must be empty | ||||
| 	Spec SelfSubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. | ||||
| // Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions | ||||
| // checking. | ||||
| type LocalSubjectAccessReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace | ||||
| 	// you made the request against.  If empty, it is defaulted. | ||||
| 	Spec SubjectAccessReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates whether the request is allowed or not | ||||
| 	// +optional | ||||
| 	Status SubjectAccessReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface | ||||
| type ResourceAttributes struct { | ||||
| 	// Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces | ||||
| 	// "" (empty) is defaulted for LocalSubjectAccessReviews | ||||
| 	// "" (empty) is empty for cluster-scoped resources | ||||
| 	// "" (empty) means "all" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview | ||||
| 	// +optional | ||||
| 	Namespace string `json:"namespace,omitempty" protobuf:"bytes,1,opt,name=namespace"` | ||||
| 	// Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
| 	// +optional | ||||
| 	Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` | ||||
| 	// Group is the API Group of the Resource.  "*" means all. | ||||
| 	// +optional | ||||
| 	Group string `json:"group,omitempty" protobuf:"bytes,3,opt,name=group"` | ||||
| 	// Version is the API Version of the Resource.  "*" means all. | ||||
| 	// +optional | ||||
| 	Version string `json:"version,omitempty" protobuf:"bytes,4,opt,name=version"` | ||||
| 	// Resource is one of the existing resource types.  "*" means all. | ||||
| 	// +optional | ||||
| 	Resource string `json:"resource,omitempty" protobuf:"bytes,5,opt,name=resource"` | ||||
| 	// Subresource is one of the existing resource types.  "" means none. | ||||
| 	// +optional | ||||
| 	Subresource string `json:"subresource,omitempty" protobuf:"bytes,6,opt,name=subresource"` | ||||
| 	// Name is the name of the resource being requested for a "get" or deleted for a "delete". "" (empty) means all. | ||||
| 	// +optional | ||||
| 	Name string `json:"name,omitempty" protobuf:"bytes,7,opt,name=name"` | ||||
| } | ||||
|  | ||||
| // NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface | ||||
| type NonResourceAttributes struct { | ||||
| 	// Path is the URL path of the request | ||||
| 	// +optional | ||||
| 	Path string `json:"path,omitempty" protobuf:"bytes,1,opt,name=path"` | ||||
| 	// Verb is the standard HTTP verb | ||||
| 	// +optional | ||||
| 	Verb string `json:"verb,omitempty" protobuf:"bytes,2,opt,name=verb"` | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| type SubjectAccessReviewSpec struct { | ||||
| 	// ResourceAuthorizationAttributes describes information for a resource access request | ||||
| 	// +optional | ||||
| 	ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` | ||||
| 	// NonResourceAttributes describes information for a non-resource access request | ||||
| 	// +optional | ||||
| 	NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` | ||||
|  | ||||
| 	// User is the user you're testing for. | ||||
| 	// If you specify "User" but not "Group", then is it interpreted as "What if User were not a member of any groups | ||||
| 	// +optional | ||||
| 	User string `json:"user,omitempty" protobuf:"bytes,3,opt,name=user"` | ||||
| 	// Groups is the groups you're testing for. | ||||
| 	// +optional | ||||
| 	Groups []string `json:"group,omitempty" protobuf:"bytes,4,rep,name=group"` | ||||
| 	// Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer | ||||
| 	// it needs a reflection here. | ||||
| 	// +optional | ||||
| 	Extra map[string]ExtraValue `json:"extra,omitempty" protobuf:"bytes,5,rep,name=extra"` | ||||
| 	// UID information about the requesting user. | ||||
| 	// +optional | ||||
| 	UID string `json:"uid,omitempty" protobuf:"bytes,6,opt,name=uid"` | ||||
| } | ||||
|  | ||||
| // ExtraValue masks the value so protobuf can generate | ||||
| // +protobuf.nullable=true | ||||
| // +protobuf.options.(gogoproto.goproto_stringer)=false | ||||
| type ExtraValue []string | ||||
|  | ||||
| func (t ExtraValue) String() string { | ||||
| 	return fmt.Sprintf("%v", []string(t)) | ||||
| } | ||||
|  | ||||
| // SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes | ||||
| // and NonResourceAuthorizationAttributes must be set | ||||
| type SelfSubjectAccessReviewSpec struct { | ||||
| 	// ResourceAuthorizationAttributes describes information for a resource access request | ||||
| 	// +optional | ||||
| 	ResourceAttributes *ResourceAttributes `json:"resourceAttributes,omitempty" protobuf:"bytes,1,opt,name=resourceAttributes"` | ||||
| 	// NonResourceAttributes describes information for a non-resource access request | ||||
| 	// +optional | ||||
| 	NonResourceAttributes *NonResourceAttributes `json:"nonResourceAttributes,omitempty" protobuf:"bytes,2,opt,name=nonResourceAttributes"` | ||||
| } | ||||
|  | ||||
| // SubjectAccessReviewStatus | ||||
| type SubjectAccessReviewStatus struct { | ||||
| 	// Allowed is required. True if the action would be allowed, false otherwise. | ||||
| 	Allowed bool `json:"allowed" protobuf:"varint,1,opt,name=allowed"` | ||||
| 	// Denied is optional. True if the action would be denied, otherwise | ||||
| 	// false. If both allowed is false and denied is false, then the | ||||
| 	// authorizer has no opinion on whether to authorize the action. Denied | ||||
| 	// may not be true if Allowed is true. | ||||
| 	// +optional | ||||
| 	Denied bool `json:"denied,omitempty" protobuf:"varint,4,opt,name=denied"` | ||||
| 	// Reason is optional.  It indicates why a request was allowed or denied. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,2,opt,name=reason"` | ||||
| 	// EvaluationError is an indication that some error occurred during the authorization check. | ||||
| 	// It is entirely possible to get an error and be able to continue determine authorization status in spite of it. | ||||
| 	// For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request. | ||||
| 	// +optional | ||||
| 	EvaluationError string `json:"evaluationError,omitempty" protobuf:"bytes,3,opt,name=evaluationError"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +genclient:noVerbs | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. | ||||
| // The returned list of actions may be incomplete depending on the server's authorization mode, | ||||
| // and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, | ||||
| // or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to | ||||
| // drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. | ||||
| // SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server. | ||||
| type SelfSubjectRulesReview struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Spec holds information about the request being evaluated. | ||||
| 	Spec SelfSubjectRulesReviewSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Status is filled in by the server and indicates the set of actions a user can perform. | ||||
| 	// +optional | ||||
| 	Status SubjectRulesReviewStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| type SelfSubjectRulesReviewSpec struct { | ||||
| 	// Namespace to evaluate rules for. Required. | ||||
| 	Namespace string `json:"namespace,omitempty" protobuf:"bytes,1,opt,name=namespace"` | ||||
| } | ||||
|  | ||||
| // SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on | ||||
| // the set of authorizers the server is configured with and any errors experienced during evaluation. | ||||
| // Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, | ||||
| // even if that list is incomplete. | ||||
| type SubjectRulesReviewStatus struct { | ||||
| 	// ResourceRules is the list of actions the subject is allowed to perform on resources. | ||||
| 	// The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
| 	ResourceRules []ResourceRule `json:"resourceRules" protobuf:"bytes,1,rep,name=resourceRules"` | ||||
| 	// NonResourceRules is the list of actions the subject is allowed to perform on non-resources. | ||||
| 	// The list ordering isn't significant, may contain duplicates, and possibly be incomplete. | ||||
| 	NonResourceRules []NonResourceRule `json:"nonResourceRules" protobuf:"bytes,2,rep,name=nonResourceRules"` | ||||
| 	// Incomplete is true when the rules returned by this call are incomplete. This is most commonly | ||||
| 	// encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation. | ||||
| 	Incomplete bool `json:"incomplete" protobuf:"bytes,3,rep,name=incomplete"` | ||||
| 	// EvaluationError can appear in combination with Rules. It indicates an error occurred during | ||||
| 	// rule evaluation, such as an authorizer that doesn't support rule evaluation, and that | ||||
| 	// ResourceRules and/or NonResourceRules may be incomplete. | ||||
| 	// +optional | ||||
| 	EvaluationError string `json:"evaluationError,omitempty" protobuf:"bytes,4,opt,name=evaluationError"` | ||||
| } | ||||
|  | ||||
| // ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, | ||||
| // may contain duplicates, and possibly be incomplete. | ||||
| type ResourceRule struct { | ||||
| 	// Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  "*" means all. | ||||
| 	Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` | ||||
|  | ||||
| 	// APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
| 	// the enumerated resources in any API group will be allowed.  "*" means all. | ||||
| 	// +optional | ||||
| 	APIGroups []string `json:"apiGroups,omitempty" protobuf:"bytes,2,rep,name=apiGroups"` | ||||
| 	// Resources is a list of resources this rule applies to.  "*" means all in the specified apiGroups. | ||||
| 	//  "*/foo" represents the subresource 'foo' for all resources in the specified apiGroups. | ||||
| 	// +optional | ||||
| 	Resources []string `json:"resources,omitempty" protobuf:"bytes,3,rep,name=resources"` | ||||
| 	// ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  "*" means all. | ||||
| 	// +optional | ||||
| 	ResourceNames []string `json:"resourceNames,omitempty" protobuf:"bytes,4,rep,name=resourceNames"` | ||||
| } | ||||
|  | ||||
| // NonResourceRule holds information that describes a rule for the non-resource | ||||
| type NonResourceRule struct { | ||||
| 	// Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  "*" means all. | ||||
| 	Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` | ||||
|  | ||||
| 	// NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, | ||||
| 	// final step in the path.  "*" means all. | ||||
| 	// +optional | ||||
| 	NonResourceURLs []string `json:"nonResourceURLs,omitempty" protobuf:"bytes,2,rep,name=nonResourceURLs"` | ||||
| } | ||||
							
								
								
									
										173
									
								
								vendor/k8s.io/api/authorization/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								vendor/k8s.io/api/authorization/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,173 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_LocalSubjectAccessReview = map[string]string{ | ||||
| 	"":       "LocalSubjectAccessReview checks whether or not a user or group can perform an action in a given namespace. Having a namespace scoped resource makes it much easier to grant namespace scoped policy that includes permissions checking.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.  spec.namespace must be equal to the namespace you made the request against.  If empty, it is defaulted.", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (LocalSubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_LocalSubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_NonResourceAttributes = map[string]string{ | ||||
| 	"":     "NonResourceAttributes includes the authorization attributes available for non-resource requests to the Authorizer interface", | ||||
| 	"path": "Path is the URL path of the request", | ||||
| 	"verb": "Verb is the standard HTTP verb", | ||||
| } | ||||
|  | ||||
| func (NonResourceAttributes) SwaggerDoc() map[string]string { | ||||
| 	return map_NonResourceAttributes | ||||
| } | ||||
|  | ||||
| var map_NonResourceRule = map[string]string{ | ||||
| 	"":                "NonResourceRule holds information that describes a rule for the non-resource", | ||||
| 	"verbs":           "Verb is a list of kubernetes non-resource API verbs, like: get, post, put, delete, patch, head, options.  \"*\" means all.", | ||||
| 	"nonResourceURLs": "NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path.  \"*\" means all.", | ||||
| } | ||||
|  | ||||
| func (NonResourceRule) SwaggerDoc() map[string]string { | ||||
| 	return map_NonResourceRule | ||||
| } | ||||
|  | ||||
| var map_ResourceAttributes = map[string]string{ | ||||
| 	"":            "ResourceAttributes includes the authorization attributes available for resource requests to the Authorizer interface", | ||||
| 	"namespace":   "Namespace is the namespace of the action being requested.  Currently, there is no distinction between no namespace and all namespaces \"\" (empty) is defaulted for LocalSubjectAccessReviews \"\" (empty) is empty for cluster-scoped resources \"\" (empty) means \"all\" for namespace scoped resources from a SubjectAccessReview or SelfSubjectAccessReview", | ||||
| 	"verb":        "Verb is a kubernetes resource API verb, like: get, list, watch, create, update, delete, proxy.  \"*\" means all.", | ||||
| 	"group":       "Group is the API Group of the Resource.  \"*\" means all.", | ||||
| 	"version":     "Version is the API Version of the Resource.  \"*\" means all.", | ||||
| 	"resource":    "Resource is one of the existing resource types.  \"*\" means all.", | ||||
| 	"subresource": "Subresource is one of the existing resource types.  \"\" means none.", | ||||
| 	"name":        "Name is the name of the resource being requested for a \"get\" or deleted for a \"delete\". \"\" (empty) means all.", | ||||
| } | ||||
|  | ||||
| func (ResourceAttributes) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceAttributes | ||||
| } | ||||
|  | ||||
| var map_ResourceRule = map[string]string{ | ||||
| 	"":              "ResourceRule is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"verbs":         "Verb is a list of kubernetes resource API verbs, like: get, list, watch, create, update, delete, proxy.  \"*\" means all.", | ||||
| 	"apiGroups":     "APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.  \"*\" means all.", | ||||
| 	"resources":     "Resources is a list of resources this rule applies to.  \"*\" means all in the specified apiGroups.\n \"*/foo\" represents the subresource 'foo' for all resources in the specified apiGroups.", | ||||
| 	"resourceNames": "ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.  \"*\" means all.", | ||||
| } | ||||
|  | ||||
| func (ResourceRule) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceRule | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectAccessReview = map[string]string{ | ||||
| 	"":       "SelfSubjectAccessReview checks whether or the current user can perform an action.  Not filling in a spec.namespace means \"in all namespaces\".  Self is a special case, because users should always be able to check whether they can perform an action", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.  user and groups must be empty", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectAccessReviewSpec = map[string]string{ | ||||
| 	"":                      "SelfSubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes and NonResourceAuthorizationAttributes must be set", | ||||
| 	"resourceAttributes":    "ResourceAuthorizationAttributes describes information for a resource access request", | ||||
| 	"nonResourceAttributes": "NonResourceAttributes describes information for a non-resource access request", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectAccessReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectAccessReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectRulesReview = map[string]string{ | ||||
| 	"":       "SelfSubjectRulesReview enumerates the set of actions the current user can perform within a namespace. The returned list of actions may be incomplete depending on the server's authorization mode, and any errors experienced during the evaluation. SelfSubjectRulesReview should be used by UIs to show/hide actions, or to quickly let an end user reason about their permissions. It should NOT Be used by external systems to drive authorization decisions as this raises confused deputy, cache lifetime/revocation, and correctness concerns. SubjectAccessReview, and LocalAccessReview are the correct way to defer authorization decisions to the API server.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated.", | ||||
| 	"status": "Status is filled in by the server and indicates the set of actions a user can perform.", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectRulesReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectRulesReview | ||||
| } | ||||
|  | ||||
| var map_SelfSubjectRulesReviewSpec = map[string]string{ | ||||
| 	"namespace": "Namespace to evaluate rules for. Required.", | ||||
| } | ||||
|  | ||||
| func (SelfSubjectRulesReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SelfSubjectRulesReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReview = map[string]string{ | ||||
| 	"":       "SubjectAccessReview checks whether or not a user or group can perform an action.", | ||||
| 	"spec":   "Spec holds information about the request being evaluated", | ||||
| 	"status": "Status is filled in by the server and indicates whether the request is allowed or not", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReview) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReview | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReviewSpec = map[string]string{ | ||||
| 	"":                      "SubjectAccessReviewSpec is a description of the access request.  Exactly one of ResourceAuthorizationAttributes and NonResourceAuthorizationAttributes must be set", | ||||
| 	"resourceAttributes":    "ResourceAuthorizationAttributes describes information for a resource access request", | ||||
| 	"nonResourceAttributes": "NonResourceAttributes describes information for a non-resource access request", | ||||
| 	"user":                  "User is the user you're testing for. If you specify \"User\" but not \"Group\", then is it interpreted as \"What if User were not a member of any groups", | ||||
| 	"group":                 "Groups is the groups you're testing for.", | ||||
| 	"extra":                 "Extra corresponds to the user.Info.GetExtra() method from the authenticator.  Since that is input to the authorizer it needs a reflection here.", | ||||
| 	"uid":                   "UID information about the requesting user.", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReviewSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReviewSpec | ||||
| } | ||||
|  | ||||
| var map_SubjectAccessReviewStatus = map[string]string{ | ||||
| 	"":                "SubjectAccessReviewStatus", | ||||
| 	"allowed":         "Allowed is required. True if the action would be allowed, false otherwise.", | ||||
| 	"denied":          "Denied is optional. True if the action would be denied, otherwise false. If both allowed is false and denied is false, then the authorizer has no opinion on whether to authorize the action. Denied may not be true if Allowed is true.", | ||||
| 	"reason":          "Reason is optional.  It indicates why a request was allowed or denied.", | ||||
| 	"evaluationError": "EvaluationError is an indication that some error occurred during the authorization check. It is entirely possible to get an error and be able to continue determine authorization status in spite of it. For instance, RBAC can be missing a role, but enough roles are still present and bound to reason about the request.", | ||||
| } | ||||
|  | ||||
| func (SubjectAccessReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectAccessReviewStatus | ||||
| } | ||||
|  | ||||
| var map_SubjectRulesReviewStatus = map[string]string{ | ||||
| 	"":                 "SubjectRulesReviewStatus contains the result of a rules check. This check can be incomplete depending on the set of authorizers the server is configured with and any errors experienced during evaluation. Because authorization rules are additive, if a rule appears in a list it's safe to assume the subject has that permission, even if that list is incomplete.", | ||||
| 	"resourceRules":    "ResourceRules is the list of actions the subject is allowed to perform on resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"nonResourceRules": "NonResourceRules is the list of actions the subject is allowed to perform on non-resources. The list ordering isn't significant, may contain duplicates, and possibly be incomplete.", | ||||
| 	"incomplete":       "Incomplete is true when the rules returned by this call are incomplete. This is most commonly encountered when an authorizer, such as an external authorizer, doesn't support rules evaluation.", | ||||
| 	"evaluationError":  "EvaluationError can appear in combination with Rules. It indicates an error occurred during rule evaluation, such as an authorizer that doesn't support rule evaluation, and that ResourceRules and/or NonResourceRules may be incomplete.", | ||||
| } | ||||
|  | ||||
| func (SubjectRulesReviewStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_SubjectRulesReviewStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										385
									
								
								vendor/k8s.io/api/authorization/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										385
									
								
								vendor/k8s.io/api/authorization/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,385 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in ExtraValue) DeepCopyInto(out *ExtraValue) { | ||||
| 	{ | ||||
| 		in := &in | ||||
| 		*out = make(ExtraValue, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExtraValue. | ||||
| func (in ExtraValue) DeepCopy() ExtraValue { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExtraValue) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return *out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *LocalSubjectAccessReview) DeepCopyInto(out *LocalSubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new LocalSubjectAccessReview. | ||||
| func (in *LocalSubjectAccessReview) DeepCopy() *LocalSubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(LocalSubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *LocalSubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *NonResourceAttributes) DeepCopyInto(out *NonResourceAttributes) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new NonResourceAttributes. | ||||
| func (in *NonResourceAttributes) DeepCopy() *NonResourceAttributes { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(NonResourceAttributes) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *NonResourceRule) DeepCopyInto(out *NonResourceRule) { | ||||
| 	*out = *in | ||||
| 	if in.Verbs != nil { | ||||
| 		in, out := &in.Verbs, &out.Verbs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.NonResourceURLs != nil { | ||||
| 		in, out := &in.NonResourceURLs, &out.NonResourceURLs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new NonResourceRule. | ||||
| func (in *NonResourceRule) DeepCopy() *NonResourceRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(NonResourceRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceAttributes) DeepCopyInto(out *ResourceAttributes) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceAttributes. | ||||
| func (in *ResourceAttributes) DeepCopy() *ResourceAttributes { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceAttributes) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceRule) DeepCopyInto(out *ResourceRule) { | ||||
| 	*out = *in | ||||
| 	if in.Verbs != nil { | ||||
| 		in, out := &in.Verbs, &out.Verbs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.APIGroups != nil { | ||||
| 		in, out := &in.APIGroups, &out.APIGroups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Resources != nil { | ||||
| 		in, out := &in.Resources, &out.Resources | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.ResourceNames != nil { | ||||
| 		in, out := &in.ResourceNames, &out.ResourceNames | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceRule. | ||||
| func (in *ResourceRule) DeepCopy() *ResourceRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectAccessReview) DeepCopyInto(out *SelfSubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectAccessReview. | ||||
| func (in *SelfSubjectAccessReview) DeepCopy() *SelfSubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SelfSubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectAccessReviewSpec) DeepCopyInto(out *SelfSubjectAccessReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceAttributes != nil { | ||||
| 		in, out := &in.ResourceAttributes, &out.ResourceAttributes | ||||
| 		*out = new(ResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.NonResourceAttributes != nil { | ||||
| 		in, out := &in.NonResourceAttributes, &out.NonResourceAttributes | ||||
| 		*out = new(NonResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectAccessReviewSpec. | ||||
| func (in *SelfSubjectAccessReviewSpec) DeepCopy() *SelfSubjectAccessReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectAccessReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectRulesReview) DeepCopyInto(out *SelfSubjectRulesReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	out.Spec = in.Spec | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectRulesReview. | ||||
| func (in *SelfSubjectRulesReview) DeepCopy() *SelfSubjectRulesReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectRulesReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SelfSubjectRulesReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SelfSubjectRulesReviewSpec) DeepCopyInto(out *SelfSubjectRulesReviewSpec) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SelfSubjectRulesReviewSpec. | ||||
| func (in *SelfSubjectRulesReviewSpec) DeepCopy() *SelfSubjectRulesReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SelfSubjectRulesReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReview) DeepCopyInto(out *SubjectAccessReview) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReview. | ||||
| func (in *SubjectAccessReview) DeepCopy() *SubjectAccessReview { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReview) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *SubjectAccessReview) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReviewSpec) DeepCopyInto(out *SubjectAccessReviewSpec) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceAttributes != nil { | ||||
| 		in, out := &in.ResourceAttributes, &out.ResourceAttributes | ||||
| 		*out = new(ResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.NonResourceAttributes != nil { | ||||
| 		in, out := &in.NonResourceAttributes, &out.NonResourceAttributes | ||||
| 		*out = new(NonResourceAttributes) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Groups != nil { | ||||
| 		in, out := &in.Groups, &out.Groups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Extra != nil { | ||||
| 		in, out := &in.Extra, &out.Extra | ||||
| 		*out = make(map[string]ExtraValue, len(*in)) | ||||
| 		for key, val := range *in { | ||||
| 			var outVal []string | ||||
| 			if val == nil { | ||||
| 				(*out)[key] = nil | ||||
| 			} else { | ||||
| 				in, out := &val, &outVal | ||||
| 				*out = make(ExtraValue, len(*in)) | ||||
| 				copy(*out, *in) | ||||
| 			} | ||||
| 			(*out)[key] = outVal | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReviewSpec. | ||||
| func (in *SubjectAccessReviewSpec) DeepCopy() *SubjectAccessReviewSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReviewSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectAccessReviewStatus) DeepCopyInto(out *SubjectAccessReviewStatus) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectAccessReviewStatus. | ||||
| func (in *SubjectAccessReviewStatus) DeepCopy() *SubjectAccessReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectAccessReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *SubjectRulesReviewStatus) DeepCopyInto(out *SubjectRulesReviewStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ResourceRules != nil { | ||||
| 		in, out := &in.ResourceRules, &out.ResourceRules | ||||
| 		*out = make([]ResourceRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.NonResourceRules != nil { | ||||
| 		in, out := &in.NonResourceRules, &out.NonResourceRules | ||||
| 		*out = make([]NonResourceRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SubjectRulesReviewStatus. | ||||
| func (in *SubjectRulesReviewStatus) DeepCopy() *SubjectRulesReviewStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(SubjectRulesReviewStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1 // import "k8s.io/api/autoscaling/v1" | ||||
							
								
								
									
										4697
									
								
								vendor/k8s.io/api/autoscaling/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4697
									
								
								vendor/k8s.io/api/autoscaling/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										415
									
								
								vendor/k8s.io/api/autoscaling/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										415
									
								
								vendor/k8s.io/api/autoscaling/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,415 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.autoscaling.v1; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/api/resource/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1"; | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| message CrossVersionObjectReference { | ||||
|   // Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds" | ||||
|   optional string kind = 1; | ||||
|  | ||||
|   // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names | ||||
|   optional string name = 2; | ||||
|  | ||||
|   // API version of the referent | ||||
|   // +optional | ||||
|   optional string apiVersion = 3; | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| message ExternalMetricSource { | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // metricSelector is used to identify a specific time series | ||||
|   // within a given metric. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector metricSelector = 2; | ||||
|  | ||||
|   // targetValue is the target value of the metric (as a quantity). | ||||
|   // Mutually exclusive with TargetAverageValue. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetValue = 3; | ||||
|  | ||||
|   // targetAverageValue is the target per-pod value of global metric (as a quantity). | ||||
|   // Mutually exclusive with TargetValue. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 4; | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| message ExternalMetricStatus { | ||||
|   // metricName is the name of a metric used for autoscaling in | ||||
|   // metric system. | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // metricSelector is used to identify a specific time series | ||||
|   // within a given metric. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector metricSelector = 2; | ||||
|  | ||||
|   // currentValue is the current value of the metric (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentValue = 3; | ||||
|  | ||||
|   // currentAverageValue is the current value of metric averaged over autoscaled pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 4; | ||||
| } | ||||
|  | ||||
| // configuration of a horizontal pod autoscaler. | ||||
| message HorizontalPodAutoscaler { | ||||
|   // Standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // behaviour of autoscaler. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerSpec spec = 2; | ||||
|  | ||||
|   // current information about the autoscaler. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerStatus status = 3; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| message HorizontalPodAutoscalerCondition { | ||||
|   // type describes the current condition | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // status is the status of the condition (True, False, Unknown) | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // lastTransitionTime is the last time the condition transitioned from | ||||
|   // one status to another | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // reason is the reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // message is a human-readable explanation containing details about | ||||
|   // the transition | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // list of horizontal pod autoscaler objects. | ||||
| message HorizontalPodAutoscalerList { | ||||
|   // Standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // list of horizontal pod autoscaler objects. | ||||
|   repeated HorizontalPodAutoscaler items = 2; | ||||
| } | ||||
|  | ||||
| // specification of a horizontal pod autoscaler. | ||||
| message HorizontalPodAutoscalerSpec { | ||||
|   // reference to scaled resource; horizontal pod autoscaler will learn the current resource consumption | ||||
|   // and will set the desired number of pods by using its Scale subresource. | ||||
|   optional CrossVersionObjectReference scaleTargetRef = 1; | ||||
|  | ||||
|   // lower limit for the number of pods that can be set by the autoscaler, default 1. | ||||
|   // +optional | ||||
|   optional int32 minReplicas = 2; | ||||
|  | ||||
|   // upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. | ||||
|   optional int32 maxReplicas = 3; | ||||
|  | ||||
|   // target average CPU utilization (represented as a percentage of requested CPU) over all the pods; | ||||
|   // if not specified the default autoscaling policy will be used. | ||||
|   // +optional | ||||
|   optional int32 targetCPUUtilizationPercentage = 4; | ||||
| } | ||||
|  | ||||
| // current status of a horizontal pod autoscaler | ||||
| message HorizontalPodAutoscalerStatus { | ||||
|   // most recent generation observed by this autoscaler. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // last time the HorizontalPodAutoscaler scaled the number of pods; | ||||
|   // used by the autoscaler to control how often the number of pods is changed. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastScaleTime = 2; | ||||
|  | ||||
|   // current number of replicas of pods managed by this autoscaler. | ||||
|   optional int32 currentReplicas = 3; | ||||
|  | ||||
|   // desired number of replicas of pods managed by this autoscaler. | ||||
|   optional int32 desiredReplicas = 4; | ||||
|  | ||||
|   // current average CPU utilization over all pods, represented as a percentage of requested CPU, | ||||
|   // e.g. 70 means that an average pod is using now 70% of its requested CPU. | ||||
|   // +optional | ||||
|   optional int32 currentCPUUtilizationPercentage = 5; | ||||
| } | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| message MetricSpec { | ||||
|   // type is the type of metric source.  It should be one of "Object", | ||||
|   // "Pods" or "Resource", each mapping to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricSource object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricSource pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricSource resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricSource external = 5; | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| message MetricStatus { | ||||
|   // type is the type of metric source.  It will be one of "Object", | ||||
|   // "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricStatus object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricStatus pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricStatus resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricStatus external = 5; | ||||
| } | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricSource { | ||||
|   // target is the described Kubernetes object. | ||||
|   optional CrossVersionObjectReference target = 1; | ||||
|  | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 2; | ||||
|  | ||||
|   // targetValue is the target value of the metric (as a quantity). | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetValue = 3; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric. | ||||
|   // When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; | ||||
|  | ||||
|   // averageValue is the target value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 5; | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricStatus { | ||||
|   // target is the described Kubernetes object. | ||||
|   optional CrossVersionObjectReference target = 1; | ||||
|  | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 2; | ||||
|  | ||||
|   // currentValue is the current value of the metric (as a quantity). | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentValue = 3; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; | ||||
|  | ||||
|   // averageValue is the current value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 5; | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| message PodsMetricSource { | ||||
|   // metricName is the name of the metric in question | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // targetAverageValue is the target value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 2; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 3; | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| message PodsMetricStatus { | ||||
|   // metricName is the name of the metric in question | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // currentAverageValue is the current value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 2; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 3; | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| message ResourceMetricSource { | ||||
|   // name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // targetAverageUtilization is the target value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods. | ||||
|   // +optional | ||||
|   optional int32 targetAverageUtilization = 2; | ||||
|  | ||||
|   // targetAverageValue is the target value of the average of the | ||||
|   // resource metric across all relevant pods, as a raw value (instead of as | ||||
|   // a percentage of the request), similar to the "pods" metric source type. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 3; | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| message ResourceMetricStatus { | ||||
|   // name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // currentAverageUtilization is the current value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods.  It will only be | ||||
|   // present if `targetAverageValue` was set in the corresponding metric | ||||
|   // specification. | ||||
|   // +optional | ||||
|   optional int32 currentAverageUtilization = 2; | ||||
|  | ||||
|   // currentAverageValue is the current value of the average of the | ||||
|   // resource metric across all relevant pods, as a raw value (instead of as | ||||
|   // a percentage of the request), similar to the "pods" metric source type. | ||||
|   // It will always be set, regardless of the corresponding metric specification. | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 3; | ||||
| } | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| message Scale { | ||||
|   // Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional ScaleSpec spec = 2; | ||||
|  | ||||
|   // current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only. | ||||
|   // +optional | ||||
|   optional ScaleStatus status = 3; | ||||
| } | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource. | ||||
| message ScaleSpec { | ||||
|   // desired number of instances for the scaled object. | ||||
|   // +optional | ||||
|   optional int32 replicas = 1; | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| message ScaleStatus { | ||||
|   // actual number of observed instances of the scaled object. | ||||
|   optional int32 replicas = 1; | ||||
|  | ||||
|   // label query over pods that should match the replicas count. This is same | ||||
|   // as the label selector but in the string format to avoid introspection | ||||
|   // by clients. The string will be in the same format as the query-param syntax. | ||||
|   // More info about label selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
|   // +optional | ||||
|   optional string selector = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										53
									
								
								vendor/k8s.io/api/autoscaling/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								vendor/k8s.io/api/autoscaling/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| /* | ||||
| Copyright 2016 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 ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "autoscaling" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&HorizontalPodAutoscaler{}, | ||||
| 		&HorizontalPodAutoscalerList{}, | ||||
| 		&Scale{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										428
									
								
								vendor/k8s.io/api/autoscaling/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										428
									
								
								vendor/k8s.io/api/autoscaling/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,428 @@ | ||||
| /* | ||||
| Copyright 2016 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 ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	"k8s.io/apimachinery/pkg/api/resource" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| type CrossVersionObjectReference struct { | ||||
| 	// Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/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 | ||||
| 	Name string `json:"name" protobuf:"bytes,2,opt,name=name"` | ||||
| 	// API version of the referent | ||||
| 	// +optional | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` | ||||
| } | ||||
|  | ||||
| // specification of a horizontal pod autoscaler. | ||||
| type HorizontalPodAutoscalerSpec struct { | ||||
| 	// reference to scaled resource; horizontal pod autoscaler will learn the current resource consumption | ||||
| 	// and will set the desired number of pods by using its Scale subresource. | ||||
| 	ScaleTargetRef CrossVersionObjectReference `json:"scaleTargetRef" protobuf:"bytes,1,opt,name=scaleTargetRef"` | ||||
| 	// lower limit for the number of pods that can be set by the autoscaler, default 1. | ||||
| 	// +optional | ||||
| 	MinReplicas *int32 `json:"minReplicas,omitempty" protobuf:"varint,2,opt,name=minReplicas"` | ||||
| 	// upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas. | ||||
| 	MaxReplicas int32 `json:"maxReplicas" protobuf:"varint,3,opt,name=maxReplicas"` | ||||
| 	// target average CPU utilization (represented as a percentage of requested CPU) over all the pods; | ||||
| 	// if not specified the default autoscaling policy will be used. | ||||
| 	// +optional | ||||
| 	TargetCPUUtilizationPercentage *int32 `json:"targetCPUUtilizationPercentage,omitempty" protobuf:"varint,4,opt,name=targetCPUUtilizationPercentage"` | ||||
| } | ||||
|  | ||||
| // current status of a horizontal pod autoscaler | ||||
| type HorizontalPodAutoscalerStatus struct { | ||||
| 	// most recent generation observed by this autoscaler. | ||||
| 	// +optional | ||||
| 	ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// last time the HorizontalPodAutoscaler scaled the number of pods; | ||||
| 	// used by the autoscaler to control how often the number of pods is changed. | ||||
| 	// +optional | ||||
| 	LastScaleTime *metav1.Time `json:"lastScaleTime,omitempty" protobuf:"bytes,2,opt,name=lastScaleTime"` | ||||
|  | ||||
| 	// current number of replicas of pods managed by this autoscaler. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas" protobuf:"varint,3,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// desired number of replicas of pods managed by this autoscaler. | ||||
| 	DesiredReplicas int32 `json:"desiredReplicas" protobuf:"varint,4,opt,name=desiredReplicas"` | ||||
|  | ||||
| 	// current average CPU utilization over all pods, represented as a percentage of requested CPU, | ||||
| 	// e.g. 70 means that an average pod is using now 70% of its requested CPU. | ||||
| 	// +optional | ||||
| 	CurrentCPUUtilizationPercentage *int32 `json:"currentCPUUtilizationPercentage,omitempty" protobuf:"varint,5,opt,name=currentCPUUtilizationPercentage"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // configuration of a horizontal pod autoscaler. | ||||
| type HorizontalPodAutoscaler struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// behaviour of autoscaler. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// current information about the autoscaler. | ||||
| 	// +optional | ||||
| 	Status HorizontalPodAutoscalerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // list of horizontal pod autoscaler objects. | ||||
| type HorizontalPodAutoscalerList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// list of horizontal pod autoscaler objects. | ||||
| 	Items []HorizontalPodAutoscaler `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Scale represents a scaling request for a resource. | ||||
| type Scale struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec ScaleSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only. | ||||
| 	// +optional | ||||
| 	Status ScaleStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // ScaleSpec describes the attributes of a scale subresource. | ||||
| type ScaleSpec struct { | ||||
| 	// desired number of instances for the scaled object. | ||||
| 	// +optional | ||||
| 	Replicas int32 `json:"replicas,omitempty" protobuf:"varint,1,opt,name=replicas"` | ||||
| } | ||||
|  | ||||
| // ScaleStatus represents the current status of a scale subresource. | ||||
| type ScaleStatus struct { | ||||
| 	// actual number of observed instances of the scaled object. | ||||
| 	Replicas int32 `json:"replicas" protobuf:"varint,1,opt,name=replicas"` | ||||
|  | ||||
| 	// label query over pods that should match the replicas count. This is same | ||||
| 	// as the label selector but in the string format to avoid introspection | ||||
| 	// by clients. The string will be in the same format as the query-param syntax. | ||||
| 	// More info about label selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors | ||||
| 	// +optional | ||||
| 	Selector string `json:"selector,omitempty" protobuf:"bytes,2,opt,name=selector"` | ||||
| } | ||||
|  | ||||
| // the types below are used in the alpha metrics annotation | ||||
|  | ||||
| // MetricSourceType indicates the type of metric. | ||||
| type MetricSourceType string | ||||
|  | ||||
| var ( | ||||
| 	// ObjectMetricSourceType is a metric describing a kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	ObjectMetricSourceType MetricSourceType = "Object" | ||||
| 	// PodsMetricSourceType is a metric describing each pod in the current scale | ||||
| 	// target (for example, transactions-processed-per-second).  The values | ||||
| 	// will be averaged together before being compared to the target value. | ||||
| 	PodsMetricSourceType MetricSourceType = "Pods" | ||||
| 	// ResourceMetricSourceType is a resource metric known to Kubernetes, as | ||||
| 	// specified in requests and limits, describing each pod in the current | ||||
| 	// scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics (the "pods" source). | ||||
| 	ResourceMetricSourceType MetricSourceType = "Resource" | ||||
| 	// ExternalMetricSourceType is a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	ExternalMetricSourceType MetricSourceType = "External" | ||||
| ) | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| type MetricSpec struct { | ||||
| 	// type is the type of metric source.  It should be one of "Object", | ||||
| 	// "Pods" or "Resource", each mapping to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricSource `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricSource `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricSource `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricSource `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricSource struct { | ||||
| 	// target is the described Kubernetes object. | ||||
| 	Target CrossVersionObjectReference `json:"target" protobuf:"bytes,1,name=target"` | ||||
|  | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,2,name=metricName"` | ||||
| 	// targetValue is the target value of the metric (as a quantity). | ||||
| 	TargetValue resource.Quantity `json:"targetValue" protobuf:"bytes,3,name=targetValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric. | ||||
| 	// When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,name=selector"` | ||||
| 	// averageValue is the target value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,5,name=averageValue"` | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| type PodsMetricSource struct { | ||||
| 	// metricName is the name of the metric in question | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// targetAverageValue is the target value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	TargetAverageValue resource.Quantity `json:"targetAverageValue" protobuf:"bytes,2,name=targetAverageValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,3,name=selector"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| type ResourceMetricSource struct { | ||||
| 	// name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// targetAverageUtilization is the target value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods. | ||||
| 	// +optional | ||||
| 	TargetAverageUtilization *int32 `json:"targetAverageUtilization,omitempty" protobuf:"varint,2,opt,name=targetAverageUtilization"` | ||||
| 	// targetAverageValue is the target value of the average of the | ||||
| 	// resource metric across all relevant pods, as a raw value (instead of as | ||||
| 	// a percentage of the request), similar to the "pods" metric source type. | ||||
| 	// +optional | ||||
| 	TargetAverageValue *resource.Quantity `json:"targetAverageValue,omitempty" protobuf:"bytes,3,opt,name=targetAverageValue"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| type ExternalMetricSource struct { | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// metricSelector is used to identify a specific time series | ||||
| 	// within a given metric. | ||||
| 	// +optional | ||||
| 	MetricSelector *metav1.LabelSelector `json:"metricSelector,omitempty" protobuf:"bytes,2,opt,name=metricSelector"` | ||||
| 	// targetValue is the target value of the metric (as a quantity). | ||||
| 	// Mutually exclusive with TargetAverageValue. | ||||
| 	// +optional | ||||
| 	TargetValue *resource.Quantity `json:"targetValue,omitempty" protobuf:"bytes,3,opt,name=targetValue"` | ||||
| 	// targetAverageValue is the target per-pod value of global metric (as a quantity). | ||||
| 	// Mutually exclusive with TargetValue. | ||||
| 	// +optional | ||||
| 	TargetAverageValue *resource.Quantity `json:"targetAverageValue,omitempty" protobuf:"bytes,4,opt,name=targetAverageValue"` | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| type MetricStatus struct { | ||||
| 	// type is the type of metric source.  It will be one of "Object", | ||||
| 	// "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricStatus `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricStatus `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricStatus `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricStatus `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerConditionType are the valid conditions of | ||||
| // a HorizontalPodAutoscaler. | ||||
| type HorizontalPodAutoscalerConditionType string | ||||
|  | ||||
| var ( | ||||
| 	// ScalingActive indicates that the HPA controller is able to scale if necessary: | ||||
| 	// it's correctly configured, can fetch the desired metrics, and isn't disabled. | ||||
| 	ScalingActive HorizontalPodAutoscalerConditionType = "ScalingActive" | ||||
| 	// AbleToScale indicates a lack of transient issues which prevent scaling from occurring, | ||||
| 	// such as being in a backoff window, or being unable to access/update the target scale. | ||||
| 	AbleToScale HorizontalPodAutoscalerConditionType = "AbleToScale" | ||||
| 	// ScalingLimited indicates that the calculated scale based on metrics would be above or | ||||
| 	// below the range for the HPA, and has thus been capped. | ||||
| 	ScalingLimited HorizontalPodAutoscalerConditionType = "ScalingLimited" | ||||
| ) | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| type HorizontalPodAutoscalerCondition struct { | ||||
| 	// type describes the current condition | ||||
| 	Type HorizontalPodAutoscalerConditionType `json:"type" protobuf:"bytes,1,name=type"` | ||||
| 	// status is the status of the condition (True, False, Unknown) | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,name=status"` | ||||
| 	// lastTransitionTime is the last time the condition transitioned from | ||||
| 	// one status to another | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// reason is the reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// message is a human-readable explanation containing details about | ||||
| 	// the transition | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricStatus struct { | ||||
| 	// target is the described Kubernetes object. | ||||
| 	Target CrossVersionObjectReference `json:"target" protobuf:"bytes,1,name=target"` | ||||
|  | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,2,name=metricName"` | ||||
| 	// currentValue is the current value of the metric (as a quantity). | ||||
| 	CurrentValue resource.Quantity `json:"currentValue" protobuf:"bytes,3,name=currentValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,name=selector"` | ||||
| 	// averageValue is the current value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,5,name=averageValue"` | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| type PodsMetricStatus struct { | ||||
| 	// metricName is the name of the metric in question | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// currentAverageValue is the current value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	CurrentAverageValue resource.Quantity `json:"currentAverageValue" protobuf:"bytes,2,name=currentAverageValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,3,name=selector"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| type ResourceMetricStatus struct { | ||||
| 	// name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// currentAverageUtilization is the current value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods.  It will only be | ||||
| 	// present if `targetAverageValue` was set in the corresponding metric | ||||
| 	// specification. | ||||
| 	// +optional | ||||
| 	CurrentAverageUtilization *int32 `json:"currentAverageUtilization,omitempty" protobuf:"bytes,2,opt,name=currentAverageUtilization"` | ||||
| 	// currentAverageValue is the current value of the average of the | ||||
| 	// resource metric across all relevant pods, as a raw value (instead of as | ||||
| 	// a percentage of the request), similar to the "pods" metric source type. | ||||
| 	// It will always be set, regardless of the corresponding metric specification. | ||||
| 	CurrentAverageValue resource.Quantity `json:"currentAverageValue" protobuf:"bytes,3,name=currentAverageValue"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| type ExternalMetricStatus struct { | ||||
| 	// metricName is the name of a metric used for autoscaling in | ||||
| 	// metric system. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// metricSelector is used to identify a specific time series | ||||
| 	// within a given metric. | ||||
| 	// +optional | ||||
| 	MetricSelector *metav1.LabelSelector `json:"metricSelector,omitempty" protobuf:"bytes,2,opt,name=metricSelector"` | ||||
| 	// currentValue is the current value of the metric (as a quantity) | ||||
| 	CurrentValue resource.Quantity `json:"currentValue" protobuf:"bytes,3,name=currentValue"` | ||||
| 	// currentAverageValue is the current value of metric averaged over autoscaled pods. | ||||
| 	// +optional | ||||
| 	CurrentAverageValue *resource.Quantity `json:"currentAverageValue,omitempty" protobuf:"bytes,4,opt,name=currentAverageValue"` | ||||
| } | ||||
							
								
								
									
										250
									
								
								vendor/k8s.io/api/autoscaling/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										250
									
								
								vendor/k8s.io/api/autoscaling/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,250 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_CrossVersionObjectReference = map[string]string{ | ||||
| 	"":           "CrossVersionObjectReference contains enough information to let you identify the referred resource.", | ||||
| 	"kind":       "Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds\"", | ||||
| 	"name":       "Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names", | ||||
| 	"apiVersion": "API version of the referent", | ||||
| } | ||||
|  | ||||
| func (CrossVersionObjectReference) SwaggerDoc() map[string]string { | ||||
| 	return map_CrossVersionObjectReference | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricSource = map[string]string{ | ||||
| 	"":                   "ExternalMetricSource indicates how to scale on a metric not associated with any Kubernetes object (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| 	"metricName":         "metricName is the name of the metric in question.", | ||||
| 	"metricSelector":     "metricSelector is used to identify a specific time series within a given metric.", | ||||
| 	"targetValue":        "targetValue is the target value of the metric (as a quantity). Mutually exclusive with TargetAverageValue.", | ||||
| 	"targetAverageValue": "targetAverageValue is the target per-pod value of global metric (as a quantity). Mutually exclusive with TargetValue.", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricSource | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricStatus = map[string]string{ | ||||
| 	"":                    "ExternalMetricStatus indicates the current value of a global metric not associated with any Kubernetes object.", | ||||
| 	"metricName":          "metricName is the name of a metric used for autoscaling in metric system.", | ||||
| 	"metricSelector":      "metricSelector is used to identify a specific time series within a given metric.", | ||||
| 	"currentValue":        "currentValue is the current value of the metric (as a quantity)", | ||||
| 	"currentAverageValue": "currentAverageValue is the current value of metric averaged over autoscaled pods.", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricStatus | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscaler = map[string]string{ | ||||
| 	"":         "configuration of a horizontal pod autoscaler.", | ||||
| 	"metadata": "Standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "behaviour of autoscaler. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "current information about the autoscaler.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscaler) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscaler | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerCondition = map[string]string{ | ||||
| 	"":                   "HorizontalPodAutoscalerCondition describes the state of a HorizontalPodAutoscaler at a certain point.", | ||||
| 	"type":               "type describes the current condition", | ||||
| 	"status":             "status is the status of the condition (True, False, Unknown)", | ||||
| 	"lastTransitionTime": "lastTransitionTime is the last time the condition transitioned from one status to another", | ||||
| 	"reason":             "reason is the reason for the condition's last transition.", | ||||
| 	"message":            "message is a human-readable explanation containing details about the transition", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerCondition | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerList = map[string]string{ | ||||
| 	"":         "list of horizontal pod autoscaler objects.", | ||||
| 	"metadata": "Standard list metadata.", | ||||
| 	"items":    "list of horizontal pod autoscaler objects.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerList) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerList | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerSpec = map[string]string{ | ||||
| 	"":                               "specification of a horizontal pod autoscaler.", | ||||
| 	"scaleTargetRef":                 "reference to scaled resource; horizontal pod autoscaler will learn the current resource consumption and will set the desired number of pods by using its Scale subresource.", | ||||
| 	"minReplicas":                    "lower limit for the number of pods that can be set by the autoscaler, default 1.", | ||||
| 	"maxReplicas":                    "upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas.", | ||||
| 	"targetCPUUtilizationPercentage": "target average CPU utilization (represented as a percentage of requested CPU) over all the pods; if not specified the default autoscaling policy will be used.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerSpec | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerStatus = map[string]string{ | ||||
| 	"":                                "current status of a horizontal pod autoscaler", | ||||
| 	"observedGeneration":              "most recent generation observed by this autoscaler.", | ||||
| 	"lastScaleTime":                   "last time the HorizontalPodAutoscaler scaled the number of pods; used by the autoscaler to control how often the number of pods is changed.", | ||||
| 	"currentReplicas":                 "current number of replicas of pods managed by this autoscaler.", | ||||
| 	"desiredReplicas":                 "desired number of replicas of pods managed by this autoscaler.", | ||||
| 	"currentCPUUtilizationPercentage": "current average CPU utilization over all pods, represented as a percentage of requested CPU, e.g. 70 means that an average pod is using now 70% of its requested CPU.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerStatus | ||||
| } | ||||
|  | ||||
| var map_MetricSpec = map[string]string{ | ||||
| 	"":         "MetricSpec specifies how to scale based on a single metric (only `type` and one other matching field should be set at once).", | ||||
| 	"type":     "type is the type of metric source.  It should be one of \"Object\", \"Pods\" or \"Resource\", each mapping to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricSpec | ||||
| } | ||||
|  | ||||
| var map_MetricStatus = map[string]string{ | ||||
| 	"":         "MetricStatus describes the last-read state of a single metric.", | ||||
| 	"type":     "type is the type of metric source.  It will be one of \"Object\", \"Pods\" or \"Resource\", each corresponds to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricStatus | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricSource = map[string]string{ | ||||
| 	"":             "ObjectMetricSource indicates how to scale on a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"target":       "target is the described Kubernetes object.", | ||||
| 	"metricName":   "metricName is the name of the metric in question.", | ||||
| 	"targetValue":  "targetValue is the target value of the metric (as a quantity).", | ||||
| 	"selector":     "selector is the string-encoded form of a standard kubernetes label selector for the given metric. When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping When unset, just the metricName will be used to gather metrics.", | ||||
| 	"averageValue": "averageValue is the target value of the average of the metric across all relevant pods (as a quantity)", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricSource | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricStatus = map[string]string{ | ||||
| 	"":             "ObjectMetricStatus indicates the current value of a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"target":       "target is the described Kubernetes object.", | ||||
| 	"metricName":   "metricName is the name of the metric in question.", | ||||
| 	"currentValue": "currentValue is the current value of the metric (as a quantity).", | ||||
| 	"selector":     "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.", | ||||
| 	"averageValue": "averageValue is the current value of the average of the metric across all relevant pods (as a quantity)", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricStatus | ||||
| } | ||||
|  | ||||
| var map_PodsMetricSource = map[string]string{ | ||||
| 	"":                   "PodsMetricSource indicates how to scale on a metric describing each pod in the current scale target (for example, transactions-processed-per-second). The values will be averaged together before being compared to the target value.", | ||||
| 	"metricName":         "metricName is the name of the metric in question", | ||||
| 	"targetAverageValue": "targetAverageValue is the target value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"selector":           "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping When unset, just the metricName will be used to gather metrics.", | ||||
| } | ||||
|  | ||||
| func (PodsMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricSource | ||||
| } | ||||
|  | ||||
| var map_PodsMetricStatus = map[string]string{ | ||||
| 	"":                    "PodsMetricStatus indicates the current value of a metric describing each pod in the current scale target (for example, transactions-processed-per-second).", | ||||
| 	"metricName":          "metricName is the name of the metric in question", | ||||
| 	"currentAverageValue": "currentAverageValue is the current value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"selector":            "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.", | ||||
| } | ||||
|  | ||||
| func (PodsMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricStatus | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricSource = map[string]string{ | ||||
| 	"":                         "ResourceMetricSource indicates how to scale on a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  The values will be averaged together before being compared to the target.  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.  Only one \"target\" type should be set.", | ||||
| 	"name":                     "name is the name of the resource in question.", | ||||
| 	"targetAverageUtilization": "targetAverageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.", | ||||
| 	"targetAverageValue":       "targetAverageValue is the target value of the average of the resource metric across all relevant pods, as a raw value (instead of as a percentage of the request), similar to the \"pods\" metric source type.", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricSource | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricStatus = map[string]string{ | ||||
| 	"":                          "ResourceMetricStatus indicates the current value of a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"name":                      "name is the name of the resource in question.", | ||||
| 	"currentAverageUtilization": "currentAverageUtilization is the current value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.  It will only be present if `targetAverageValue` was set in the corresponding metric specification.", | ||||
| 	"currentAverageValue":       "currentAverageValue is the current value of the average of the resource metric across all relevant pods, as a raw value (instead of as a percentage of the request), similar to the \"pods\" metric source type. It will always be set, regardless of the corresponding metric specification.", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricStatus | ||||
| } | ||||
|  | ||||
| var map_Scale = map[string]string{ | ||||
| 	"":         "Scale represents a scaling request for a resource.", | ||||
| 	"metadata": "Standard object metadata; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata.", | ||||
| 	"spec":     "defines the behavior of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "current status of the scale. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. Read-only.", | ||||
| } | ||||
|  | ||||
| func (Scale) SwaggerDoc() map[string]string { | ||||
| 	return map_Scale | ||||
| } | ||||
|  | ||||
| var map_ScaleSpec = map[string]string{ | ||||
| 	"":         "ScaleSpec describes the attributes of a scale subresource.", | ||||
| 	"replicas": "desired number of instances for the scaled object.", | ||||
| } | ||||
|  | ||||
| func (ScaleSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleSpec | ||||
| } | ||||
|  | ||||
| var map_ScaleStatus = map[string]string{ | ||||
| 	"":         "ScaleStatus represents the current status of a scale subresource.", | ||||
| 	"replicas": "actual number of observed instances of the scaled object.", | ||||
| 	"selector": "label query over pods that should match the replicas count. This is same as the label selector but in the string format to avoid introspection by clients. The string will be in the same format as the query-param syntax. More info about label selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors", | ||||
| } | ||||
|  | ||||
| func (ScaleStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ScaleStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										515
									
								
								vendor/k8s.io/api/autoscaling/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										515
									
								
								vendor/k8s.io/api/autoscaling/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,515 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CrossVersionObjectReference) DeepCopyInto(out *CrossVersionObjectReference) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CrossVersionObjectReference. | ||||
| func (in *CrossVersionObjectReference) DeepCopy() *CrossVersionObjectReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CrossVersionObjectReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricSource) DeepCopyInto(out *ExternalMetricSource) { | ||||
| 	*out = *in | ||||
| 	if in.MetricSelector != nil { | ||||
| 		in, out := &in.MetricSelector, &out.MetricSelector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.TargetValue != nil { | ||||
| 		in, out := &in.TargetValue, &out.TargetValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.TargetAverageValue != nil { | ||||
| 		in, out := &in.TargetAverageValue, &out.TargetAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricSource. | ||||
| func (in *ExternalMetricSource) DeepCopy() *ExternalMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricStatus) DeepCopyInto(out *ExternalMetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.MetricSelector != nil { | ||||
| 		in, out := &in.MetricSelector, &out.MetricSelector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	out.CurrentValue = in.CurrentValue.DeepCopy() | ||||
| 	if in.CurrentAverageValue != nil { | ||||
| 		in, out := &in.CurrentAverageValue, &out.CurrentAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricStatus. | ||||
| func (in *ExternalMetricStatus) DeepCopy() *ExternalMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyInto(out *HorizontalPodAutoscaler) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscaler. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopy() *HorizontalPodAutoscaler { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscaler) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopyInto(out *HorizontalPodAutoscalerCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerCondition. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopy() *HorizontalPodAutoscalerCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyInto(out *HorizontalPodAutoscalerList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]HorizontalPodAutoscaler, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerList. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopy() *HorizontalPodAutoscalerList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopyInto(out *HorizontalPodAutoscalerSpec) { | ||||
| 	*out = *in | ||||
| 	out.ScaleTargetRef = in.ScaleTargetRef | ||||
| 	if in.MinReplicas != nil { | ||||
| 		in, out := &in.MinReplicas, &out.MinReplicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.TargetCPUUtilizationPercentage != nil { | ||||
| 		in, out := &in.TargetCPUUtilizationPercentage, &out.TargetCPUUtilizationPercentage | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerSpec. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopy() *HorizontalPodAutoscalerSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopyInto(out *HorizontalPodAutoscalerStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ObservedGeneration != nil { | ||||
| 		in, out := &in.ObservedGeneration, &out.ObservedGeneration | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.LastScaleTime != nil { | ||||
| 		in, out := &in.LastScaleTime, &out.LastScaleTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	if in.CurrentCPUUtilizationPercentage != nil { | ||||
| 		in, out := &in.CurrentCPUUtilizationPercentage, &out.CurrentCPUUtilizationPercentage | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerStatus. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopy() *HorizontalPodAutoscalerStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricSpec) DeepCopyInto(out *MetricSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricSpec. | ||||
| func (in *MetricSpec) DeepCopy() *MetricSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricStatus) DeepCopyInto(out *MetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricStatus. | ||||
| func (in *MetricStatus) DeepCopy() *MetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricSource) DeepCopyInto(out *ObjectMetricSource) { | ||||
| 	*out = *in | ||||
| 	out.Target = in.Target | ||||
| 	out.TargetValue = in.TargetValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricSource. | ||||
| func (in *ObjectMetricSource) DeepCopy() *ObjectMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricStatus) DeepCopyInto(out *ObjectMetricStatus) { | ||||
| 	*out = *in | ||||
| 	out.Target = in.Target | ||||
| 	out.CurrentValue = in.CurrentValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricStatus. | ||||
| func (in *ObjectMetricStatus) DeepCopy() *ObjectMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricSource) DeepCopyInto(out *PodsMetricSource) { | ||||
| 	*out = *in | ||||
| 	out.TargetAverageValue = in.TargetAverageValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricSource. | ||||
| func (in *PodsMetricSource) DeepCopy() *PodsMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricStatus) DeepCopyInto(out *PodsMetricStatus) { | ||||
| 	*out = *in | ||||
| 	out.CurrentAverageValue = in.CurrentAverageValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricStatus. | ||||
| func (in *PodsMetricStatus) DeepCopy() *PodsMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricSource) DeepCopyInto(out *ResourceMetricSource) { | ||||
| 	*out = *in | ||||
| 	if in.TargetAverageUtilization != nil { | ||||
| 		in, out := &in.TargetAverageUtilization, &out.TargetAverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.TargetAverageValue != nil { | ||||
| 		in, out := &in.TargetAverageValue, &out.TargetAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricSource. | ||||
| func (in *ResourceMetricSource) DeepCopy() *ResourceMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricStatus) DeepCopyInto(out *ResourceMetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CurrentAverageUtilization != nil { | ||||
| 		in, out := &in.CurrentAverageUtilization, &out.CurrentAverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	out.CurrentAverageValue = in.CurrentAverageValue.DeepCopy() | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricStatus. | ||||
| func (in *ResourceMetricStatus) DeepCopy() *ResourceMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Scale) DeepCopyInto(out *Scale) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	out.Spec = in.Spec | ||||
| 	out.Status = in.Status | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Scale. | ||||
| func (in *Scale) DeepCopy() *Scale { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Scale) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Scale) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleSpec) DeepCopyInto(out *ScaleSpec) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleSpec. | ||||
| func (in *ScaleSpec) DeepCopy() *ScaleSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ScaleStatus) DeepCopyInto(out *ScaleStatus) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ScaleStatus. | ||||
| func (in *ScaleStatus) DeepCopy() *ScaleStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ScaleStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v2beta1 // import "k8s.io/api/autoscaling/v2beta1" | ||||
							
								
								
									
										4313
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4313
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										397
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										397
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,397 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.autoscaling.v2beta1; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/api/resource/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v2beta1"; | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| message CrossVersionObjectReference { | ||||
|   // Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds" | ||||
|   optional string kind = 1; | ||||
|  | ||||
|   // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names | ||||
|   optional string name = 2; | ||||
|  | ||||
|   // API version of the referent | ||||
|   // +optional | ||||
|   optional string apiVersion = 3; | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| // Exactly one "target" type should be set. | ||||
| message ExternalMetricSource { | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // metricSelector is used to identify a specific time series | ||||
|   // within a given metric. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector metricSelector = 2; | ||||
|  | ||||
|   // targetValue is the target value of the metric (as a quantity). | ||||
|   // Mutually exclusive with TargetAverageValue. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetValue = 3; | ||||
|  | ||||
|   // targetAverageValue is the target per-pod value of global metric (as a quantity). | ||||
|   // Mutually exclusive with TargetValue. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 4; | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| message ExternalMetricStatus { | ||||
|   // metricName is the name of a metric used for autoscaling in | ||||
|   // metric system. | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // metricSelector is used to identify a specific time series | ||||
|   // within a given metric. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector metricSelector = 2; | ||||
|  | ||||
|   // currentValue is the current value of the metric (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentValue = 3; | ||||
|  | ||||
|   // currentAverageValue is the current value of metric averaged over autoscaled pods. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 4; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscaler is the configuration for a horizontal pod | ||||
| // autoscaler, which automatically manages the replica count of any resource | ||||
| // implementing the scale subresource based on the metrics specified. | ||||
| message HorizontalPodAutoscaler { | ||||
|   // metadata is the standard object metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // spec is the specification for the behaviour of the autoscaler. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerSpec spec = 2; | ||||
|  | ||||
|   // status is the current information about the autoscaler. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerStatus status = 3; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| message HorizontalPodAutoscalerCondition { | ||||
|   // type describes the current condition | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // status is the status of the condition (True, False, Unknown) | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // lastTransitionTime is the last time the condition transitioned from | ||||
|   // one status to another | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // reason is the reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // message is a human-readable explanation containing details about | ||||
|   // the transition | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscaler is a list of horizontal pod autoscaler objects. | ||||
| message HorizontalPodAutoscalerList { | ||||
|   // metadata is the standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // items is the list of horizontal pod autoscaler objects. | ||||
|   repeated HorizontalPodAutoscaler items = 2; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler. | ||||
| message HorizontalPodAutoscalerSpec { | ||||
|   // scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics | ||||
|   // should be collected, as well as to actually change the replica count. | ||||
|   optional CrossVersionObjectReference scaleTargetRef = 1; | ||||
|  | ||||
|   // minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. | ||||
|   // It defaults to 1 pod. | ||||
|   // +optional | ||||
|   optional int32 minReplicas = 2; | ||||
|  | ||||
|   // maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. | ||||
|   // It cannot be less that minReplicas. | ||||
|   optional int32 maxReplicas = 3; | ||||
|  | ||||
|   // metrics contains the specifications for which to use to calculate the | ||||
|   // desired replica count (the maximum replica count across all metrics will | ||||
|   // be used).  The desired replica count is calculated multiplying the | ||||
|   // ratio between the target value and the current value by the current | ||||
|   // number of pods.  Ergo, metrics used must decrease as the pod count is | ||||
|   // increased, and vice-versa.  See the individual metric source types for | ||||
|   // more information about how each type of metric must respond. | ||||
|   // +optional | ||||
|   repeated MetricSpec metrics = 4; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler. | ||||
| message HorizontalPodAutoscalerStatus { | ||||
|   // observedGeneration is the most recent generation observed by this autoscaler. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, | ||||
|   // used by the autoscaler to control how often the number of pods is changed. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastScaleTime = 2; | ||||
|  | ||||
|   // currentReplicas is current number of replicas of pods managed by this autoscaler, | ||||
|   // as last seen by the autoscaler. | ||||
|   optional int32 currentReplicas = 3; | ||||
|  | ||||
|   // desiredReplicas is the desired number of replicas of pods managed by this autoscaler, | ||||
|   // as last calculated by the autoscaler. | ||||
|   optional int32 desiredReplicas = 4; | ||||
|  | ||||
|   // currentMetrics is the last read state of the metrics used by this autoscaler. | ||||
|   // +optional | ||||
|   repeated MetricStatus currentMetrics = 5; | ||||
|  | ||||
|   // conditions is the set of conditions required for this autoscaler to scale its target, | ||||
|   // and indicates whether or not those conditions are met. | ||||
|   repeated HorizontalPodAutoscalerCondition conditions = 6; | ||||
| } | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| message MetricSpec { | ||||
|   // type is the type of metric source.  It should be one of "Object", | ||||
|   // "Pods" or "Resource", each mapping to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricSource object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricSource pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricSource resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricSource external = 5; | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| message MetricStatus { | ||||
|   // type is the type of metric source.  It will be one of "Object", | ||||
|   // "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricStatus object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricStatus pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricStatus resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricStatus external = 5; | ||||
| } | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricSource { | ||||
|   // target is the described Kubernetes object. | ||||
|   optional CrossVersionObjectReference target = 1; | ||||
|  | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 2; | ||||
|  | ||||
|   // targetValue is the target value of the metric (as a quantity). | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetValue = 3; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; | ||||
|  | ||||
|   // averageValue is the target value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 5; | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricStatus { | ||||
|   // target is the described Kubernetes object. | ||||
|   optional CrossVersionObjectReference target = 1; | ||||
|  | ||||
|   // metricName is the name of the metric in question. | ||||
|   optional string metricName = 2; | ||||
|  | ||||
|   // currentValue is the current value of the metric (as a quantity). | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentValue = 3; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; | ||||
|  | ||||
|   // averageValue is the current value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 5; | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| message PodsMetricSource { | ||||
|   // metricName is the name of the metric in question | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // targetAverageValue is the target value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 2; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 3; | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| message PodsMetricStatus { | ||||
|   // metricName is the name of the metric in question | ||||
|   optional string metricName = 1; | ||||
|  | ||||
|   // currentAverageValue is the current value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 2; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 3; | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| message ResourceMetricSource { | ||||
|   // name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // targetAverageUtilization is the target value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods. | ||||
|   // +optional | ||||
|   optional int32 targetAverageUtilization = 2; | ||||
|  | ||||
|   // targetAverageValue is the target value of the average of the | ||||
|   // resource metric across all relevant pods, as a raw value (instead of as | ||||
|   // a percentage of the request), similar to the "pods" metric source type. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity targetAverageValue = 3; | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| message ResourceMetricStatus { | ||||
|   // name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // currentAverageUtilization is the current value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods.  It will only be | ||||
|   // present if `targetAverageValue` was set in the corresponding metric | ||||
|   // specification. | ||||
|   // +optional | ||||
|   optional int32 currentAverageUtilization = 2; | ||||
|  | ||||
|   // currentAverageValue is the current value of the average of the | ||||
|   // resource metric across all relevant pods, as a raw value (instead of as | ||||
|   // a percentage of the request), similar to the "pods" metric source type. | ||||
|   // It will always be set, regardless of the corresponding metric specification. | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity currentAverageValue = 3; | ||||
| } | ||||
|  | ||||
							
								
								
									
										52
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| /* | ||||
| Copyright 2016 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 v2beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "autoscaling" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v2beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&HorizontalPodAutoscaler{}, | ||||
| 		&HorizontalPodAutoscalerList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										405
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										405
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,405 @@ | ||||
| /* | ||||
| Copyright 2016 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 v2beta1 | ||||
|  | ||||
| import ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	"k8s.io/apimachinery/pkg/api/resource" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| type CrossVersionObjectReference struct { | ||||
| 	// Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/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 | ||||
| 	Name string `json:"name" protobuf:"bytes,2,opt,name=name"` | ||||
| 	// API version of the referent | ||||
| 	// +optional | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler. | ||||
| type HorizontalPodAutoscalerSpec struct { | ||||
| 	// scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics | ||||
| 	// should be collected, as well as to actually change the replica count. | ||||
| 	ScaleTargetRef CrossVersionObjectReference `json:"scaleTargetRef" protobuf:"bytes,1,opt,name=scaleTargetRef"` | ||||
| 	// minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. | ||||
| 	// It defaults to 1 pod. | ||||
| 	// +optional | ||||
| 	MinReplicas *int32 `json:"minReplicas,omitempty" protobuf:"varint,2,opt,name=minReplicas"` | ||||
| 	// maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. | ||||
| 	// It cannot be less that minReplicas. | ||||
| 	MaxReplicas int32 `json:"maxReplicas" protobuf:"varint,3,opt,name=maxReplicas"` | ||||
| 	// metrics contains the specifications for which to use to calculate the | ||||
| 	// desired replica count (the maximum replica count across all metrics will | ||||
| 	// be used).  The desired replica count is calculated multiplying the | ||||
| 	// ratio between the target value and the current value by the current | ||||
| 	// number of pods.  Ergo, metrics used must decrease as the pod count is | ||||
| 	// increased, and vice-versa.  See the individual metric source types for | ||||
| 	// more information about how each type of metric must respond. | ||||
| 	// +optional | ||||
| 	Metrics []MetricSpec `json:"metrics,omitempty" protobuf:"bytes,4,rep,name=metrics"` | ||||
| } | ||||
|  | ||||
| // MetricSourceType indicates the type of metric. | ||||
| type MetricSourceType string | ||||
|  | ||||
| var ( | ||||
| 	// ObjectMetricSourceType is a metric describing a kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	ObjectMetricSourceType MetricSourceType = "Object" | ||||
| 	// PodsMetricSourceType is a metric describing each pod in the current scale | ||||
| 	// target (for example, transactions-processed-per-second).  The values | ||||
| 	// will be averaged together before being compared to the target value. | ||||
| 	PodsMetricSourceType MetricSourceType = "Pods" | ||||
| 	// ResourceMetricSourceType is a resource metric known to Kubernetes, as | ||||
| 	// specified in requests and limits, describing each pod in the current | ||||
| 	// scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics (the "pods" source). | ||||
| 	ResourceMetricSourceType MetricSourceType = "Resource" | ||||
| 	// ExternalMetricSourceType is a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	ExternalMetricSourceType MetricSourceType = "External" | ||||
| ) | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| type MetricSpec struct { | ||||
| 	// type is the type of metric source.  It should be one of "Object", | ||||
| 	// "Pods" or "Resource", each mapping to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricSource `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricSource `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricSource `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricSource `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricSource struct { | ||||
| 	// target is the described Kubernetes object. | ||||
| 	Target CrossVersionObjectReference `json:"target" protobuf:"bytes,1,name=target"` | ||||
|  | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,2,name=metricName"` | ||||
| 	// targetValue is the target value of the metric (as a quantity). | ||||
| 	TargetValue resource.Quantity `json:"targetValue" protobuf:"bytes,3,name=targetValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,name=selector"` | ||||
| 	// averageValue is the target value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,5,name=averageValue"` | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| type PodsMetricSource struct { | ||||
| 	// metricName is the name of the metric in question | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// targetAverageValue is the target value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	TargetAverageValue resource.Quantity `json:"targetAverageValue" protobuf:"bytes,2,name=targetAverageValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,3,name=selector"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| type ResourceMetricSource struct { | ||||
| 	// name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// targetAverageUtilization is the target value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods. | ||||
| 	// +optional | ||||
| 	TargetAverageUtilization *int32 `json:"targetAverageUtilization,omitempty" protobuf:"varint,2,opt,name=targetAverageUtilization"` | ||||
| 	// targetAverageValue is the target value of the average of the | ||||
| 	// resource metric across all relevant pods, as a raw value (instead of as | ||||
| 	// a percentage of the request), similar to the "pods" metric source type. | ||||
| 	// +optional | ||||
| 	TargetAverageValue *resource.Quantity `json:"targetAverageValue,omitempty" protobuf:"bytes,3,opt,name=targetAverageValue"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| // Exactly one "target" type should be set. | ||||
| type ExternalMetricSource struct { | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// metricSelector is used to identify a specific time series | ||||
| 	// within a given metric. | ||||
| 	// +optional | ||||
| 	MetricSelector *metav1.LabelSelector `json:"metricSelector,omitempty" protobuf:"bytes,2,opt,name=metricSelector"` | ||||
| 	// targetValue is the target value of the metric (as a quantity). | ||||
| 	// Mutually exclusive with TargetAverageValue. | ||||
| 	// +optional | ||||
| 	TargetValue *resource.Quantity `json:"targetValue,omitempty" protobuf:"bytes,3,opt,name=targetValue"` | ||||
| 	// targetAverageValue is the target per-pod value of global metric (as a quantity). | ||||
| 	// Mutually exclusive with TargetValue. | ||||
| 	// +optional | ||||
| 	TargetAverageValue *resource.Quantity `json:"targetAverageValue,omitempty" protobuf:"bytes,4,opt,name=targetAverageValue"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler. | ||||
| type HorizontalPodAutoscalerStatus struct { | ||||
| 	// observedGeneration is the most recent generation observed by this autoscaler. | ||||
| 	// +optional | ||||
| 	ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, | ||||
| 	// used by the autoscaler to control how often the number of pods is changed. | ||||
| 	// +optional | ||||
| 	LastScaleTime *metav1.Time `json:"lastScaleTime,omitempty" protobuf:"bytes,2,opt,name=lastScaleTime"` | ||||
|  | ||||
| 	// currentReplicas is current number of replicas of pods managed by this autoscaler, | ||||
| 	// as last seen by the autoscaler. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas" protobuf:"varint,3,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// desiredReplicas is the desired number of replicas of pods managed by this autoscaler, | ||||
| 	// as last calculated by the autoscaler. | ||||
| 	DesiredReplicas int32 `json:"desiredReplicas" protobuf:"varint,4,opt,name=desiredReplicas"` | ||||
|  | ||||
| 	// currentMetrics is the last read state of the metrics used by this autoscaler. | ||||
| 	// +optional | ||||
| 	CurrentMetrics []MetricStatus `json:"currentMetrics" protobuf:"bytes,5,rep,name=currentMetrics"` | ||||
|  | ||||
| 	// conditions is the set of conditions required for this autoscaler to scale its target, | ||||
| 	// and indicates whether or not those conditions are met. | ||||
| 	Conditions []HorizontalPodAutoscalerCondition `json:"conditions" protobuf:"bytes,6,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerConditionType are the valid conditions of | ||||
| // a HorizontalPodAutoscaler. | ||||
| type HorizontalPodAutoscalerConditionType string | ||||
|  | ||||
| var ( | ||||
| 	// ScalingActive indicates that the HPA controller is able to scale if necessary: | ||||
| 	// it's correctly configured, can fetch the desired metrics, and isn't disabled. | ||||
| 	ScalingActive HorizontalPodAutoscalerConditionType = "ScalingActive" | ||||
| 	// AbleToScale indicates a lack of transient issues which prevent scaling from occurring, | ||||
| 	// such as being in a backoff window, or being unable to access/update the target scale. | ||||
| 	AbleToScale HorizontalPodAutoscalerConditionType = "AbleToScale" | ||||
| 	// ScalingLimited indicates that the calculated scale based on metrics would be above or | ||||
| 	// below the range for the HPA, and has thus been capped. | ||||
| 	ScalingLimited HorizontalPodAutoscalerConditionType = "ScalingLimited" | ||||
| ) | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| type HorizontalPodAutoscalerCondition struct { | ||||
| 	// type describes the current condition | ||||
| 	Type HorizontalPodAutoscalerConditionType `json:"type" protobuf:"bytes,1,name=type"` | ||||
| 	// status is the status of the condition (True, False, Unknown) | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,name=status"` | ||||
| 	// lastTransitionTime is the last time the condition transitioned from | ||||
| 	// one status to another | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// reason is the reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// message is a human-readable explanation containing details about | ||||
| 	// the transition | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| type MetricStatus struct { | ||||
| 	// type is the type of metric source.  It will be one of "Object", | ||||
| 	// "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricStatus `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricStatus `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricStatus `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricStatus `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricStatus struct { | ||||
| 	// target is the described Kubernetes object. | ||||
| 	Target CrossVersionObjectReference `json:"target" protobuf:"bytes,1,name=target"` | ||||
|  | ||||
| 	// metricName is the name of the metric in question. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,2,name=metricName"` | ||||
| 	// currentValue is the current value of the metric (as a quantity). | ||||
| 	CurrentValue resource.Quantity `json:"currentValue" protobuf:"bytes,3,name=currentValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,name=selector"` | ||||
| 	// averageValue is the current value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,5,name=averageValue"` | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| type PodsMetricStatus struct { | ||||
| 	// metricName is the name of the metric in question | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// currentAverageValue is the current value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	CurrentAverageValue resource.Quantity `json:"currentAverageValue" protobuf:"bytes,2,name=currentAverageValue"` | ||||
|  | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,3,name=selector"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| type ResourceMetricStatus struct { | ||||
| 	// name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// currentAverageUtilization is the current value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods.  It will only be | ||||
| 	// present if `targetAverageValue` was set in the corresponding metric | ||||
| 	// specification. | ||||
| 	// +optional | ||||
| 	CurrentAverageUtilization *int32 `json:"currentAverageUtilization,omitempty" protobuf:"bytes,2,opt,name=currentAverageUtilization"` | ||||
| 	// currentAverageValue is the current value of the average of the | ||||
| 	// resource metric across all relevant pods, as a raw value (instead of as | ||||
| 	// a percentage of the request), similar to the "pods" metric source type. | ||||
| 	// It will always be set, regardless of the corresponding metric specification. | ||||
| 	CurrentAverageValue resource.Quantity `json:"currentAverageValue" protobuf:"bytes,3,name=currentAverageValue"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| type ExternalMetricStatus struct { | ||||
| 	// metricName is the name of a metric used for autoscaling in | ||||
| 	// metric system. | ||||
| 	MetricName string `json:"metricName" protobuf:"bytes,1,name=metricName"` | ||||
| 	// metricSelector is used to identify a specific time series | ||||
| 	// within a given metric. | ||||
| 	// +optional | ||||
| 	MetricSelector *metav1.LabelSelector `json:"metricSelector,omitempty" protobuf:"bytes,2,opt,name=metricSelector"` | ||||
| 	// currentValue is the current value of the metric (as a quantity) | ||||
| 	CurrentValue resource.Quantity `json:"currentValue" protobuf:"bytes,3,name=currentValue"` | ||||
| 	// currentAverageValue is the current value of metric averaged over autoscaled pods. | ||||
| 	// +optional | ||||
| 	CurrentAverageValue *resource.Quantity `json:"currentAverageValue,omitempty" protobuf:"bytes,4,opt,name=currentAverageValue"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // HorizontalPodAutoscaler is the configuration for a horizontal pod | ||||
| // autoscaler, which automatically manages the replica count of any resource | ||||
| // implementing the scale subresource based on the metrics specified. | ||||
| type HorizontalPodAutoscaler struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// metadata is the standard object metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// spec is the specification for the behaviour of the autoscaler. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// status is the current information about the autoscaler. | ||||
| 	// +optional | ||||
| 	Status HorizontalPodAutoscalerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // HorizontalPodAutoscaler is a list of horizontal pod autoscaler objects. | ||||
| type HorizontalPodAutoscalerList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// metadata is the standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// items is the list of horizontal pod autoscaler objects. | ||||
| 	Items []HorizontalPodAutoscaler `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										221
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										221
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,221 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v2beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_CrossVersionObjectReference = map[string]string{ | ||||
| 	"":           "CrossVersionObjectReference contains enough information to let you identify the referred resource.", | ||||
| 	"kind":       "Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds\"", | ||||
| 	"name":       "Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names", | ||||
| 	"apiVersion": "API version of the referent", | ||||
| } | ||||
|  | ||||
| func (CrossVersionObjectReference) SwaggerDoc() map[string]string { | ||||
| 	return map_CrossVersionObjectReference | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricSource = map[string]string{ | ||||
| 	"":                   "ExternalMetricSource indicates how to scale on a metric not associated with any Kubernetes object (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster). Exactly one \"target\" type should be set.", | ||||
| 	"metricName":         "metricName is the name of the metric in question.", | ||||
| 	"metricSelector":     "metricSelector is used to identify a specific time series within a given metric.", | ||||
| 	"targetValue":        "targetValue is the target value of the metric (as a quantity). Mutually exclusive with TargetAverageValue.", | ||||
| 	"targetAverageValue": "targetAverageValue is the target per-pod value of global metric (as a quantity). Mutually exclusive with TargetValue.", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricSource | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricStatus = map[string]string{ | ||||
| 	"":                    "ExternalMetricStatus indicates the current value of a global metric not associated with any Kubernetes object.", | ||||
| 	"metricName":          "metricName is the name of a metric used for autoscaling in metric system.", | ||||
| 	"metricSelector":      "metricSelector is used to identify a specific time series within a given metric.", | ||||
| 	"currentValue":        "currentValue is the current value of the metric (as a quantity)", | ||||
| 	"currentAverageValue": "currentAverageValue is the current value of metric averaged over autoscaled pods.", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricStatus | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscaler = map[string]string{ | ||||
| 	"":         "HorizontalPodAutoscaler is the configuration for a horizontal pod autoscaler, which automatically manages the replica count of any resource implementing the scale subresource based on the metrics specified.", | ||||
| 	"metadata": "metadata is the standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "spec is the specification for the behaviour of the autoscaler. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "status is the current information about the autoscaler.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscaler) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscaler | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerCondition = map[string]string{ | ||||
| 	"":                   "HorizontalPodAutoscalerCondition describes the state of a HorizontalPodAutoscaler at a certain point.", | ||||
| 	"type":               "type describes the current condition", | ||||
| 	"status":             "status is the status of the condition (True, False, Unknown)", | ||||
| 	"lastTransitionTime": "lastTransitionTime is the last time the condition transitioned from one status to another", | ||||
| 	"reason":             "reason is the reason for the condition's last transition.", | ||||
| 	"message":            "message is a human-readable explanation containing details about the transition", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerCondition | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerList = map[string]string{ | ||||
| 	"":         "HorizontalPodAutoscaler is a list of horizontal pod autoscaler objects.", | ||||
| 	"metadata": "metadata is the standard list metadata.", | ||||
| 	"items":    "items is the list of horizontal pod autoscaler objects.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerList) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerList | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerSpec = map[string]string{ | ||||
| 	"":               "HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler.", | ||||
| 	"scaleTargetRef": "scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics should be collected, as well as to actually change the replica count.", | ||||
| 	"minReplicas":    "minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. It defaults to 1 pod.", | ||||
| 	"maxReplicas":    "maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. It cannot be less that minReplicas.", | ||||
| 	"metrics":        "metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).  The desired replica count is calculated multiplying the ratio between the target value and the current value by the current number of pods.  Ergo, metrics used must decrease as the pod count is increased, and vice-versa.  See the individual metric source types for more information about how each type of metric must respond.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerSpec | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerStatus = map[string]string{ | ||||
| 	"":                   "HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler.", | ||||
| 	"observedGeneration": "observedGeneration is the most recent generation observed by this autoscaler.", | ||||
| 	"lastScaleTime":      "lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, used by the autoscaler to control how often the number of pods is changed.", | ||||
| 	"currentReplicas":    "currentReplicas is current number of replicas of pods managed by this autoscaler, as last seen by the autoscaler.", | ||||
| 	"desiredReplicas":    "desiredReplicas is the desired number of replicas of pods managed by this autoscaler, as last calculated by the autoscaler.", | ||||
| 	"currentMetrics":     "currentMetrics is the last read state of the metrics used by this autoscaler.", | ||||
| 	"conditions":         "conditions is the set of conditions required for this autoscaler to scale its target, and indicates whether or not those conditions are met.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerStatus | ||||
| } | ||||
|  | ||||
| var map_MetricSpec = map[string]string{ | ||||
| 	"":         "MetricSpec specifies how to scale based on a single metric (only `type` and one other matching field should be set at once).", | ||||
| 	"type":     "type is the type of metric source.  It should be one of \"Object\", \"Pods\" or \"Resource\", each mapping to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricSpec | ||||
| } | ||||
|  | ||||
| var map_MetricStatus = map[string]string{ | ||||
| 	"":         "MetricStatus describes the last-read state of a single metric.", | ||||
| 	"type":     "type is the type of metric source.  It will be one of \"Object\", \"Pods\" or \"Resource\", each corresponds to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricStatus | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricSource = map[string]string{ | ||||
| 	"":             "ObjectMetricSource indicates how to scale on a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"target":       "target is the described Kubernetes object.", | ||||
| 	"metricName":   "metricName is the name of the metric in question.", | ||||
| 	"targetValue":  "targetValue is the target value of the metric (as a quantity).", | ||||
| 	"selector":     "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping When unset, just the metricName will be used to gather metrics.", | ||||
| 	"averageValue": "averageValue is the target value of the average of the metric across all relevant pods (as a quantity)", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricSource | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricStatus = map[string]string{ | ||||
| 	"":             "ObjectMetricStatus indicates the current value of a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"target":       "target is the described Kubernetes object.", | ||||
| 	"metricName":   "metricName is the name of the metric in question.", | ||||
| 	"currentValue": "currentValue is the current value of the metric (as a quantity).", | ||||
| 	"selector":     "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set in the ObjectMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.", | ||||
| 	"averageValue": "averageValue is the current value of the average of the metric across all relevant pods (as a quantity)", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricStatus | ||||
| } | ||||
|  | ||||
| var map_PodsMetricSource = map[string]string{ | ||||
| 	"":                   "PodsMetricSource indicates how to scale on a metric describing each pod in the current scale target (for example, transactions-processed-per-second). The values will be averaged together before being compared to the target value.", | ||||
| 	"metricName":         "metricName is the name of the metric in question", | ||||
| 	"targetAverageValue": "targetAverageValue is the target value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"selector":           "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping When unset, just the metricName will be used to gather metrics.", | ||||
| } | ||||
|  | ||||
| func (PodsMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricSource | ||||
| } | ||||
|  | ||||
| var map_PodsMetricStatus = map[string]string{ | ||||
| 	"":                    "PodsMetricStatus indicates the current value of a metric describing each pod in the current scale target (for example, transactions-processed-per-second).", | ||||
| 	"metricName":          "metricName is the name of the metric in question", | ||||
| 	"currentAverageValue": "currentAverageValue is the current value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"selector":            "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set in the PodsMetricSource, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.", | ||||
| } | ||||
|  | ||||
| func (PodsMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricStatus | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricSource = map[string]string{ | ||||
| 	"":                         "ResourceMetricSource indicates how to scale on a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  The values will be averaged together before being compared to the target.  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.  Only one \"target\" type should be set.", | ||||
| 	"name":                     "name is the name of the resource in question.", | ||||
| 	"targetAverageUtilization": "targetAverageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.", | ||||
| 	"targetAverageValue":       "targetAverageValue is the target value of the average of the resource metric across all relevant pods, as a raw value (instead of as a percentage of the request), similar to the \"pods\" metric source type.", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricSource | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricStatus = map[string]string{ | ||||
| 	"":                          "ResourceMetricStatus indicates the current value of a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"name":                      "name is the name of the resource in question.", | ||||
| 	"currentAverageUtilization": "currentAverageUtilization is the current value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.  It will only be present if `targetAverageValue` was set in the corresponding metric specification.", | ||||
| 	"currentAverageValue":       "currentAverageValue is the current value of the average of the resource metric across all relevant pods, as a raw value (instead of as a percentage of the request), similar to the \"pods\" metric source type. It will always be set, regardless of the corresponding metric specification.", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										466
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										466
									
								
								vendor/k8s.io/api/autoscaling/v2beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,466 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v2beta1 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CrossVersionObjectReference) DeepCopyInto(out *CrossVersionObjectReference) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CrossVersionObjectReference. | ||||
| func (in *CrossVersionObjectReference) DeepCopy() *CrossVersionObjectReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CrossVersionObjectReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricSource) DeepCopyInto(out *ExternalMetricSource) { | ||||
| 	*out = *in | ||||
| 	if in.MetricSelector != nil { | ||||
| 		in, out := &in.MetricSelector, &out.MetricSelector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.TargetValue != nil { | ||||
| 		in, out := &in.TargetValue, &out.TargetValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.TargetAverageValue != nil { | ||||
| 		in, out := &in.TargetAverageValue, &out.TargetAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricSource. | ||||
| func (in *ExternalMetricSource) DeepCopy() *ExternalMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricStatus) DeepCopyInto(out *ExternalMetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.MetricSelector != nil { | ||||
| 		in, out := &in.MetricSelector, &out.MetricSelector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	out.CurrentValue = in.CurrentValue.DeepCopy() | ||||
| 	if in.CurrentAverageValue != nil { | ||||
| 		in, out := &in.CurrentAverageValue, &out.CurrentAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricStatus. | ||||
| func (in *ExternalMetricStatus) DeepCopy() *ExternalMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyInto(out *HorizontalPodAutoscaler) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscaler. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopy() *HorizontalPodAutoscaler { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscaler) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopyInto(out *HorizontalPodAutoscalerCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerCondition. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopy() *HorizontalPodAutoscalerCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyInto(out *HorizontalPodAutoscalerList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]HorizontalPodAutoscaler, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerList. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopy() *HorizontalPodAutoscalerList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopyInto(out *HorizontalPodAutoscalerSpec) { | ||||
| 	*out = *in | ||||
| 	out.ScaleTargetRef = in.ScaleTargetRef | ||||
| 	if in.MinReplicas != nil { | ||||
| 		in, out := &in.MinReplicas, &out.MinReplicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Metrics != nil { | ||||
| 		in, out := &in.Metrics, &out.Metrics | ||||
| 		*out = make([]MetricSpec, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerSpec. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopy() *HorizontalPodAutoscalerSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopyInto(out *HorizontalPodAutoscalerStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ObservedGeneration != nil { | ||||
| 		in, out := &in.ObservedGeneration, &out.ObservedGeneration | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.LastScaleTime != nil { | ||||
| 		in, out := &in.LastScaleTime, &out.LastScaleTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	if in.CurrentMetrics != nil { | ||||
| 		in, out := &in.CurrentMetrics, &out.CurrentMetrics | ||||
| 		*out = make([]MetricStatus, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]HorizontalPodAutoscalerCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerStatus. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopy() *HorizontalPodAutoscalerStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricSpec) DeepCopyInto(out *MetricSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricSpec. | ||||
| func (in *MetricSpec) DeepCopy() *MetricSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricStatus) DeepCopyInto(out *MetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricStatus. | ||||
| func (in *MetricStatus) DeepCopy() *MetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricSource) DeepCopyInto(out *ObjectMetricSource) { | ||||
| 	*out = *in | ||||
| 	out.Target = in.Target | ||||
| 	out.TargetValue = in.TargetValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricSource. | ||||
| func (in *ObjectMetricSource) DeepCopy() *ObjectMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricStatus) DeepCopyInto(out *ObjectMetricStatus) { | ||||
| 	*out = *in | ||||
| 	out.Target = in.Target | ||||
| 	out.CurrentValue = in.CurrentValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricStatus. | ||||
| func (in *ObjectMetricStatus) DeepCopy() *ObjectMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricSource) DeepCopyInto(out *PodsMetricSource) { | ||||
| 	*out = *in | ||||
| 	out.TargetAverageValue = in.TargetAverageValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricSource. | ||||
| func (in *PodsMetricSource) DeepCopy() *PodsMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricStatus) DeepCopyInto(out *PodsMetricStatus) { | ||||
| 	*out = *in | ||||
| 	out.CurrentAverageValue = in.CurrentAverageValue.DeepCopy() | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricStatus. | ||||
| func (in *PodsMetricStatus) DeepCopy() *PodsMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricSource) DeepCopyInto(out *ResourceMetricSource) { | ||||
| 	*out = *in | ||||
| 	if in.TargetAverageUtilization != nil { | ||||
| 		in, out := &in.TargetAverageUtilization, &out.TargetAverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.TargetAverageValue != nil { | ||||
| 		in, out := &in.TargetAverageValue, &out.TargetAverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricSource. | ||||
| func (in *ResourceMetricSource) DeepCopy() *ResourceMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricStatus) DeepCopyInto(out *ResourceMetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.CurrentAverageUtilization != nil { | ||||
| 		in, out := &in.CurrentAverageUtilization, &out.CurrentAverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	out.CurrentAverageValue = in.CurrentAverageValue.DeepCopy() | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricStatus. | ||||
| func (in *ResourceMetricStatus) DeepCopy() *ResourceMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2018 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v2beta2 // import "k8s.io/api/autoscaling/v2beta2" | ||||
							
								
								
									
										4425
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4425
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										369
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										369
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,369 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.autoscaling.v2beta2; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/api/resource/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v2beta2"; | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| message CrossVersionObjectReference { | ||||
|   // Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds" | ||||
|   optional string kind = 1; | ||||
|  | ||||
|   // Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names | ||||
|   optional string name = 2; | ||||
|  | ||||
|   // API version of the referent | ||||
|   // +optional | ||||
|   optional string apiVersion = 3; | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| message ExternalMetricSource { | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 1; | ||||
|  | ||||
|   // target specifies the target value for the given metric | ||||
|   optional MetricTarget target = 2; | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| message ExternalMetricStatus { | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 1; | ||||
|  | ||||
|   // current contains the current value for the given metric | ||||
|   optional MetricValueStatus current = 2; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscaler is the configuration for a horizontal pod | ||||
| // autoscaler, which automatically manages the replica count of any resource | ||||
| // implementing the scale subresource based on the metrics specified. | ||||
| message HorizontalPodAutoscaler { | ||||
|   // metadata is the standard object metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // spec is the specification for the behaviour of the autoscaler. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerSpec spec = 2; | ||||
|  | ||||
|   // status is the current information about the autoscaler. | ||||
|   // +optional | ||||
|   optional HorizontalPodAutoscalerStatus status = 3; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| message HorizontalPodAutoscalerCondition { | ||||
|   // type describes the current condition | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // status is the status of the condition (True, False, Unknown) | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // lastTransitionTime is the last time the condition transitioned from | ||||
|   // one status to another | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 3; | ||||
|  | ||||
|   // reason is the reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 4; | ||||
|  | ||||
|   // message is a human-readable explanation containing details about | ||||
|   // the transition | ||||
|   // +optional | ||||
|   optional string message = 5; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerList is a list of horizontal pod autoscaler objects. | ||||
| message HorizontalPodAutoscalerList { | ||||
|   // metadata is the standard list metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // items is the list of horizontal pod autoscaler objects. | ||||
|   repeated HorizontalPodAutoscaler items = 2; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler. | ||||
| message HorizontalPodAutoscalerSpec { | ||||
|   // scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics | ||||
|   // should be collected, as well as to actually change the replica count. | ||||
|   optional CrossVersionObjectReference scaleTargetRef = 1; | ||||
|  | ||||
|   // minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. | ||||
|   // It defaults to 1 pod. | ||||
|   // +optional | ||||
|   optional int32 minReplicas = 2; | ||||
|  | ||||
|   // maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. | ||||
|   // It cannot be less that minReplicas. | ||||
|   optional int32 maxReplicas = 3; | ||||
|  | ||||
|   // metrics contains the specifications for which to use to calculate the | ||||
|   // desired replica count (the maximum replica count across all metrics will | ||||
|   // be used).  The desired replica count is calculated multiplying the | ||||
|   // ratio between the target value and the current value by the current | ||||
|   // number of pods.  Ergo, metrics used must decrease as the pod count is | ||||
|   // increased, and vice-versa.  See the individual metric source types for | ||||
|   // more information about how each type of metric must respond. | ||||
|   // If not set, the default metric will be set to 80% average CPU utilization. | ||||
|   // +optional | ||||
|   repeated MetricSpec metrics = 4; | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler. | ||||
| message HorizontalPodAutoscalerStatus { | ||||
|   // observedGeneration is the most recent generation observed by this autoscaler. | ||||
|   // +optional | ||||
|   optional int64 observedGeneration = 1; | ||||
|  | ||||
|   // lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, | ||||
|   // used by the autoscaler to control how often the number of pods is changed. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastScaleTime = 2; | ||||
|  | ||||
|   // currentReplicas is current number of replicas of pods managed by this autoscaler, | ||||
|   // as last seen by the autoscaler. | ||||
|   optional int32 currentReplicas = 3; | ||||
|  | ||||
|   // desiredReplicas is the desired number of replicas of pods managed by this autoscaler, | ||||
|   // as last calculated by the autoscaler. | ||||
|   optional int32 desiredReplicas = 4; | ||||
|  | ||||
|   // currentMetrics is the last read state of the metrics used by this autoscaler. | ||||
|   // +optional | ||||
|   repeated MetricStatus currentMetrics = 5; | ||||
|  | ||||
|   // conditions is the set of conditions required for this autoscaler to scale its target, | ||||
|   // and indicates whether or not those conditions are met. | ||||
|   repeated HorizontalPodAutoscalerCondition conditions = 6; | ||||
| } | ||||
|  | ||||
| // MetricIdentifier defines the name and optionally selector for a metric | ||||
| message MetricIdentifier { | ||||
|   // name is the name of the given metric | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
|   // When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
|   // When unset, just the metricName will be used to gather metrics. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 2; | ||||
| } | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| message MetricSpec { | ||||
|   // type is the type of metric source.  It should be one of "Object", | ||||
|   // "Pods" or "Resource", each mapping to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricSource object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricSource pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricSource resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricSource external = 5; | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| message MetricStatus { | ||||
|   // type is the type of metric source.  It will be one of "Object", | ||||
|   // "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // object refers to a metric describing a single kubernetes object | ||||
|   // (for example, hits-per-second on an Ingress object). | ||||
|   // +optional | ||||
|   optional ObjectMetricStatus object = 2; | ||||
|  | ||||
|   // pods refers to a metric describing each pod in the current scale target | ||||
|   // (for example, transactions-processed-per-second).  The values will be | ||||
|   // averaged together before being compared to the target value. | ||||
|   // +optional | ||||
|   optional PodsMetricStatus pods = 3; | ||||
|  | ||||
|   // resource refers to a resource metric (such as those specified in | ||||
|   // requests and limits) known to Kubernetes describing each pod in the | ||||
|   // current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
|   // Kubernetes, and have special scaling options on top of those available | ||||
|   // to normal per-pod metrics using the "pods" source. | ||||
|   // +optional | ||||
|   optional ResourceMetricStatus resource = 4; | ||||
|  | ||||
|   // external refers to a global metric that is not associated | ||||
|   // with any Kubernetes object. It allows autoscaling based on information | ||||
|   // coming from components running outside of cluster | ||||
|   // (for example length of queue in cloud messaging service, or | ||||
|   // QPS from loadbalancer running outside of cluster). | ||||
|   // +optional | ||||
|   optional ExternalMetricStatus external = 5; | ||||
| } | ||||
|  | ||||
| // MetricTarget defines the target value, average value, or average utilization of a specific metric | ||||
| message MetricTarget { | ||||
|   // type represents whether the metric type is Utilization, Value, or AverageValue | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // value is the target value of the metric (as a quantity). | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity value = 2; | ||||
|  | ||||
|   // averageValue is the target value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 3; | ||||
|  | ||||
|   // averageUtilization is the target value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods. | ||||
|   // Currently only valid for Resource metric source type | ||||
|   // +optional | ||||
|   optional int32 averageUtilization = 4; | ||||
| } | ||||
|  | ||||
| // MetricValueStatus holds the current value for a metric | ||||
| message MetricValueStatus { | ||||
|   // value is the current value of the metric (as a quantity). | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity value = 1; | ||||
|  | ||||
|   // averageValue is the current value of the average of the | ||||
|   // metric across all relevant pods (as a quantity) | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.api.resource.Quantity averageValue = 2; | ||||
|  | ||||
|   // currentAverageUtilization is the current value of the average of the | ||||
|   // resource metric across all relevant pods, represented as a percentage of | ||||
|   // the requested value of the resource for the pods. | ||||
|   // +optional | ||||
|   optional int32 averageUtilization = 3; | ||||
| } | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricSource { | ||||
|   optional CrossVersionObjectReference describedObject = 1; | ||||
|  | ||||
|   // target specifies the target value for the given metric | ||||
|   optional MetricTarget target = 2; | ||||
|  | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 3; | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| message ObjectMetricStatus { | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 1; | ||||
|  | ||||
|   // current contains the current value for the given metric | ||||
|   optional MetricValueStatus current = 2; | ||||
|  | ||||
|   optional CrossVersionObjectReference describedObject = 3; | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| message PodsMetricSource { | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 1; | ||||
|  | ||||
|   // target specifies the target value for the given metric | ||||
|   optional MetricTarget target = 2; | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| message PodsMetricStatus { | ||||
|   // metric identifies the target metric by name and selector | ||||
|   optional MetricIdentifier metric = 1; | ||||
|  | ||||
|   // current contains the current value for the given metric | ||||
|   optional MetricValueStatus current = 2; | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| message ResourceMetricSource { | ||||
|   // name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // target specifies the target value for the given metric | ||||
|   optional MetricTarget target = 2; | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| message ResourceMetricStatus { | ||||
|   // Name is the name of the resource in question. | ||||
|   optional string name = 1; | ||||
|  | ||||
|   // current contains the current value for the given metric | ||||
|   optional MetricValueStatus current = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										50
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | ||||
| /* | ||||
| Copyright 2018 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 v2beta2 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "autoscaling" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v2beta2"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&HorizontalPodAutoscaler{}, | ||||
| 		&HorizontalPodAutoscalerList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										393
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										393
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,393 @@ | ||||
| /* | ||||
| Copyright 2018 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v2beta2 | ||||
|  | ||||
| import ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	"k8s.io/apimachinery/pkg/api/resource" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // HorizontalPodAutoscaler is the configuration for a horizontal pod | ||||
| // autoscaler, which automatically manages the replica count of any resource | ||||
| // implementing the scale subresource based on the metrics specified. | ||||
| type HorizontalPodAutoscaler struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// metadata is the standard object metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// spec is the specification for the behaviour of the autoscaler. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||||
| 	// +optional | ||||
| 	Spec HorizontalPodAutoscalerSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// status is the current information about the autoscaler. | ||||
| 	// +optional | ||||
| 	Status HorizontalPodAutoscalerStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler. | ||||
| type HorizontalPodAutoscalerSpec struct { | ||||
| 	// scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics | ||||
| 	// should be collected, as well as to actually change the replica count. | ||||
| 	ScaleTargetRef CrossVersionObjectReference `json:"scaleTargetRef" protobuf:"bytes,1,opt,name=scaleTargetRef"` | ||||
| 	// minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. | ||||
| 	// It defaults to 1 pod. | ||||
| 	// +optional | ||||
| 	MinReplicas *int32 `json:"minReplicas,omitempty" protobuf:"varint,2,opt,name=minReplicas"` | ||||
| 	// maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. | ||||
| 	// It cannot be less that minReplicas. | ||||
| 	MaxReplicas int32 `json:"maxReplicas" protobuf:"varint,3,opt,name=maxReplicas"` | ||||
| 	// metrics contains the specifications for which to use to calculate the | ||||
| 	// desired replica count (the maximum replica count across all metrics will | ||||
| 	// be used).  The desired replica count is calculated multiplying the | ||||
| 	// ratio between the target value and the current value by the current | ||||
| 	// number of pods.  Ergo, metrics used must decrease as the pod count is | ||||
| 	// increased, and vice-versa.  See the individual metric source types for | ||||
| 	// more information about how each type of metric must respond. | ||||
| 	// If not set, the default metric will be set to 80% average CPU utilization. | ||||
| 	// +optional | ||||
| 	Metrics []MetricSpec `json:"metrics,omitempty" protobuf:"bytes,4,rep,name=metrics"` | ||||
| } | ||||
|  | ||||
| // CrossVersionObjectReference contains enough information to let you identify the referred resource. | ||||
| type CrossVersionObjectReference struct { | ||||
| 	// Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/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 | ||||
| 	Name string `json:"name" protobuf:"bytes,2,opt,name=name"` | ||||
| 	// API version of the referent | ||||
| 	// +optional | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,3,opt,name=apiVersion"` | ||||
| } | ||||
|  | ||||
| // MetricSpec specifies how to scale based on a single metric | ||||
| // (only `type` and one other matching field should be set at once). | ||||
| type MetricSpec struct { | ||||
| 	// type is the type of metric source.  It should be one of "Object", | ||||
| 	// "Pods" or "Resource", each mapping to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricSource `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricSource `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricSource `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricSource `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // MetricSourceType indicates the type of metric. | ||||
| type MetricSourceType string | ||||
|  | ||||
| var ( | ||||
| 	// ObjectMetricSourceType is a metric describing a kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	ObjectMetricSourceType MetricSourceType = "Object" | ||||
| 	// PodsMetricSourceType is a metric describing each pod in the current scale | ||||
| 	// target (for example, transactions-processed-per-second).  The values | ||||
| 	// will be averaged together before being compared to the target value. | ||||
| 	PodsMetricSourceType MetricSourceType = "Pods" | ||||
| 	// ResourceMetricSourceType is a resource metric known to Kubernetes, as | ||||
| 	// specified in requests and limits, describing each pod in the current | ||||
| 	// scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics (the "pods" source). | ||||
| 	ResourceMetricSourceType MetricSourceType = "Resource" | ||||
| 	// ExternalMetricSourceType is a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	ExternalMetricSourceType MetricSourceType = "External" | ||||
| ) | ||||
|  | ||||
| // ObjectMetricSource indicates how to scale on a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricSource struct { | ||||
| 	DescribedObject CrossVersionObjectReference `json:"describedObject" protobuf:"bytes,1,name=describedObject"` | ||||
| 	// target specifies the target value for the given metric | ||||
| 	Target MetricTarget `json:"target" protobuf:"bytes,2,name=target"` | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,3,name=metric"` | ||||
| } | ||||
|  | ||||
| // PodsMetricSource indicates how to scale on a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| // The values will be averaged together before being compared to the target | ||||
| // value. | ||||
| type PodsMetricSource struct { | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,1,name=metric"` | ||||
| 	// target specifies the target value for the given metric | ||||
| 	Target MetricTarget `json:"target" protobuf:"bytes,2,name=target"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricSource indicates how to scale on a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  The values will be averaged | ||||
| // together before being compared to the target.  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source.  Only one "target" type | ||||
| // should be set. | ||||
| type ResourceMetricSource struct { | ||||
| 	// name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// target specifies the target value for the given metric | ||||
| 	Target MetricTarget `json:"target" protobuf:"bytes,2,name=target"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricSource indicates how to scale on a metric not associated with | ||||
| // any Kubernetes object (for example length of queue in cloud | ||||
| // messaging service, or QPS from loadbalancer running outside of cluster). | ||||
| type ExternalMetricSource struct { | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,1,name=metric"` | ||||
| 	// target specifies the target value for the given metric | ||||
| 	Target MetricTarget `json:"target" protobuf:"bytes,2,name=target"` | ||||
| } | ||||
|  | ||||
| // MetricIdentifier defines the name and optionally selector for a metric | ||||
| type MetricIdentifier struct { | ||||
| 	// name is the name of the given metric | ||||
| 	Name string `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// selector is the string-encoded form of a standard kubernetes label selector for the given metric | ||||
| 	// When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. | ||||
| 	// When unset, just the metricName will be used to gather metrics. | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,2,name=selector"` | ||||
| } | ||||
|  | ||||
| // MetricTarget defines the target value, average value, or average utilization of a specific metric | ||||
| type MetricTarget struct { | ||||
| 	// type represents whether the metric type is Utilization, Value, or AverageValue | ||||
| 	Type MetricTargetType `json:"type" protobuf:"bytes,1,name=type"` | ||||
| 	// value is the target value of the metric (as a quantity). | ||||
| 	// +optional | ||||
| 	Value *resource.Quantity `json:"value,omitempty" protobuf:"bytes,2,opt,name=value"` | ||||
| 	// averageValue is the target value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,3,opt,name=averageValue"` | ||||
| 	// averageUtilization is the target value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods. | ||||
| 	// Currently only valid for Resource metric source type | ||||
| 	// +optional | ||||
| 	AverageUtilization *int32 `json:"averageUtilization,omitempty" protobuf:"bytes,4,opt,name=averageUtilization"` | ||||
| } | ||||
|  | ||||
| // MetricTargetType specifies the type of metric being targeted, and should be either | ||||
| // "Value", "AverageValue", or "Utilization" | ||||
| type MetricTargetType string | ||||
|  | ||||
| var ( | ||||
| 	// UtilizationMetricType declares a MetricTarget is an AverageUtilization value | ||||
| 	UtilizationMetricType MetricTargetType = "Utilization" | ||||
| 	// ValueMetricType declares a MetricTarget is a raw value | ||||
| 	ValueMetricType MetricTargetType = "Value" | ||||
| 	// AverageValueMetricType declares a MetricTarget is an | ||||
| 	AverageValueMetricType MetricTargetType = "AverageValue" | ||||
| ) | ||||
|  | ||||
| // HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler. | ||||
| type HorizontalPodAutoscalerStatus struct { | ||||
| 	// observedGeneration is the most recent generation observed by this autoscaler. | ||||
| 	// +optional | ||||
| 	ObservedGeneration *int64 `json:"observedGeneration,omitempty" protobuf:"varint,1,opt,name=observedGeneration"` | ||||
|  | ||||
| 	// lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, | ||||
| 	// used by the autoscaler to control how often the number of pods is changed. | ||||
| 	// +optional | ||||
| 	LastScaleTime *metav1.Time `json:"lastScaleTime,omitempty" protobuf:"bytes,2,opt,name=lastScaleTime"` | ||||
|  | ||||
| 	// currentReplicas is current number of replicas of pods managed by this autoscaler, | ||||
| 	// as last seen by the autoscaler. | ||||
| 	CurrentReplicas int32 `json:"currentReplicas" protobuf:"varint,3,opt,name=currentReplicas"` | ||||
|  | ||||
| 	// desiredReplicas is the desired number of replicas of pods managed by this autoscaler, | ||||
| 	// as last calculated by the autoscaler. | ||||
| 	DesiredReplicas int32 `json:"desiredReplicas" protobuf:"varint,4,opt,name=desiredReplicas"` | ||||
|  | ||||
| 	// currentMetrics is the last read state of the metrics used by this autoscaler. | ||||
| 	// +optional | ||||
| 	CurrentMetrics []MetricStatus `json:"currentMetrics" protobuf:"bytes,5,rep,name=currentMetrics"` | ||||
|  | ||||
| 	// conditions is the set of conditions required for this autoscaler to scale its target, | ||||
| 	// and indicates whether or not those conditions are met. | ||||
| 	Conditions []HorizontalPodAutoscalerCondition `json:"conditions" protobuf:"bytes,6,rep,name=conditions"` | ||||
| } | ||||
|  | ||||
| // HorizontalPodAutoscalerConditionType are the valid conditions of | ||||
| // a HorizontalPodAutoscaler. | ||||
| type HorizontalPodAutoscalerConditionType string | ||||
|  | ||||
| var ( | ||||
| 	// ScalingActive indicates that the HPA controller is able to scale if necessary: | ||||
| 	// it's correctly configured, can fetch the desired metrics, and isn't disabled. | ||||
| 	ScalingActive HorizontalPodAutoscalerConditionType = "ScalingActive" | ||||
| 	// AbleToScale indicates a lack of transient issues which prevent scaling from occurring, | ||||
| 	// such as being in a backoff window, or being unable to access/update the target scale. | ||||
| 	AbleToScale HorizontalPodAutoscalerConditionType = "AbleToScale" | ||||
| 	// ScalingLimited indicates that the calculated scale based on metrics would be above or | ||||
| 	// below the range for the HPA, and has thus been capped. | ||||
| 	ScalingLimited HorizontalPodAutoscalerConditionType = "ScalingLimited" | ||||
| ) | ||||
|  | ||||
| // HorizontalPodAutoscalerCondition describes the state of | ||||
| // a HorizontalPodAutoscaler at a certain point. | ||||
| type HorizontalPodAutoscalerCondition struct { | ||||
| 	// type describes the current condition | ||||
| 	Type HorizontalPodAutoscalerConditionType `json:"type" protobuf:"bytes,1,name=type"` | ||||
| 	// status is the status of the condition (True, False, Unknown) | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,name=status"` | ||||
| 	// lastTransitionTime is the last time the condition transitioned from | ||||
| 	// one status to another | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,3,opt,name=lastTransitionTime"` | ||||
| 	// reason is the reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,4,opt,name=reason"` | ||||
| 	// message is a human-readable explanation containing details about | ||||
| 	// the transition | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,5,opt,name=message"` | ||||
| } | ||||
|  | ||||
| // MetricStatus describes the last-read state of a single metric. | ||||
| type MetricStatus struct { | ||||
| 	// type is the type of metric source.  It will be one of "Object", | ||||
| 	// "Pods" or "Resource", each corresponds to a matching field in the object. | ||||
| 	Type MetricSourceType `json:"type" protobuf:"bytes,1,name=type"` | ||||
|  | ||||
| 	// object refers to a metric describing a single kubernetes object | ||||
| 	// (for example, hits-per-second on an Ingress object). | ||||
| 	// +optional | ||||
| 	Object *ObjectMetricStatus `json:"object,omitempty" protobuf:"bytes,2,opt,name=object"` | ||||
| 	// pods refers to a metric describing each pod in the current scale target | ||||
| 	// (for example, transactions-processed-per-second).  The values will be | ||||
| 	// averaged together before being compared to the target value. | ||||
| 	// +optional | ||||
| 	Pods *PodsMetricStatus `json:"pods,omitempty" protobuf:"bytes,3,opt,name=pods"` | ||||
| 	// resource refers to a resource metric (such as those specified in | ||||
| 	// requests and limits) known to Kubernetes describing each pod in the | ||||
| 	// current scale target (e.g. CPU or memory). Such metrics are built in to | ||||
| 	// Kubernetes, and have special scaling options on top of those available | ||||
| 	// to normal per-pod metrics using the "pods" source. | ||||
| 	// +optional | ||||
| 	Resource *ResourceMetricStatus `json:"resource,omitempty" protobuf:"bytes,4,opt,name=resource"` | ||||
| 	// external refers to a global metric that is not associated | ||||
| 	// with any Kubernetes object. It allows autoscaling based on information | ||||
| 	// coming from components running outside of cluster | ||||
| 	// (for example length of queue in cloud messaging service, or | ||||
| 	// QPS from loadbalancer running outside of cluster). | ||||
| 	// +optional | ||||
| 	External *ExternalMetricStatus `json:"external,omitempty" protobuf:"bytes,5,opt,name=external"` | ||||
| } | ||||
|  | ||||
| // ObjectMetricStatus indicates the current value of a metric describing a | ||||
| // kubernetes object (for example, hits-per-second on an Ingress object). | ||||
| type ObjectMetricStatus struct { | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,1,name=metric"` | ||||
| 	// current contains the current value for the given metric | ||||
| 	Current MetricValueStatus `json:"current" protobuf:"bytes,2,name=current"` | ||||
|  | ||||
| 	DescribedObject CrossVersionObjectReference `json:"describedObject" protobuf:"bytes,3,name=describedObject"` | ||||
| } | ||||
|  | ||||
| // PodsMetricStatus indicates the current value of a metric describing each pod in | ||||
| // the current scale target (for example, transactions-processed-per-second). | ||||
| type PodsMetricStatus struct { | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,1,name=metric"` | ||||
| 	// current contains the current value for the given metric | ||||
| 	Current MetricValueStatus `json:"current" protobuf:"bytes,2,name=current"` | ||||
| } | ||||
|  | ||||
| // ResourceMetricStatus indicates the current value of a resource metric known to | ||||
| // Kubernetes, as specified in requests and limits, describing each pod in the | ||||
| // current scale target (e.g. CPU or memory).  Such metrics are built in to | ||||
| // Kubernetes, and have special scaling options on top of those available to | ||||
| // normal per-pod metrics using the "pods" source. | ||||
| type ResourceMetricStatus struct { | ||||
| 	// Name is the name of the resource in question. | ||||
| 	Name v1.ResourceName `json:"name" protobuf:"bytes,1,name=name"` | ||||
| 	// current contains the current value for the given metric | ||||
| 	Current MetricValueStatus `json:"current" protobuf:"bytes,2,name=current"` | ||||
| } | ||||
|  | ||||
| // ExternalMetricStatus indicates the current value of a global metric | ||||
| // not associated with any Kubernetes object. | ||||
| type ExternalMetricStatus struct { | ||||
| 	// metric identifies the target metric by name and selector | ||||
| 	Metric MetricIdentifier `json:"metric" protobuf:"bytes,1,name=metric"` | ||||
| 	// current contains the current value for the given metric | ||||
| 	Current MetricValueStatus `json:"current" protobuf:"bytes,2,name=current"` | ||||
| } | ||||
|  | ||||
| // MetricValueStatus holds the current value for a metric | ||||
| type MetricValueStatus struct { | ||||
| 	// value is the current value of the metric (as a quantity). | ||||
| 	// +optional | ||||
| 	Value *resource.Quantity `json:"value,omitempty" protobuf:"bytes,1,opt,name=value"` | ||||
| 	// averageValue is the current value of the average of the | ||||
| 	// metric across all relevant pods (as a quantity) | ||||
| 	// +optional | ||||
| 	AverageValue *resource.Quantity `json:"averageValue,omitempty" protobuf:"bytes,2,opt,name=averageValue"` | ||||
| 	// currentAverageUtilization is the current value of the average of the | ||||
| 	// resource metric across all relevant pods, represented as a percentage of | ||||
| 	// the requested value of the resource for the pods. | ||||
| 	// +optional | ||||
| 	AverageUtilization *int32 `json:"averageUtilization,omitempty" protobuf:"bytes,3,opt,name=averageUtilization"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // HorizontalPodAutoscalerList is a list of horizontal pod autoscaler objects. | ||||
| type HorizontalPodAutoscalerList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// metadata is the standard list metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// items is the list of horizontal pod autoscaler objects. | ||||
| 	Items []HorizontalPodAutoscaler `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										240
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										240
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,240 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v2beta2 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_CrossVersionObjectReference = map[string]string{ | ||||
| 	"":           "CrossVersionObjectReference contains enough information to let you identify the referred resource.", | ||||
| 	"kind":       "Kind of the referent; More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds\"", | ||||
| 	"name":       "Name of the referent; More info: http://kubernetes.io/docs/user-guide/identifiers#names", | ||||
| 	"apiVersion": "API version of the referent", | ||||
| } | ||||
|  | ||||
| func (CrossVersionObjectReference) SwaggerDoc() map[string]string { | ||||
| 	return map_CrossVersionObjectReference | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricSource = map[string]string{ | ||||
| 	"":       "ExternalMetricSource indicates how to scale on a metric not associated with any Kubernetes object (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| 	"metric": "metric identifies the target metric by name and selector", | ||||
| 	"target": "target specifies the target value for the given metric", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricSource | ||||
| } | ||||
|  | ||||
| var map_ExternalMetricStatus = map[string]string{ | ||||
| 	"":        "ExternalMetricStatus indicates the current value of a global metric not associated with any Kubernetes object.", | ||||
| 	"metric":  "metric identifies the target metric by name and selector", | ||||
| 	"current": "current contains the current value for the given metric", | ||||
| } | ||||
|  | ||||
| func (ExternalMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ExternalMetricStatus | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscaler = map[string]string{ | ||||
| 	"":         "HorizontalPodAutoscaler is the configuration for a horizontal pod autoscaler, which automatically manages the replica count of any resource implementing the scale subresource based on the metrics specified.", | ||||
| 	"metadata": "metadata is the standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "spec is the specification for the behaviour of the autoscaler. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status.", | ||||
| 	"status":   "status is the current information about the autoscaler.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscaler) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscaler | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerCondition = map[string]string{ | ||||
| 	"":                   "HorizontalPodAutoscalerCondition describes the state of a HorizontalPodAutoscaler at a certain point.", | ||||
| 	"type":               "type describes the current condition", | ||||
| 	"status":             "status is the status of the condition (True, False, Unknown)", | ||||
| 	"lastTransitionTime": "lastTransitionTime is the last time the condition transitioned from one status to another", | ||||
| 	"reason":             "reason is the reason for the condition's last transition.", | ||||
| 	"message":            "message is a human-readable explanation containing details about the transition", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerCondition | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerList = map[string]string{ | ||||
| 	"":         "HorizontalPodAutoscalerList is a list of horizontal pod autoscaler objects.", | ||||
| 	"metadata": "metadata is the standard list metadata.", | ||||
| 	"items":    "items is the list of horizontal pod autoscaler objects.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerList) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerList | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerSpec = map[string]string{ | ||||
| 	"":               "HorizontalPodAutoscalerSpec describes the desired functionality of the HorizontalPodAutoscaler.", | ||||
| 	"scaleTargetRef": "scaleTargetRef points to the target resource to scale, and is used to the pods for which metrics should be collected, as well as to actually change the replica count.", | ||||
| 	"minReplicas":    "minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. It defaults to 1 pod.", | ||||
| 	"maxReplicas":    "maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. It cannot be less that minReplicas.", | ||||
| 	"metrics":        "metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).  The desired replica count is calculated multiplying the ratio between the target value and the current value by the current number of pods.  Ergo, metrics used must decrease as the pod count is increased, and vice-versa.  See the individual metric source types for more information about how each type of metric must respond. If not set, the default metric will be set to 80% average CPU utilization.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerSpec | ||||
| } | ||||
|  | ||||
| var map_HorizontalPodAutoscalerStatus = map[string]string{ | ||||
| 	"":                   "HorizontalPodAutoscalerStatus describes the current status of a horizontal pod autoscaler.", | ||||
| 	"observedGeneration": "observedGeneration is the most recent generation observed by this autoscaler.", | ||||
| 	"lastScaleTime":      "lastScaleTime is the last time the HorizontalPodAutoscaler scaled the number of pods, used by the autoscaler to control how often the number of pods is changed.", | ||||
| 	"currentReplicas":    "currentReplicas is current number of replicas of pods managed by this autoscaler, as last seen by the autoscaler.", | ||||
| 	"desiredReplicas":    "desiredReplicas is the desired number of replicas of pods managed by this autoscaler, as last calculated by the autoscaler.", | ||||
| 	"currentMetrics":     "currentMetrics is the last read state of the metrics used by this autoscaler.", | ||||
| 	"conditions":         "conditions is the set of conditions required for this autoscaler to scale its target, and indicates whether or not those conditions are met.", | ||||
| } | ||||
|  | ||||
| func (HorizontalPodAutoscalerStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_HorizontalPodAutoscalerStatus | ||||
| } | ||||
|  | ||||
| var map_MetricIdentifier = map[string]string{ | ||||
| 	"":         "MetricIdentifier defines the name and optionally selector for a metric", | ||||
| 	"name":     "name is the name of the given metric", | ||||
| 	"selector": "selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.", | ||||
| } | ||||
|  | ||||
| func (MetricIdentifier) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricIdentifier | ||||
| } | ||||
|  | ||||
| var map_MetricSpec = map[string]string{ | ||||
| 	"":         "MetricSpec specifies how to scale based on a single metric (only `type` and one other matching field should be set at once).", | ||||
| 	"type":     "type is the type of metric source.  It should be one of \"Object\", \"Pods\" or \"Resource\", each mapping to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricSpec | ||||
| } | ||||
|  | ||||
| var map_MetricStatus = map[string]string{ | ||||
| 	"":         "MetricStatus describes the last-read state of a single metric.", | ||||
| 	"type":     "type is the type of metric source.  It will be one of \"Object\", \"Pods\" or \"Resource\", each corresponds to a matching field in the object.", | ||||
| 	"object":   "object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"pods":     "pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.", | ||||
| 	"resource": "resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"external": "external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).", | ||||
| } | ||||
|  | ||||
| func (MetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricStatus | ||||
| } | ||||
|  | ||||
| var map_MetricTarget = map[string]string{ | ||||
| 	"":                   "MetricTarget defines the target value, average value, or average utilization of a specific metric", | ||||
| 	"type":               "type represents whether the metric type is Utilization, Value, or AverageValue", | ||||
| 	"value":              "value is the target value of the metric (as a quantity).", | ||||
| 	"averageValue":       "averageValue is the target value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"averageUtilization": "averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type", | ||||
| } | ||||
|  | ||||
| func (MetricTarget) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricTarget | ||||
| } | ||||
|  | ||||
| var map_MetricValueStatus = map[string]string{ | ||||
| 	"":                   "MetricValueStatus holds the current value for a metric", | ||||
| 	"value":              "value is the current value of the metric (as a quantity).", | ||||
| 	"averageValue":       "averageValue is the current value of the average of the metric across all relevant pods (as a quantity)", | ||||
| 	"averageUtilization": "currentAverageUtilization is the current value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.", | ||||
| } | ||||
|  | ||||
| func (MetricValueStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_MetricValueStatus | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricSource = map[string]string{ | ||||
| 	"":       "ObjectMetricSource indicates how to scale on a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"target": "target specifies the target value for the given metric", | ||||
| 	"metric": "metric identifies the target metric by name and selector", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricSource | ||||
| } | ||||
|  | ||||
| var map_ObjectMetricStatus = map[string]string{ | ||||
| 	"":        "ObjectMetricStatus indicates the current value of a metric describing a kubernetes object (for example, hits-per-second on an Ingress object).", | ||||
| 	"metric":  "metric identifies the target metric by name and selector", | ||||
| 	"current": "current contains the current value for the given metric", | ||||
| } | ||||
|  | ||||
| func (ObjectMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ObjectMetricStatus | ||||
| } | ||||
|  | ||||
| var map_PodsMetricSource = map[string]string{ | ||||
| 	"":       "PodsMetricSource indicates how to scale on a metric describing each pod in the current scale target (for example, transactions-processed-per-second). The values will be averaged together before being compared to the target value.", | ||||
| 	"metric": "metric identifies the target metric by name and selector", | ||||
| 	"target": "target specifies the target value for the given metric", | ||||
| } | ||||
|  | ||||
| func (PodsMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricSource | ||||
| } | ||||
|  | ||||
| var map_PodsMetricStatus = map[string]string{ | ||||
| 	"":        "PodsMetricStatus indicates the current value of a metric describing each pod in the current scale target (for example, transactions-processed-per-second).", | ||||
| 	"metric":  "metric identifies the target metric by name and selector", | ||||
| 	"current": "current contains the current value for the given metric", | ||||
| } | ||||
|  | ||||
| func (PodsMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_PodsMetricStatus | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricSource = map[string]string{ | ||||
| 	"":       "ResourceMetricSource indicates how to scale on a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  The values will be averaged together before being compared to the target.  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.  Only one \"target\" type should be set.", | ||||
| 	"name":   "name is the name of the resource in question.", | ||||
| 	"target": "target specifies the target value for the given metric", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricSource) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricSource | ||||
| } | ||||
|  | ||||
| var map_ResourceMetricStatus = map[string]string{ | ||||
| 	"":        "ResourceMetricStatus indicates the current value of a resource metric known to Kubernetes, as specified in requests and limits, describing each pod in the current scale target (e.g. CPU or memory).  Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.", | ||||
| 	"name":    "Name is the name of the resource in question.", | ||||
| 	"current": "current contains the current value for the given metric", | ||||
| } | ||||
|  | ||||
| func (ResourceMetricStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_ResourceMetricStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										487
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										487
									
								
								vendor/k8s.io/api/autoscaling/v2beta2/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,487 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v2beta2 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CrossVersionObjectReference) DeepCopyInto(out *CrossVersionObjectReference) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CrossVersionObjectReference. | ||||
| func (in *CrossVersionObjectReference) DeepCopy() *CrossVersionObjectReference { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CrossVersionObjectReference) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricSource) DeepCopyInto(out *ExternalMetricSource) { | ||||
| 	*out = *in | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	in.Target.DeepCopyInto(&out.Target) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricSource. | ||||
| func (in *ExternalMetricSource) DeepCopy() *ExternalMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ExternalMetricStatus) DeepCopyInto(out *ExternalMetricStatus) { | ||||
| 	*out = *in | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	in.Current.DeepCopyInto(&out.Current) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalMetricStatus. | ||||
| func (in *ExternalMetricStatus) DeepCopy() *ExternalMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ExternalMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyInto(out *HorizontalPodAutoscaler) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscaler. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopy() *HorizontalPodAutoscaler { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscaler) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscaler) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopyInto(out *HorizontalPodAutoscalerCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerCondition. | ||||
| func (in *HorizontalPodAutoscalerCondition) DeepCopy() *HorizontalPodAutoscalerCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyInto(out *HorizontalPodAutoscalerList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]HorizontalPodAutoscaler, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerList. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopy() *HorizontalPodAutoscalerList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *HorizontalPodAutoscalerList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopyInto(out *HorizontalPodAutoscalerSpec) { | ||||
| 	*out = *in | ||||
| 	out.ScaleTargetRef = in.ScaleTargetRef | ||||
| 	if in.MinReplicas != nil { | ||||
| 		in, out := &in.MinReplicas, &out.MinReplicas | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Metrics != nil { | ||||
| 		in, out := &in.Metrics, &out.Metrics | ||||
| 		*out = make([]MetricSpec, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerSpec. | ||||
| func (in *HorizontalPodAutoscalerSpec) DeepCopy() *HorizontalPodAutoscalerSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopyInto(out *HorizontalPodAutoscalerStatus) { | ||||
| 	*out = *in | ||||
| 	if in.ObservedGeneration != nil { | ||||
| 		in, out := &in.ObservedGeneration, &out.ObservedGeneration | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.LastScaleTime != nil { | ||||
| 		in, out := &in.LastScaleTime, &out.LastScaleTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	if in.CurrentMetrics != nil { | ||||
| 		in, out := &in.CurrentMetrics, &out.CurrentMetrics | ||||
| 		*out = make([]MetricStatus, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]HorizontalPodAutoscalerCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HorizontalPodAutoscalerStatus. | ||||
| func (in *HorizontalPodAutoscalerStatus) DeepCopy() *HorizontalPodAutoscalerStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(HorizontalPodAutoscalerStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricIdentifier) DeepCopyInto(out *MetricIdentifier) { | ||||
| 	*out = *in | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(v1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricIdentifier. | ||||
| func (in *MetricIdentifier) DeepCopy() *MetricIdentifier { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricIdentifier) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricSpec) DeepCopyInto(out *MetricSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricSource) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricSpec. | ||||
| func (in *MetricSpec) DeepCopy() *MetricSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricStatus) DeepCopyInto(out *MetricStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Object != nil { | ||||
| 		in, out := &in.Object, &out.Object | ||||
| 		*out = new(ObjectMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Pods != nil { | ||||
| 		in, out := &in.Pods, &out.Pods | ||||
| 		*out = new(PodsMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.Resource != nil { | ||||
| 		in, out := &in.Resource, &out.Resource | ||||
| 		*out = new(ResourceMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.External != nil { | ||||
| 		in, out := &in.External, &out.External | ||||
| 		*out = new(ExternalMetricStatus) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricStatus. | ||||
| func (in *MetricStatus) DeepCopy() *MetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricTarget) DeepCopyInto(out *MetricTarget) { | ||||
| 	*out = *in | ||||
| 	if in.Value != nil { | ||||
| 		in, out := &in.Value, &out.Value | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.AverageUtilization != nil { | ||||
| 		in, out := &in.AverageUtilization, &out.AverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricTarget. | ||||
| func (in *MetricTarget) DeepCopy() *MetricTarget { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricTarget) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *MetricValueStatus) DeepCopyInto(out *MetricValueStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Value != nil { | ||||
| 		in, out := &in.Value, &out.Value | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.AverageValue != nil { | ||||
| 		in, out := &in.AverageValue, &out.AverageValue | ||||
| 		x := (*in).DeepCopy() | ||||
| 		*out = &x | ||||
| 	} | ||||
| 	if in.AverageUtilization != nil { | ||||
| 		in, out := &in.AverageUtilization, &out.AverageUtilization | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricValueStatus. | ||||
| func (in *MetricValueStatus) DeepCopy() *MetricValueStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(MetricValueStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricSource) DeepCopyInto(out *ObjectMetricSource) { | ||||
| 	*out = *in | ||||
| 	out.DescribedObject = in.DescribedObject | ||||
| 	in.Target.DeepCopyInto(&out.Target) | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricSource. | ||||
| func (in *ObjectMetricSource) DeepCopy() *ObjectMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ObjectMetricStatus) DeepCopyInto(out *ObjectMetricStatus) { | ||||
| 	*out = *in | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	in.Current.DeepCopyInto(&out.Current) | ||||
| 	out.DescribedObject = in.DescribedObject | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ObjectMetricStatus. | ||||
| func (in *ObjectMetricStatus) DeepCopy() *ObjectMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ObjectMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricSource) DeepCopyInto(out *PodsMetricSource) { | ||||
| 	*out = *in | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	in.Target.DeepCopyInto(&out.Target) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricSource. | ||||
| func (in *PodsMetricSource) DeepCopy() *PodsMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PodsMetricStatus) DeepCopyInto(out *PodsMetricStatus) { | ||||
| 	*out = *in | ||||
| 	in.Metric.DeepCopyInto(&out.Metric) | ||||
| 	in.Current.DeepCopyInto(&out.Current) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodsMetricStatus. | ||||
| func (in *PodsMetricStatus) DeepCopy() *PodsMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PodsMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricSource) DeepCopyInto(out *ResourceMetricSource) { | ||||
| 	*out = *in | ||||
| 	in.Target.DeepCopyInto(&out.Target) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricSource. | ||||
| func (in *ResourceMetricSource) DeepCopy() *ResourceMetricSource { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricSource) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ResourceMetricStatus) DeepCopyInto(out *ResourceMetricStatus) { | ||||
| 	*out = *in | ||||
| 	in.Current.DeepCopyInto(&out.Current) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ResourceMetricStatus. | ||||
| func (in *ResourceMetricStatus) DeepCopy() *ResourceMetricStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ResourceMetricStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/batch/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/batch/v1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1 // import "k8s.io/api/batch/v1" | ||||
							
								
								
									
										1633
									
								
								vendor/k8s.io/api/batch/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1633
									
								
								vendor/k8s.io/api/batch/v1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										184
									
								
								vendor/k8s.io/api/batch/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								vendor/k8s.io/api/batch/v1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,184 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.batch.v1; | ||||
|  | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1"; | ||||
|  | ||||
| // Job represents the configuration of a single job. | ||||
| message Job { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of a job. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional JobSpec spec = 2; | ||||
|  | ||||
|   // Current status of a job. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional JobStatus status = 3; | ||||
| } | ||||
|  | ||||
| // JobCondition describes current state of a job. | ||||
| message JobCondition { | ||||
|   // Type of job condition, Complete or Failed. | ||||
|   optional string type = 1; | ||||
|  | ||||
|   // Status of the condition, one of True, False, Unknown. | ||||
|   optional string status = 2; | ||||
|  | ||||
|   // Last time the condition was checked. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastProbeTime = 3; | ||||
|  | ||||
|   // Last time the condition transit from one status to another. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastTransitionTime = 4; | ||||
|  | ||||
|   // (brief) reason for the condition's last transition. | ||||
|   // +optional | ||||
|   optional string reason = 5; | ||||
|  | ||||
|   // Human readable message indicating details about last transition. | ||||
|   // +optional | ||||
|   optional string message = 6; | ||||
| } | ||||
|  | ||||
| // JobList is a collection of jobs. | ||||
| message JobList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // items is the list of Jobs. | ||||
|   repeated Job items = 2; | ||||
| } | ||||
|  | ||||
| // JobSpec describes how the job execution will look like. | ||||
| message JobSpec { | ||||
|   // Specifies the maximum desired number of pods the job should | ||||
|   // run at any given time. The actual number of pods running in steady state will | ||||
|   // be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), | ||||
|   // i.e. when the work left to do is less than max parallelism. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
|   // +optional | ||||
|   optional int32 parallelism = 1; | ||||
|  | ||||
|   // Specifies the desired number of successfully finished pods the | ||||
|   // job should be run with.  Setting to nil means that the success of any | ||||
|   // pod signals the success of all pods, and allows parallelism to have any positive | ||||
|   // value.  Setting to 1 means that parallelism is limited to 1 and the success of that | ||||
|   // pod signals the success of the job. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
|   // +optional | ||||
|   optional int32 completions = 2; | ||||
|  | ||||
|   // Specifies the duration in seconds relative to the startTime that the job may be active | ||||
|   // before the system tries to terminate it; value must be positive integer | ||||
|   // +optional | ||||
|   optional int64 activeDeadlineSeconds = 3; | ||||
|  | ||||
|   // Specifies the number of retries before marking this job failed. | ||||
|   // Defaults to 6 | ||||
|   // +optional | ||||
|   optional int32 backoffLimit = 7; | ||||
|  | ||||
|   // A label query over pods that should match the pod count. | ||||
|   // Normally, the system sets this field for you. | ||||
|   // More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector selector = 4; | ||||
|  | ||||
|   // manualSelector controls generation of pod labels and pod selectors. | ||||
|   // Leave `manualSelector` unset unless you are certain what you are doing. | ||||
|   // When false or unset, the system pick labels unique to this job | ||||
|   // and appends those labels to the pod template.  When true, | ||||
|   // the user is responsible for picking unique labels and specifying | ||||
|   // the selector.  Failure to pick a unique label may cause this | ||||
|   // and other jobs to not function correctly.  However, You may see | ||||
|   // `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` | ||||
|   // API. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/#specifying-your-own-pod-selector | ||||
|   // +optional | ||||
|   optional bool manualSelector = 5; | ||||
|  | ||||
|   // Describes the pod that will be created when executing a job. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
|   optional k8s.io.api.core.v1.PodTemplateSpec template = 6; | ||||
|  | ||||
|   // ttlSecondsAfterFinished limits the lifetime of a Job that has finished | ||||
|   // execution (either Complete or Failed). If this field is set, | ||||
|   // ttlSecondsAfterFinished after the Job finishes, it is eligible to be | ||||
|   // automatically deleted. When the Job is being deleted, its lifecycle | ||||
|   // guarantees (e.g. finalizers) will be honored. If this field is unset, | ||||
|   // the Job won't be automatically deleted. If this field is set to zero, | ||||
|   // the Job becomes eligible to be deleted immediately after it finishes. | ||||
|   // This field is alpha-level and is only honored by servers that enable the | ||||
|   // TTLAfterFinished feature. | ||||
|   // +optional | ||||
|   optional int32 ttlSecondsAfterFinished = 8; | ||||
| } | ||||
|  | ||||
| // JobStatus represents the current state of a Job. | ||||
| message JobStatus { | ||||
|   // The latest available observations of an object's current state. | ||||
|   // More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
|   // +optional | ||||
|   // +patchMergeKey=type | ||||
|   // +patchStrategy=merge | ||||
|   repeated JobCondition conditions = 1; | ||||
|  | ||||
|   // Represents time when the job was acknowledged by the job controller. | ||||
|   // It is not guaranteed to be set in happens-before order across separate operations. | ||||
|   // It is represented in RFC3339 form and is in UTC. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time startTime = 2; | ||||
|  | ||||
|   // Represents time when the job was completed. It is not guaranteed to | ||||
|   // be set in happens-before order across separate operations. | ||||
|   // It is represented in RFC3339 form and is in UTC. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time completionTime = 3; | ||||
|  | ||||
|   // The number of actively running pods. | ||||
|   // +optional | ||||
|   optional int32 active = 4; | ||||
|  | ||||
|   // The number of pods which reached phase Succeeded. | ||||
|   // +optional | ||||
|   optional int32 succeeded = 5; | ||||
|  | ||||
|   // The number of pods which reached phase Failed. | ||||
|   // +optional | ||||
|   optional int32 failed = 6; | ||||
| } | ||||
|  | ||||
							
								
								
									
										52
									
								
								vendor/k8s.io/api/batch/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/k8s.io/api/batch/v1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,52 @@ | ||||
| /* | ||||
| Copyright 2016 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 ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "batch" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Job{}, | ||||
| 		&JobList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										193
									
								
								vendor/k8s.io/api/batch/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										193
									
								
								vendor/k8s.io/api/batch/v1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,193 @@ | ||||
| /* | ||||
| Copyright 2016 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 ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Job represents the configuration of a single job. | ||||
| type Job struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of a job. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Current status of a job. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Status JobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // JobList is a collection of jobs. | ||||
| type JobList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// items is the list of Jobs. | ||||
| 	Items []Job `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // JobSpec describes how the job execution will look like. | ||||
| type JobSpec struct { | ||||
|  | ||||
| 	// Specifies the maximum desired number of pods the job should | ||||
| 	// run at any given time. The actual number of pods running in steady state will | ||||
| 	// be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), | ||||
| 	// i.e. when the work left to do is less than max parallelism. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
| 	// +optional | ||||
| 	Parallelism *int32 `json:"parallelism,omitempty" protobuf:"varint,1,opt,name=parallelism"` | ||||
|  | ||||
| 	// Specifies the desired number of successfully finished pods the | ||||
| 	// job should be run with.  Setting to nil means that the success of any | ||||
| 	// pod signals the success of all pods, and allows parallelism to have any positive | ||||
| 	// value.  Setting to 1 means that parallelism is limited to 1 and the success of that | ||||
| 	// pod signals the success of the job. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
| 	// +optional | ||||
| 	Completions *int32 `json:"completions,omitempty" protobuf:"varint,2,opt,name=completions"` | ||||
|  | ||||
| 	// Specifies the duration in seconds relative to the startTime that the job may be active | ||||
| 	// before the system tries to terminate it; value must be positive integer | ||||
| 	// +optional | ||||
| 	ActiveDeadlineSeconds *int64 `json:"activeDeadlineSeconds,omitempty" protobuf:"varint,3,opt,name=activeDeadlineSeconds"` | ||||
|  | ||||
| 	// Specifies the number of retries before marking this job failed. | ||||
| 	// Defaults to 6 | ||||
| 	// +optional | ||||
| 	BackoffLimit *int32 `json:"backoffLimit,omitempty" protobuf:"varint,7,opt,name=backoffLimit"` | ||||
|  | ||||
| 	// TODO enabled it when https://github.com/kubernetes/kubernetes/issues/28486 has been fixed | ||||
| 	// Optional number of failed pods to retain. | ||||
| 	// +optional | ||||
| 	// FailedPodsLimit *int32 `json:"failedPodsLimit,omitempty" protobuf:"varint,9,opt,name=failedPodsLimit"` | ||||
|  | ||||
| 	// A label query over pods that should match the pod count. | ||||
| 	// Normally, the system sets this field for you. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors | ||||
| 	// +optional | ||||
| 	Selector *metav1.LabelSelector `json:"selector,omitempty" protobuf:"bytes,4,opt,name=selector"` | ||||
|  | ||||
| 	// manualSelector controls generation of pod labels and pod selectors. | ||||
| 	// Leave `manualSelector` unset unless you are certain what you are doing. | ||||
| 	// When false or unset, the system pick labels unique to this job | ||||
| 	// and appends those labels to the pod template.  When true, | ||||
| 	// the user is responsible for picking unique labels and specifying | ||||
| 	// the selector.  Failure to pick a unique label may cause this | ||||
| 	// and other jobs to not function correctly.  However, You may see | ||||
| 	// `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` | ||||
| 	// API. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/#specifying-your-own-pod-selector | ||||
| 	// +optional | ||||
| 	ManualSelector *bool `json:"manualSelector,omitempty" protobuf:"varint,5,opt,name=manualSelector"` | ||||
|  | ||||
| 	// Describes the pod that will be created when executing a job. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
| 	Template v1.PodTemplateSpec `json:"template" protobuf:"bytes,6,opt,name=template"` | ||||
|  | ||||
| 	// ttlSecondsAfterFinished limits the lifetime of a Job that has finished | ||||
| 	// execution (either Complete or Failed). If this field is set, | ||||
| 	// ttlSecondsAfterFinished after the Job finishes, it is eligible to be | ||||
| 	// automatically deleted. When the Job is being deleted, its lifecycle | ||||
| 	// guarantees (e.g. finalizers) will be honored. If this field is unset, | ||||
| 	// the Job won't be automatically deleted. If this field is set to zero, | ||||
| 	// the Job becomes eligible to be deleted immediately after it finishes. | ||||
| 	// This field is alpha-level and is only honored by servers that enable the | ||||
| 	// TTLAfterFinished feature. | ||||
| 	// +optional | ||||
| 	TTLSecondsAfterFinished *int32 `json:"ttlSecondsAfterFinished,omitempty" protobuf:"varint,8,opt,name=ttlSecondsAfterFinished"` | ||||
| } | ||||
|  | ||||
| // JobStatus represents the current state of a Job. | ||||
| type JobStatus struct { | ||||
| 	// The latest available observations of an object's current state. | ||||
| 	// More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/ | ||||
| 	// +optional | ||||
| 	// +patchMergeKey=type | ||||
| 	// +patchStrategy=merge | ||||
| 	Conditions []JobCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type" protobuf:"bytes,1,rep,name=conditions"` | ||||
|  | ||||
| 	// Represents time when the job was acknowledged by the job controller. | ||||
| 	// It is not guaranteed to be set in happens-before order across separate operations. | ||||
| 	// It is represented in RFC3339 form and is in UTC. | ||||
| 	// +optional | ||||
| 	StartTime *metav1.Time `json:"startTime,omitempty" protobuf:"bytes,2,opt,name=startTime"` | ||||
|  | ||||
| 	// Represents time when the job was completed. It is not guaranteed to | ||||
| 	// be set in happens-before order across separate operations. | ||||
| 	// It is represented in RFC3339 form and is in UTC. | ||||
| 	// +optional | ||||
| 	CompletionTime *metav1.Time `json:"completionTime,omitempty" protobuf:"bytes,3,opt,name=completionTime"` | ||||
|  | ||||
| 	// The number of actively running pods. | ||||
| 	// +optional | ||||
| 	Active int32 `json:"active,omitempty" protobuf:"varint,4,opt,name=active"` | ||||
|  | ||||
| 	// The number of pods which reached phase Succeeded. | ||||
| 	// +optional | ||||
| 	Succeeded int32 `json:"succeeded,omitempty" protobuf:"varint,5,opt,name=succeeded"` | ||||
|  | ||||
| 	// The number of pods which reached phase Failed. | ||||
| 	// +optional | ||||
| 	Failed int32 `json:"failed,omitempty" protobuf:"varint,6,opt,name=failed"` | ||||
| } | ||||
|  | ||||
| type JobConditionType string | ||||
|  | ||||
| // These are valid conditions of a job. | ||||
| const ( | ||||
| 	// JobComplete means the job has completed its execution. | ||||
| 	JobComplete JobConditionType = "Complete" | ||||
| 	// JobFailed means the job has failed its execution. | ||||
| 	JobFailed JobConditionType = "Failed" | ||||
| ) | ||||
|  | ||||
| // JobCondition describes current state of a job. | ||||
| type JobCondition struct { | ||||
| 	// Type of job condition, Complete or Failed. | ||||
| 	Type JobConditionType `json:"type" protobuf:"bytes,1,opt,name=type,casttype=JobConditionType"` | ||||
| 	// Status of the condition, one of True, False, Unknown. | ||||
| 	Status v1.ConditionStatus `json:"status" protobuf:"bytes,2,opt,name=status,casttype=k8s.io/api/core/v1.ConditionStatus"` | ||||
| 	// Last time the condition was checked. | ||||
| 	// +optional | ||||
| 	LastProbeTime metav1.Time `json:"lastProbeTime,omitempty" protobuf:"bytes,3,opt,name=lastProbeTime"` | ||||
| 	// Last time the condition transit from one status to another. | ||||
| 	// +optional | ||||
| 	LastTransitionTime metav1.Time `json:"lastTransitionTime,omitempty" protobuf:"bytes,4,opt,name=lastTransitionTime"` | ||||
| 	// (brief) reason for the condition's last transition. | ||||
| 	// +optional | ||||
| 	Reason string `json:"reason,omitempty" protobuf:"bytes,5,opt,name=reason"` | ||||
| 	// Human readable message indicating details about last transition. | ||||
| 	// +optional | ||||
| 	Message string `json:"message,omitempty" protobuf:"bytes,6,opt,name=message"` | ||||
| } | ||||
							
								
								
									
										95
									
								
								vendor/k8s.io/api/batch/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								vendor/k8s.io/api/batch/v1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,95 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_Job = map[string]string{ | ||||
| 	"":         "Job represents the configuration of a single job.", | ||||
| 	"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 a job. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Current status of a job. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| } | ||||
|  | ||||
| func (Job) SwaggerDoc() map[string]string { | ||||
| 	return map_Job | ||||
| } | ||||
|  | ||||
| var map_JobCondition = map[string]string{ | ||||
| 	"":                   "JobCondition describes current state of a job.", | ||||
| 	"type":               "Type of job condition, Complete or Failed.", | ||||
| 	"status":             "Status of the condition, one of True, False, Unknown.", | ||||
| 	"lastProbeTime":      "Last time the condition was checked.", | ||||
| 	"lastTransitionTime": "Last time the condition transit from one status to another.", | ||||
| 	"reason":             "(brief) reason for the condition's last transition.", | ||||
| 	"message":            "Human readable message indicating details about last transition.", | ||||
| } | ||||
|  | ||||
| func (JobCondition) SwaggerDoc() map[string]string { | ||||
| 	return map_JobCondition | ||||
| } | ||||
|  | ||||
| var map_JobList = map[string]string{ | ||||
| 	"":         "JobList is a collection of jobs.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"items":    "items is the list of Jobs.", | ||||
| } | ||||
|  | ||||
| func (JobList) SwaggerDoc() map[string]string { | ||||
| 	return map_JobList | ||||
| } | ||||
|  | ||||
| var map_JobSpec = map[string]string{ | ||||
| 	"":                        "JobSpec describes how the job execution will look like.", | ||||
| 	"parallelism":             "Specifies the maximum desired number of pods the job should run at any given time. The actual number of pods running in steady state will be less than this number when ((.spec.completions - .status.successful) < .spec.parallelism), i.e. when the work left to do is less than max parallelism. More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/", | ||||
| 	"completions":             "Specifies the desired number of successfully finished pods the job should be run with.  Setting to nil means that the success of any pod signals the success of all pods, and allows parallelism to have any positive value.  Setting to 1 means that parallelism is limited to 1 and the success of that pod signals the success of the job. More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/", | ||||
| 	"activeDeadlineSeconds":   "Specifies the duration in seconds relative to the startTime that the job may be active before the system tries to terminate it; value must be positive integer", | ||||
| 	"backoffLimit":            "Specifies the number of retries before marking this job failed. Defaults to 6", | ||||
| 	"selector":                "A label query over pods that should match the pod count. Normally, the system sets this field for you. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors", | ||||
| 	"manualSelector":          "manualSelector controls generation of pod labels and pod selectors. Leave `manualSelector` unset unless you are certain what you are doing. When false or unset, the system pick labels unique to this job and appends those labels to the pod template.  When true, the user is responsible for picking unique labels and specifying the selector.  Failure to pick a unique label may cause this and other jobs to not function correctly.  However, You may see `manualSelector=true` in jobs that were created with the old `extensions/v1beta1` API. More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/#specifying-your-own-pod-selector", | ||||
| 	"template":                "Describes the pod that will be created when executing a job. More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/", | ||||
| 	"ttlSecondsAfterFinished": "ttlSecondsAfterFinished limits the lifetime of a Job that has finished execution (either Complete or Failed). If this field is set, ttlSecondsAfterFinished after the Job finishes, it is eligible to be automatically deleted. When the Job is being deleted, its lifecycle guarantees (e.g. finalizers) will be honored. If this field is unset, the Job won't be automatically deleted. If this field is set to zero, the Job becomes eligible to be deleted immediately after it finishes. This field is alpha-level and is only honored by servers that enable the TTLAfterFinished feature.", | ||||
| } | ||||
|  | ||||
| func (JobSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_JobSpec | ||||
| } | ||||
|  | ||||
| var map_JobStatus = map[string]string{ | ||||
| 	"":               "JobStatus represents the current state of a Job.", | ||||
| 	"conditions":     "The latest available observations of an object's current state. More info: https://kubernetes.io/docs/concepts/workloads/controllers/jobs-run-to-completion/", | ||||
| 	"startTime":      "Represents time when the job was acknowledged by the job controller. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC.", | ||||
| 	"completionTime": "Represents time when the job was completed. It is not guaranteed to be set in happens-before order across separate operations. It is represented in RFC3339 form and is in UTC.", | ||||
| 	"active":         "The number of actively running pods.", | ||||
| 	"succeeded":      "The number of pods which reached phase Succeeded.", | ||||
| 	"failed":         "The number of pods which reached phase Failed.", | ||||
| } | ||||
|  | ||||
| func (JobStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_JobStatus | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										188
									
								
								vendor/k8s.io/api/batch/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								vendor/k8s.io/api/batch/v1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,188 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Job) DeepCopyInto(out *Job) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Job. | ||||
| func (in *Job) DeepCopy() *Job { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Job) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Job) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobCondition) DeepCopyInto(out *JobCondition) { | ||||
| 	*out = *in | ||||
| 	in.LastProbeTime.DeepCopyInto(&out.LastProbeTime) | ||||
| 	in.LastTransitionTime.DeepCopyInto(&out.LastTransitionTime) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobCondition. | ||||
| func (in *JobCondition) DeepCopy() *JobCondition { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobCondition) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobList) DeepCopyInto(out *JobList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]Job, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobList. | ||||
| func (in *JobList) DeepCopy() *JobList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *JobList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobSpec) DeepCopyInto(out *JobSpec) { | ||||
| 	*out = *in | ||||
| 	if in.Parallelism != nil { | ||||
| 		in, out := &in.Parallelism, &out.Parallelism | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Completions != nil { | ||||
| 		in, out := &in.Completions, &out.Completions | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.ActiveDeadlineSeconds != nil { | ||||
| 		in, out := &in.ActiveDeadlineSeconds, &out.ActiveDeadlineSeconds | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.BackoffLimit != nil { | ||||
| 		in, out := &in.BackoffLimit, &out.BackoffLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Selector != nil { | ||||
| 		in, out := &in.Selector, &out.Selector | ||||
| 		*out = new(metav1.LabelSelector) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	if in.ManualSelector != nil { | ||||
| 		in, out := &in.ManualSelector, &out.ManualSelector | ||||
| 		*out = new(bool) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	if in.TTLSecondsAfterFinished != nil { | ||||
| 		in, out := &in.TTLSecondsAfterFinished, &out.TTLSecondsAfterFinished | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobSpec. | ||||
| func (in *JobSpec) DeepCopy() *JobSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobStatus) DeepCopyInto(out *JobStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Conditions != nil { | ||||
| 		in, out := &in.Conditions, &out.Conditions | ||||
| 		*out = make([]JobCondition, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.StartTime != nil { | ||||
| 		in, out := &in.StartTime, &out.StartTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	if in.CompletionTime != nil { | ||||
| 		in, out := &in.CompletionTime, &out.CompletionTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobStatus. | ||||
| func (in *JobStatus) DeepCopy() *JobStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/batch/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/batch/v1beta1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2017 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v1beta1 // import "k8s.io/api/batch/v1beta1" | ||||
							
								
								
									
										1496
									
								
								vendor/k8s.io/api/batch/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1496
									
								
								vendor/k8s.io/api/batch/v1beta1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										137
									
								
								vendor/k8s.io/api/batch/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								vendor/k8s.io/api/batch/v1beta1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,137 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.batch.v1beta1; | ||||
|  | ||||
| import "k8s.io/api/batch/v1/generated.proto"; | ||||
| import "k8s.io/api/core/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1beta1"; | ||||
|  | ||||
| // CronJob represents the configuration of a single cron job. | ||||
| message CronJob { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of a cron job, including the schedule. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional CronJobSpec spec = 2; | ||||
|  | ||||
|   // Current status of a cron job. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional CronJobStatus status = 3; | ||||
| } | ||||
|  | ||||
| // CronJobList is a collection of cron jobs. | ||||
| message CronJobList { | ||||
|   // Standard list metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // items is the list of CronJobs. | ||||
|   repeated CronJob items = 2; | ||||
| } | ||||
|  | ||||
| // CronJobSpec describes how the job execution will look like and when it will actually run. | ||||
| message CronJobSpec { | ||||
|   // The schedule in Cron format, see https://en.wikipedia.org/wiki/Cron. | ||||
|   optional string schedule = 1; | ||||
|  | ||||
|   // Optional deadline in seconds for starting the job if it misses scheduled | ||||
|   // time for any reason.  Missed jobs executions will be counted as failed ones. | ||||
|   // +optional | ||||
|   optional int64 startingDeadlineSeconds = 2; | ||||
|  | ||||
|   // Specifies how to treat concurrent executions of a Job. | ||||
|   // Valid values are: | ||||
|   // - "Allow" (default): allows CronJobs to run concurrently; | ||||
|   // - "Forbid": forbids concurrent runs, skipping next run if previous run hasn't finished yet; | ||||
|   // - "Replace": cancels currently running job and replaces it with a new one | ||||
|   // +optional | ||||
|   optional string concurrencyPolicy = 3; | ||||
|  | ||||
|   // This flag tells the controller to suspend subsequent executions, it does | ||||
|   // not apply to already started executions.  Defaults to false. | ||||
|   // +optional | ||||
|   optional bool suspend = 4; | ||||
|  | ||||
|   // Specifies the job that will be created when executing a CronJob. | ||||
|   optional JobTemplateSpec jobTemplate = 5; | ||||
|  | ||||
|   // The number of successful finished jobs to retain. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 3. | ||||
|   // +optional | ||||
|   optional int32 successfulJobsHistoryLimit = 6; | ||||
|  | ||||
|   // The number of failed finished jobs to retain. | ||||
|   // This is a pointer to distinguish between explicit zero and not specified. | ||||
|   // Defaults to 1. | ||||
|   // +optional | ||||
|   optional int32 failedJobsHistoryLimit = 7; | ||||
| } | ||||
|  | ||||
| // CronJobStatus represents the current state of a cron job. | ||||
| message CronJobStatus { | ||||
|   // A list of pointers to currently running jobs. | ||||
|   // +optional | ||||
|   repeated k8s.io.api.core.v1.ObjectReference active = 1; | ||||
|  | ||||
|   // Information when was the last time the job was successfully scheduled. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.Time lastScheduleTime = 4; | ||||
| } | ||||
|  | ||||
| // JobTemplate describes a template for creating copies of a predefined pod. | ||||
| message JobTemplate { | ||||
|   // Standard object's metadata. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Defines jobs that will be created from this template. | ||||
|   // https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional JobTemplateSpec template = 2; | ||||
| } | ||||
|  | ||||
| // JobTemplateSpec describes the data a Job should have when created from a template | ||||
| message JobTemplateSpec { | ||||
|   // Standard object's metadata of the jobs created from this template. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Specification of the desired behavior of the job. | ||||
|   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
|   // +optional | ||||
|   optional k8s.io.api.batch.v1.JobSpec spec = 2; | ||||
| } | ||||
|  | ||||
							
								
								
									
										53
									
								
								vendor/k8s.io/api/batch/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								vendor/k8s.io/api/batch/v1beta1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| /* | ||||
| Copyright 2017 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| // GroupName is the group name use in this package | ||||
| const GroupName = "batch" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1beta1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&JobTemplate{}, | ||||
| 		&CronJob{}, | ||||
| 		&CronJobList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										158
									
								
								vendor/k8s.io/api/batch/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/k8s.io/api/batch/v1beta1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,158 @@ | ||||
| /* | ||||
| Copyright 2017 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 v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	batchv1 "k8s.io/api/batch/v1" | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // JobTemplate describes a template for creating copies of a predefined pod. | ||||
| type JobTemplate struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Defines jobs that will be created from this template. | ||||
| 	// https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Template JobTemplateSpec `json:"template,omitempty" protobuf:"bytes,2,opt,name=template"` | ||||
| } | ||||
|  | ||||
| // JobTemplateSpec describes the data a Job should have when created from a template | ||||
| type JobTemplateSpec struct { | ||||
| 	// Standard object's metadata of the jobs created from this template. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of the job. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec batchv1.JobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // CronJob represents the configuration of a single cron job. | ||||
| type CronJob struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Specification of the desired behavior of a cron job, including the schedule. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Spec CronJobSpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||
|  | ||||
| 	// Current status of a cron job. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status | ||||
| 	// +optional | ||||
| 	Status CronJobStatus `json:"status,omitempty" protobuf:"bytes,3,opt,name=status"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // CronJobList is a collection of cron jobs. | ||||
| type CronJobList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
|  | ||||
| 	// Standard list metadata. | ||||
| 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// items is the list of CronJobs. | ||||
| 	Items []CronJob `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // CronJobSpec describes how the job execution will look like and when it will actually run. | ||||
| type CronJobSpec struct { | ||||
|  | ||||
| 	// The schedule in Cron format, see https://en.wikipedia.org/wiki/Cron. | ||||
| 	Schedule string `json:"schedule" protobuf:"bytes,1,opt,name=schedule"` | ||||
|  | ||||
| 	// Optional deadline in seconds for starting the job if it misses scheduled | ||||
| 	// time for any reason.  Missed jobs executions will be counted as failed ones. | ||||
| 	// +optional | ||||
| 	StartingDeadlineSeconds *int64 `json:"startingDeadlineSeconds,omitempty" protobuf:"varint,2,opt,name=startingDeadlineSeconds"` | ||||
|  | ||||
| 	// Specifies how to treat concurrent executions of a Job. | ||||
| 	// Valid values are: | ||||
| 	// - "Allow" (default): allows CronJobs to run concurrently; | ||||
| 	// - "Forbid": forbids concurrent runs, skipping next run if previous run hasn't finished yet; | ||||
| 	// - "Replace": cancels currently running job and replaces it with a new one | ||||
| 	// +optional | ||||
| 	ConcurrencyPolicy ConcurrencyPolicy `json:"concurrencyPolicy,omitempty" protobuf:"bytes,3,opt,name=concurrencyPolicy,casttype=ConcurrencyPolicy"` | ||||
|  | ||||
| 	// This flag tells the controller to suspend subsequent executions, it does | ||||
| 	// not apply to already started executions.  Defaults to false. | ||||
| 	// +optional | ||||
| 	Suspend *bool `json:"suspend,omitempty" protobuf:"varint,4,opt,name=suspend"` | ||||
|  | ||||
| 	// Specifies the job that will be created when executing a CronJob. | ||||
| 	JobTemplate JobTemplateSpec `json:"jobTemplate" protobuf:"bytes,5,opt,name=jobTemplate"` | ||||
|  | ||||
| 	// The number of successful finished jobs to retain. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 3. | ||||
| 	// +optional | ||||
| 	SuccessfulJobsHistoryLimit *int32 `json:"successfulJobsHistoryLimit,omitempty" protobuf:"varint,6,opt,name=successfulJobsHistoryLimit"` | ||||
|  | ||||
| 	// The number of failed finished jobs to retain. | ||||
| 	// This is a pointer to distinguish between explicit zero and not specified. | ||||
| 	// Defaults to 1. | ||||
| 	// +optional | ||||
| 	FailedJobsHistoryLimit *int32 `json:"failedJobsHistoryLimit,omitempty" protobuf:"varint,7,opt,name=failedJobsHistoryLimit"` | ||||
| } | ||||
|  | ||||
| // ConcurrencyPolicy describes how the job will be handled. | ||||
| // Only one of the following concurrent policies may be specified. | ||||
| // If none of the following policies is specified, the default one | ||||
| // is AllowConcurrent. | ||||
| type ConcurrencyPolicy string | ||||
|  | ||||
| const ( | ||||
| 	// AllowConcurrent allows CronJobs to run concurrently. | ||||
| 	AllowConcurrent ConcurrencyPolicy = "Allow" | ||||
|  | ||||
| 	// ForbidConcurrent forbids concurrent runs, skipping next run if previous | ||||
| 	// hasn't finished yet. | ||||
| 	ForbidConcurrent ConcurrencyPolicy = "Forbid" | ||||
|  | ||||
| 	// ReplaceConcurrent cancels currently running job and replaces it with a new one. | ||||
| 	ReplaceConcurrent ConcurrencyPolicy = "Replace" | ||||
| ) | ||||
|  | ||||
| // CronJobStatus represents the current state of a cron job. | ||||
| type CronJobStatus struct { | ||||
| 	// A list of pointers to currently running jobs. | ||||
| 	// +optional | ||||
| 	Active []v1.ObjectReference `json:"active,omitempty" protobuf:"bytes,1,rep,name=active"` | ||||
|  | ||||
| 	// Information when was the last time the job was successfully scheduled. | ||||
| 	// +optional | ||||
| 	LastScheduleTime *metav1.Time `json:"lastScheduleTime,omitempty" protobuf:"bytes,4,opt,name=lastScheduleTime"` | ||||
| } | ||||
							
								
								
									
										96
									
								
								vendor/k8s.io/api/batch/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								vendor/k8s.io/api/batch/v1beta1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,96 @@ | ||||
| /* | ||||
| 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. | ||||
| */ | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_CronJob = map[string]string{ | ||||
| 	"":         "CronJob represents the configuration of a single cron job.", | ||||
| 	"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 a cron job, including the schedule. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| 	"status":   "Current status of a cron job. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| } | ||||
|  | ||||
| func (CronJob) SwaggerDoc() map[string]string { | ||||
| 	return map_CronJob | ||||
| } | ||||
|  | ||||
| var map_CronJobList = map[string]string{ | ||||
| 	"":         "CronJobList is a collection of cron jobs.", | ||||
| 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"items":    "items is the list of CronJobs.", | ||||
| } | ||||
|  | ||||
| func (CronJobList) SwaggerDoc() map[string]string { | ||||
| 	return map_CronJobList | ||||
| } | ||||
|  | ||||
| var map_CronJobSpec = map[string]string{ | ||||
| 	"":                           "CronJobSpec describes how the job execution will look like and when it will actually run.", | ||||
| 	"schedule":                   "The schedule in Cron format, see https://en.wikipedia.org/wiki/Cron.", | ||||
| 	"startingDeadlineSeconds":    "Optional deadline in seconds for starting the job if it misses scheduled time for any reason.  Missed jobs executions will be counted as failed ones.", | ||||
| 	"concurrencyPolicy":          "Specifies how to treat concurrent executions of a Job. Valid values are: - \"Allow\" (default): allows CronJobs to run concurrently; - \"Forbid\": forbids concurrent runs, skipping next run if previous run hasn't finished yet; - \"Replace\": cancels currently running job and replaces it with a new one", | ||||
| 	"suspend":                    "This flag tells the controller to suspend subsequent executions, it does not apply to already started executions.  Defaults to false.", | ||||
| 	"jobTemplate":                "Specifies the job that will be created when executing a CronJob.", | ||||
| 	"successfulJobsHistoryLimit": "The number of successful finished jobs to retain. This is a pointer to distinguish between explicit zero and not specified. Defaults to 3.", | ||||
| 	"failedJobsHistoryLimit":     "The number of failed finished jobs to retain. This is a pointer to distinguish between explicit zero and not specified. Defaults to 1.", | ||||
| } | ||||
|  | ||||
| func (CronJobSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_CronJobSpec | ||||
| } | ||||
|  | ||||
| var map_CronJobStatus = map[string]string{ | ||||
| 	"":                 "CronJobStatus represents the current state of a cron job.", | ||||
| 	"active":           "A list of pointers to currently running jobs.", | ||||
| 	"lastScheduleTime": "Information when was the last time the job was successfully scheduled.", | ||||
| } | ||||
|  | ||||
| func (CronJobStatus) SwaggerDoc() map[string]string { | ||||
| 	return map_CronJobStatus | ||||
| } | ||||
|  | ||||
| var map_JobTemplate = map[string]string{ | ||||
| 	"":         "JobTemplate 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": "Defines jobs that will be created from this template. https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| } | ||||
|  | ||||
| func (JobTemplate) SwaggerDoc() map[string]string { | ||||
| 	return map_JobTemplate | ||||
| } | ||||
|  | ||||
| var map_JobTemplateSpec = map[string]string{ | ||||
| 	"":         "JobTemplateSpec describes the data a Job should have when created from a template", | ||||
| 	"metadata": "Standard object's metadata of the jobs created from this template. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||
| 	"spec":     "Specification of the desired behavior of the job. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status", | ||||
| } | ||||
|  | ||||
| func (JobTemplateSpec) SwaggerDoc() map[string]string { | ||||
| 	return map_JobTemplateSpec | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										194
									
								
								vendor/k8s.io/api/batch/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								vendor/k8s.io/api/batch/v1beta1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,194 @@ | ||||
| // +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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1beta1 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/api/core/v1" | ||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||
| ) | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CronJob) DeepCopyInto(out *CronJob) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	in.Status.DeepCopyInto(&out.Status) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CronJob. | ||||
| func (in *CronJob) DeepCopy() *CronJob { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CronJob) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *CronJob) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CronJobList) DeepCopyInto(out *CronJobList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]CronJob, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CronJobList. | ||||
| func (in *CronJobList) DeepCopy() *CronJobList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CronJobList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *CronJobList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CronJobSpec) DeepCopyInto(out *CronJobSpec) { | ||||
| 	*out = *in | ||||
| 	if in.StartingDeadlineSeconds != nil { | ||||
| 		in, out := &in.StartingDeadlineSeconds, &out.StartingDeadlineSeconds | ||||
| 		*out = new(int64) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.Suspend != nil { | ||||
| 		in, out := &in.Suspend, &out.Suspend | ||||
| 		*out = new(bool) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	in.JobTemplate.DeepCopyInto(&out.JobTemplate) | ||||
| 	if in.SuccessfulJobsHistoryLimit != nil { | ||||
| 		in, out := &in.SuccessfulJobsHistoryLimit, &out.SuccessfulJobsHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	if in.FailedJobsHistoryLimit != nil { | ||||
| 		in, out := &in.FailedJobsHistoryLimit, &out.FailedJobsHistoryLimit | ||||
| 		*out = new(int32) | ||||
| 		**out = **in | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CronJobSpec. | ||||
| func (in *CronJobSpec) DeepCopy() *CronJobSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CronJobSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *CronJobStatus) DeepCopyInto(out *CronJobStatus) { | ||||
| 	*out = *in | ||||
| 	if in.Active != nil { | ||||
| 		in, out := &in.Active, &out.Active | ||||
| 		*out = make([]v1.ObjectReference, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.LastScheduleTime != nil { | ||||
| 		in, out := &in.LastScheduleTime, &out.LastScheduleTime | ||||
| 		*out = (*in).DeepCopy() | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CronJobStatus. | ||||
| func (in *CronJobStatus) DeepCopy() *CronJobStatus { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(CronJobStatus) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobTemplate) DeepCopyInto(out *JobTemplate) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Template.DeepCopyInto(&out.Template) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobTemplate. | ||||
| func (in *JobTemplate) DeepCopy() *JobTemplate { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobTemplate) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *JobTemplate) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *JobTemplateSpec) DeepCopyInto(out *JobTemplateSpec) { | ||||
| 	*out = *in | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	in.Spec.DeepCopyInto(&out.Spec) | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new JobTemplateSpec. | ||||
| func (in *JobTemplateSpec) DeepCopy() *JobTemplateSpec { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(JobTemplateSpec) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/k8s.io/api/batch/v2alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/k8s.io/api/batch/v2alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| /* | ||||
| Copyright 2016 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| package v2alpha1 // import "k8s.io/api/batch/v2alpha1" | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user