Class V1FieldSelectorAttributes

java.lang.Object
io.kubernetes.client.openapi.models.V1FieldSelectorAttributes

@Generated(value="org.openapitools.codegen.languages.JavaClientCodegen", date="2025-02-04T19:05:53.712211Z[Etc/UTC]", comments="Generator version: 7.6.0") public class V1FieldSelectorAttributes extends Object
FieldSelectorAttributes indicates a field limited access. Webhook authors are encouraged to * ensure rawSelector and requirements are not both set * consider the requirements field if set * not try to parse or consider the rawSelector field if set. This is to avoid another CVE-2022-2880 (i.e. getting different systems to agree on how exactly to parse a query is not something we want), see https://www.oxeye.io/resources/golang-parameter-smuggling-attack for more details. For the *SubjectAccessReview endpoints of the kube-apiserver: * If rawSelector is empty and requirements are empty, the request is not limited. * If rawSelector is present and requirements are empty, the rawSelector will be parsed and limited if the parsing succeeds. * If rawSelector is empty and requirements are present, the requirements should be honored * If rawSelector is present and requirements are present, the request is invalid.
  • Field Details

  • Constructor Details

    • V1FieldSelectorAttributes

      public V1FieldSelectorAttributes()
  • Method Details

    • rawSelector

      public V1FieldSelectorAttributes rawSelector(String rawSelector)
    • getRawSelector

      @Nullable public String getRawSelector()
      rawSelector is the serialization of a field selector that would be included in a query parameter. Webhook implementations are encouraged to ignore rawSelector. The kube-apiserver's *SubjectAccessReview will parse the rawSelector as long as the requirements are not present.
      Returns:
      rawSelector
    • setRawSelector

      public void setRawSelector(String rawSelector)
    • requirements

      public V1FieldSelectorAttributes requirements(List<V1FieldSelectorRequirement> requirements)
    • addRequirementsItem

      public V1FieldSelectorAttributes addRequirementsItem(V1FieldSelectorRequirement requirementsItem)
    • getRequirements

      @Nullable public List<V1FieldSelectorRequirement> getRequirements()
      requirements is the parsed interpretation of a field selector. All requirements must be met for a resource instance to match the selector. Webhook implementations should handle requirements, but how to handle them is up to the webhook. Since requirements can only limit the request, it is safe to authorize as unlimited request if the requirements are not understood.
      Returns:
      requirements
    • setRequirements

      public void setRequirements(List<V1FieldSelectorRequirement> requirements)
    • equals

      public boolean equals(Object o)
      Overrides:
      equals in class Object
    • hashCode

      public int hashCode()
      Overrides:
      hashCode in class Object
    • toString

      public String toString()
      Overrides:
      toString in class Object
    • validateJsonElement

      public static void validateJsonElement(com.google.gson.JsonElement jsonElement) throws IOException
      Validates the JSON Element and throws an exception if issues found
      Parameters:
      jsonElement - JSON Element
      Throws:
      IOException - if the JSON Element is invalid with respect to V1FieldSelectorAttributes
    • fromJson

      public static V1FieldSelectorAttributes fromJson(String jsonString) throws IOException
      Create an instance of V1FieldSelectorAttributes given an JSON string
      Parameters:
      jsonString - JSON string
      Returns:
      An instance of V1FieldSelectorAttributes
      Throws:
      IOException - if the JSON string is invalid with respect to V1FieldSelectorAttributes
    • toJson

      public String toJson()
      Convert an instance of V1FieldSelectorAttributes to an JSON string
      Returns:
      JSON string