{-
   Kubernetes

   No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)

   OpenAPI Version: 3.0.1
   Kubernetes API version: release-1.32
   Generated by OpenAPI Generator (https://openapi-generator.tech)
-}

{-|
Module : Kubernetes.OpenAPI.API.InternalApiserverV1alpha1
-}

{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MonoLocalBinds #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE OverloadedStrings #-}
{-# OPTIONS_GHC -fno-warn-name-shadowing -fno-warn-unused-binds -fno-warn-unused-imports #-}

module Kubernetes.OpenAPI.API.InternalApiserverV1alpha1 where

import Kubernetes.OpenAPI.Core
import Kubernetes.OpenAPI.MimeTypes
import Kubernetes.OpenAPI.Model as M

import qualified Data.Aeson as A
import qualified Data.ByteString as B
import qualified Data.ByteString.Lazy as BL
import qualified Data.Data as P (Typeable, TypeRep, typeOf, typeRep)
import qualified Data.Foldable as P
import qualified Data.Map as Map
import qualified Data.Maybe as P
import qualified Data.Proxy as P (Proxy(..))
import qualified Data.Set as Set
import qualified Data.String as P
import qualified Data.Text as T
import qualified Data.Text.Encoding as T
import qualified Data.Text.Lazy as TL
import qualified Data.Text.Lazy.Encoding as TL
import qualified Data.Time as TI
import qualified Network.HTTP.Client.MultipartFormData as NH
import qualified Network.HTTP.Media as ME
import qualified Network.HTTP.Types as NH
import qualified Web.FormUrlEncoded as WH
import qualified Web.HttpApiData as WH

import Data.Text (Text)
import GHC.Base ((<|>))

import Prelude ((==),(/=),($), (.),(<$>),(<*>),(>>=),Maybe(..),Bool(..),Char,Double,FilePath,Float,Int,Integer,String,fmap,undefined,mempty,maybe,pure,Monad,Applicative,Functor)
import qualified Prelude as P

-- * Operations


-- ** InternalApiserverV1alpha1

-- *** createStorageVersion

-- | @POST \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions@
-- 
-- create a StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
createStorageVersion
  :: (Consumes CreateStorageVersion contentType, MimeRender contentType V1alpha1StorageVersion)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1alpha1StorageVersion -- ^ "body"
  -> KubernetesRequest CreateStorageVersion contentType V1alpha1StorageVersion accept
createStorageVersion :: forall contentType accept.
(Consumes CreateStorageVersion contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
ContentType contentType
-> Accept accept
-> V1alpha1StorageVersion
-> KubernetesRequest
     CreateStorageVersion contentType V1alpha1StorageVersion accept
createStorageVersion ContentType contentType
_  Accept accept
_ V1alpha1StorageVersion
body =
  Method
-> [ByteString]
-> KubernetesRequest
     CreateStorageVersion contentType V1alpha1StorageVersion accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"POST" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions"]
    KubernetesRequest
  CreateStorageVersion contentType V1alpha1StorageVersion accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     CreateStorageVersion contentType V1alpha1StorageVersion accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)
    KubernetesRequest
  CreateStorageVersion contentType V1alpha1StorageVersion accept
-> V1alpha1StorageVersion
-> KubernetesRequest
     CreateStorageVersion contentType V1alpha1StorageVersion accept
forall req param contentType res accept.
(HasBodyParam req param, Consumes req contentType,
 MimeRender contentType param) =>
KubernetesRequest req contentType res accept
-> param -> KubernetesRequest req contentType res accept
forall contentType res accept.
(Consumes CreateStorageVersion contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
KubernetesRequest CreateStorageVersion contentType res accept
-> V1alpha1StorageVersion
-> KubernetesRequest CreateStorageVersion contentType res accept
`setBodyParam` V1alpha1StorageVersion
body

data CreateStorageVersion 
instance HasBodyParam CreateStorageVersion V1alpha1StorageVersion 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam CreateStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest CreateStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest CreateStorageVersion contentType res accept
applyOptionalParam KubernetesRequest CreateStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest CreateStorageVersion contentType res accept
req KubernetesRequest CreateStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest CreateStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam CreateStorageVersion DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest CreateStorageVersion contentType res accept
-> DryRun
-> KubernetesRequest CreateStorageVersion contentType res accept
applyOptionalParam KubernetesRequest CreateStorageVersion contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest CreateStorageVersion contentType res accept
req KubernetesRequest CreateStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest CreateStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldManager" - fieldManager is a name associated with the actor or entity that is making these changes. The value must be less than or 128 characters long, and only contain printable characters, as defined by https://golang.org/pkg/unicode/#IsPrint.
instance HasOptionalParam CreateStorageVersion FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest CreateStorageVersion contentType res accept
-> FieldManager
-> KubernetesRequest CreateStorageVersion contentType res accept
applyOptionalParam KubernetesRequest CreateStorageVersion contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest CreateStorageVersion contentType res accept
req KubernetesRequest CreateStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest CreateStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldManager", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldValidation" - fieldValidation instructs the server on how to handle objects in the request (POST/PUT/PATCH) containing unknown or duplicate fields. Valid values are: - Ignore: This will ignore any unknown fields that are silently dropped from the object, and will ignore all but the last duplicate field that the decoder encounters. This is the default behavior prior to v1.23. - Warn: This will send a warning via the standard warning response header for each unknown field that is dropped from the object, and for each duplicate field that is encountered. The request will still succeed if there are no other errors, and will only persist the last of any duplicate fields. This is the default in v1.23+ - Strict: This will fail the request with a BadRequest error if any unknown fields would be dropped from the object, or if any duplicate fields are present. The error returned from the server will contain all unknown and duplicate fields encountered.
instance HasOptionalParam CreateStorageVersion FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest CreateStorageVersion contentType res accept
-> FieldValidation
-> KubernetesRequest CreateStorageVersion contentType res accept
applyOptionalParam KubernetesRequest CreateStorageVersion contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest CreateStorageVersion contentType res accept
req KubernetesRequest CreateStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest CreateStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldValidation", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | @*/*@
instance MimeType mtype => Consumes CreateStorageVersion mtype

-- | @application/json@
instance Produces CreateStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces CreateStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces CreateStorageVersion MimeCbor
-- | @application/yaml@
instance Produces CreateStorageVersion MimeYaml


-- *** deleteCollectionStorageVersion

-- | @DELETE \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions@
-- 
-- delete collection of StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
deleteCollectionStorageVersion
  :: (Consumes DeleteCollectionStorageVersion contentType)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> KubernetesRequest DeleteCollectionStorageVersion contentType V1Status accept
deleteCollectionStorageVersion :: forall contentType accept.
Consumes DeleteCollectionStorageVersion contentType =>
ContentType contentType
-> Accept accept
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType V1Status accept
deleteCollectionStorageVersion ContentType contentType
_  Accept accept
_ =
  Method
-> [ByteString]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType V1Status accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"DELETE" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions"]
    KubernetesRequest
  DeleteCollectionStorageVersion contentType V1Status accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType V1Status accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data DeleteCollectionStorageVersion 
instance HasBodyParam DeleteCollectionStorageVersion V1DeleteOptions 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam DeleteCollectionStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "continue" - The continue option should be set when retrieving more results from the server. Since this value is server defined, clients may only use the continue value from a previous query result with identical query parameters (except for the value of continue) and the server may reject a continue value it does not recognize. If the specified continue value is no longer valid whether due to expiration (generally five to fifteen minutes) or a configuration change on the server, the server will respond with a 410 ResourceExpired error together with a continue token. If the client needs a consistent list, it must restart their list without the continue field. Otherwise, the client may send another list request with the token received with the 410 error, the server will respond with a list starting from the next key, but from the latest snapshot, which is inconsistent from the previous list results - objects that are created, modified, or deleted after the first list request will be included in the response, as long as their keys are after the \"next key\".  This field is not supported when watch is true. Clients may start a watch from the last resourceVersion value returned by the server and not miss any modifications.
instance HasOptionalParam DeleteCollectionStorageVersion Continue where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> Continue
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (Continue Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"continue", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam DeleteCollectionStorageVersion DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> DryRun
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldSelector" - A selector to restrict the list of returned objects by their fields. Defaults to everything.
instance HasOptionalParam DeleteCollectionStorageVersion FieldSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> FieldSelector
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (FieldSelector Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldSelector", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "gracePeriodSeconds" - The duration in seconds before the object should be deleted. Value must be non-negative integer. The value zero indicates delete immediately. If this value is nil, the default grace period for the specified type will be used. Defaults to a per object value if not specified. zero means delete immediately.
instance HasOptionalParam DeleteCollectionStorageVersion GracePeriodSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> GracePeriodSeconds
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (GracePeriodSeconds Int
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"gracePeriodSeconds", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | /Optional Param/ "ignoreStoreReadErrorWithClusterBreakingPotential" - if set to true, it will trigger an unsafe deletion of the resource in case the normal deletion flow fails with a corrupt object error. A resource is considered corrupt if it can not be retrieved from the underlying storage successfully because of a) its data can not be transformed e.g. decryption failure, or b) it fails to decode into an object. NOTE: unsafe deletion ignores finalizer constraints, skips precondition checks, and removes the object from the storage. WARNING: This may potentially break the cluster if the workload associated with the resource being unsafe-deleted relies on normal deletion flow. Use only if you REALLY know what you are doing. The default value is false, and the user must opt in to enable it
instance HasOptionalParam DeleteCollectionStorageVersion IgnoreStoreReadErrorWithClusterBreakingPotential where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> IgnoreStoreReadErrorWithClusterBreakingPotential
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (IgnoreStoreReadErrorWithClusterBreakingPotential Bool
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"ignoreStoreReadErrorWithClusterBreakingPotential", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "labelSelector" - A selector to restrict the list of returned objects by their labels. Defaults to everything.
instance HasOptionalParam DeleteCollectionStorageVersion LabelSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> LabelSelector
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (LabelSelector Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"labelSelector", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "limit" - limit is a maximum number of responses to return for a list call. If more items exist, the server will set the `continue` field on the list metadata to a value that can be used with the same initial query to retrieve the next set of results. Setting a limit may return fewer than the requested amount of items (up to zero items) in the event all requested objects are filtered out and clients should only use the presence of the continue field to determine whether more results are available. Servers may choose not to support the limit argument and will return all of the available results. If limit is specified and the continue field is empty, clients may assume that no more results are available. This field is not supported if watch is true.  The server guarantees that the objects returned when using continue will be identical to issuing a single list call without a limit - that is, no objects created, modified, or deleted after the first request is issued will be included in any subsequent continued requests. This is sometimes referred to as a consistent snapshot, and ensures that a client that is using limit to receive smaller chunks of a very large result can ensure they see all possible objects. If objects are updated during a chunked list the version of the object that was present at the time the first list result was calculated is returned.
instance HasOptionalParam DeleteCollectionStorageVersion Limit where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> Limit
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (Limit Int
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"limit", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | /Optional Param/ "orphanDependents" - Deprecated: please use the PropagationPolicy, this field will be deprecated in 1.7. Should the dependent objects be orphaned. If true/false, the \"orphan\" finalizer will be added to/removed from the object's finalizers list. Either this field or PropagationPolicy may be set, but not both.
instance HasOptionalParam DeleteCollectionStorageVersion OrphanDependents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> OrphanDependents
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (OrphanDependents Bool
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"orphanDependents", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "propagationPolicy" - Whether and how garbage collection will be performed. Either this field or OrphanDependents may be set, but not both. The default policy is decided by the existing finalizer set in the metadata.finalizers and the resource-specific default policy. Acceptable values are: 'Orphan' - orphan the dependents; 'Background' - allow the garbage collector to delete the dependents in the background; 'Foreground' - a cascading policy that deletes all dependents in the foreground.
instance HasOptionalParam DeleteCollectionStorageVersion PropagationPolicy where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> PropagationPolicy
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (PropagationPolicy Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"propagationPolicy", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "resourceVersion" - resourceVersion sets a constraint on what resource versions a request may be served from. See https://kubernetes.io/docs/reference/using-api/api-concepts/#resource-versions for details.  Defaults to unset
instance HasOptionalParam DeleteCollectionStorageVersion ResourceVersion where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> ResourceVersion
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (ResourceVersion Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"resourceVersion", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "resourceVersionMatch" - resourceVersionMatch determines how resourceVersion is applied to list calls. It is highly recommended that resourceVersionMatch be set for list calls where resourceVersion is set See https://kubernetes.io/docs/reference/using-api/api-concepts/#resource-versions for details.  Defaults to unset
instance HasOptionalParam DeleteCollectionStorageVersion ResourceVersionMatch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> ResourceVersionMatch
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (ResourceVersionMatch Text
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"resourceVersionMatch", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "sendInitialEvents" - `sendInitialEvents=true` may be set together with `watch=true`. In that case, the watch stream will begin with synthetic events to produce the current state of objects in the collection. Once all such events have been sent, a synthetic \"Bookmark\" event  will be sent. The bookmark will report the ResourceVersion (RV) corresponding to the set of objects, and be marked with `\"k8s.io/initial-events-end\": \"true\"` annotation. Afterwards, the watch stream will proceed as usual, sending watch events corresponding to changes (subsequent to the RV) to objects watched.  When `sendInitialEvents` option is set, we require `resourceVersionMatch` option to also be set. The semantic of the watch request is as following: - `resourceVersionMatch` = NotOlderThan   is interpreted as \"data at least as new as the provided `resourceVersion`\"   and the bookmark event is send when the state is synced   to a `resourceVersion` at least as fresh as the one provided by the ListOptions.   If `resourceVersion` is unset, this is interpreted as \"consistent read\" and the   bookmark event is send when the state is synced at least to the moment   when request started being processed. - `resourceVersionMatch` set to any other value or unset   Invalid error is returned.  Defaults to true if `resourceVersion=\"\"` or `resourceVersion=\"0\"` (for backward compatibility reasons) and to false otherwise.
instance HasOptionalParam DeleteCollectionStorageVersion SendInitialEvents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> SendInitialEvents
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (SendInitialEvents Bool
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"sendInitialEvents", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "timeoutSeconds" - Timeout for the list/watch call. This limits the duration of the call, regardless of any activity or inactivity.
instance HasOptionalParam DeleteCollectionStorageVersion TimeoutSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> TimeoutSeconds
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req (TimeoutSeconds Int
xs) =
    KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
req KubernetesRequest
  DeleteCollectionStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"timeoutSeconds", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | @*/*@
instance MimeType mtype => Consumes DeleteCollectionStorageVersion mtype

-- | @application/json@
instance Produces DeleteCollectionStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces DeleteCollectionStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces DeleteCollectionStorageVersion MimeCbor
-- | @application/yaml@
instance Produces DeleteCollectionStorageVersion MimeYaml


-- *** deleteStorageVersion

-- | @DELETE \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}@
-- 
-- delete a StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
deleteStorageVersion
  :: (Consumes DeleteStorageVersion contentType)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest DeleteStorageVersion contentType V1Status accept
deleteStorageVersion :: forall contentType accept.
Consumes DeleteStorageVersion contentType =>
ContentType contentType
-> Accept accept
-> Name
-> KubernetesRequest
     DeleteStorageVersion contentType V1Status accept
deleteStorageVersion ContentType contentType
_  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     DeleteStorageVersion contentType V1Status accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"DELETE" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest DeleteStorageVersion contentType V1Status accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     DeleteStorageVersion contentType V1Status accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data DeleteStorageVersion 
instance HasBodyParam DeleteStorageVersion V1DeleteOptions 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam DeleteStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam DeleteStorageVersion DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> DryRun
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "gracePeriodSeconds" - The duration in seconds before the object should be deleted. Value must be non-negative integer. The value zero indicates delete immediately. If this value is nil, the default grace period for the specified type will be used. Defaults to a per object value if not specified. zero means delete immediately.
instance HasOptionalParam DeleteStorageVersion GracePeriodSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> GracePeriodSeconds
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (GracePeriodSeconds Int
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"gracePeriodSeconds", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | /Optional Param/ "ignoreStoreReadErrorWithClusterBreakingPotential" - if set to true, it will trigger an unsafe deletion of the resource in case the normal deletion flow fails with a corrupt object error. A resource is considered corrupt if it can not be retrieved from the underlying storage successfully because of a) its data can not be transformed e.g. decryption failure, or b) it fails to decode into an object. NOTE: unsafe deletion ignores finalizer constraints, skips precondition checks, and removes the object from the storage. WARNING: This may potentially break the cluster if the workload associated with the resource being unsafe-deleted relies on normal deletion flow. Use only if you REALLY know what you are doing. The default value is false, and the user must opt in to enable it
instance HasOptionalParam DeleteStorageVersion IgnoreStoreReadErrorWithClusterBreakingPotential where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> IgnoreStoreReadErrorWithClusterBreakingPotential
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (IgnoreStoreReadErrorWithClusterBreakingPotential Bool
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"ignoreStoreReadErrorWithClusterBreakingPotential", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "orphanDependents" - Deprecated: please use the PropagationPolicy, this field will be deprecated in 1.7. Should the dependent objects be orphaned. If true/false, the \"orphan\" finalizer will be added to/removed from the object's finalizers list. Either this field or PropagationPolicy may be set, but not both.
instance HasOptionalParam DeleteStorageVersion OrphanDependents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> OrphanDependents
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (OrphanDependents Bool
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"orphanDependents", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "propagationPolicy" - Whether and how garbage collection will be performed. Either this field or OrphanDependents may be set, but not both. The default policy is decided by the existing finalizer set in the metadata.finalizers and the resource-specific default policy. Acceptable values are: 'Orphan' - orphan the dependents; 'Background' - allow the garbage collector to delete the dependents in the background; 'Foreground' - a cascading policy that deletes all dependents in the foreground.
instance HasOptionalParam DeleteStorageVersion PropagationPolicy where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest DeleteStorageVersion contentType res accept
-> PropagationPolicy
-> KubernetesRequest DeleteStorageVersion contentType res accept
applyOptionalParam KubernetesRequest DeleteStorageVersion contentType res accept
req (PropagationPolicy Text
xs) =
    KubernetesRequest DeleteStorageVersion contentType res accept
req KubernetesRequest DeleteStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest DeleteStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"propagationPolicy", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | @*/*@
instance MimeType mtype => Consumes DeleteStorageVersion mtype

-- | @application/json@
instance Produces DeleteStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces DeleteStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces DeleteStorageVersion MimeCbor
-- | @application/yaml@
instance Produces DeleteStorageVersion MimeYaml


-- *** getAPIResources

-- | @GET \/apis\/internal.apiserver.k8s.io\/v1alpha1\/@
-- 
-- get available resources
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
getAPIResources
  :: Accept accept -- ^ request accept ('MimeType')
  -> KubernetesRequest GetAPIResources MimeNoContent V1APIResourceList accept
getAPIResources :: forall accept.
Accept accept
-> KubernetesRequest
     GetAPIResources MimeNoContent V1APIResourceList accept
getAPIResources  Accept accept
_ =
  Method
-> [ByteString]
-> KubernetesRequest
     GetAPIResources MimeNoContent V1APIResourceList accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/"]
    KubernetesRequest
  GetAPIResources MimeNoContent V1APIResourceList accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     GetAPIResources MimeNoContent V1APIResourceList accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data GetAPIResources  
-- | @application/json@
instance Produces GetAPIResources MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces GetAPIResources MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces GetAPIResources MimeCbor
-- | @application/yaml@
instance Produces GetAPIResources MimeYaml


-- *** listStorageVersion

-- | @GET \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions@
-- 
-- list or watch objects of kind StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
listStorageVersion
  :: Accept accept -- ^ request accept ('MimeType')
  -> KubernetesRequest ListStorageVersion MimeNoContent V1alpha1StorageVersionList accept
listStorageVersion :: forall accept.
Accept accept
-> KubernetesRequest
     ListStorageVersion MimeNoContent V1alpha1StorageVersionList accept
listStorageVersion  Accept accept
_ =
  Method
-> [ByteString]
-> KubernetesRequest
     ListStorageVersion MimeNoContent V1alpha1StorageVersionList accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions"]
    KubernetesRequest
  ListStorageVersion MimeNoContent V1alpha1StorageVersionList accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ListStorageVersion MimeNoContent V1alpha1StorageVersionList accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data ListStorageVersion  

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam ListStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "allowWatchBookmarks" - allowWatchBookmarks requests watch events with type \"BOOKMARK\". Servers that do not implement bookmarks may ignore this flag and bookmarks are sent at the server's discretion. Clients should not assume bookmarks are returned at any specific interval, nor may they assume the server will send any BOOKMARK event during a session. If this is not a watch, this field is ignored.
instance HasOptionalParam ListStorageVersion AllowWatchBookmarks where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> AllowWatchBookmarks
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (AllowWatchBookmarks Bool
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"allowWatchBookmarks", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "continue" - The continue option should be set when retrieving more results from the server. Since this value is server defined, clients may only use the continue value from a previous query result with identical query parameters (except for the value of continue) and the server may reject a continue value it does not recognize. If the specified continue value is no longer valid whether due to expiration (generally five to fifteen minutes) or a configuration change on the server, the server will respond with a 410 ResourceExpired error together with a continue token. If the client needs a consistent list, it must restart their list without the continue field. Otherwise, the client may send another list request with the token received with the 410 error, the server will respond with a list starting from the next key, but from the latest snapshot, which is inconsistent from the previous list results - objects that are created, modified, or deleted after the first list request will be included in the response, as long as their keys are after the \"next key\".  This field is not supported when watch is true. Clients may start a watch from the last resourceVersion value returned by the server and not miss any modifications.
instance HasOptionalParam ListStorageVersion Continue where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> Continue
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (Continue Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"continue", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldSelector" - A selector to restrict the list of returned objects by their fields. Defaults to everything.
instance HasOptionalParam ListStorageVersion FieldSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> FieldSelector
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (FieldSelector Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldSelector", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "labelSelector" - A selector to restrict the list of returned objects by their labels. Defaults to everything.
instance HasOptionalParam ListStorageVersion LabelSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> LabelSelector
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (LabelSelector Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"labelSelector", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "limit" - limit is a maximum number of responses to return for a list call. If more items exist, the server will set the `continue` field on the list metadata to a value that can be used with the same initial query to retrieve the next set of results. Setting a limit may return fewer than the requested amount of items (up to zero items) in the event all requested objects are filtered out and clients should only use the presence of the continue field to determine whether more results are available. Servers may choose not to support the limit argument and will return all of the available results. If limit is specified and the continue field is empty, clients may assume that no more results are available. This field is not supported if watch is true.  The server guarantees that the objects returned when using continue will be identical to issuing a single list call without a limit - that is, no objects created, modified, or deleted after the first request is issued will be included in any subsequent continued requests. This is sometimes referred to as a consistent snapshot, and ensures that a client that is using limit to receive smaller chunks of a very large result can ensure they see all possible objects. If objects are updated during a chunked list the version of the object that was present at the time the first list result was calculated is returned.
instance HasOptionalParam ListStorageVersion Limit where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> Limit
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (Limit Int
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"limit", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | /Optional Param/ "resourceVersion" - resourceVersion sets a constraint on what resource versions a request may be served from. See https://kubernetes.io/docs/reference/using-api/api-concepts/#resource-versions for details.  Defaults to unset
instance HasOptionalParam ListStorageVersion ResourceVersion where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> ResourceVersion
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (ResourceVersion Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"resourceVersion", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "resourceVersionMatch" - resourceVersionMatch determines how resourceVersion is applied to list calls. It is highly recommended that resourceVersionMatch be set for list calls where resourceVersion is set See https://kubernetes.io/docs/reference/using-api/api-concepts/#resource-versions for details.  Defaults to unset
instance HasOptionalParam ListStorageVersion ResourceVersionMatch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> ResourceVersionMatch
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (ResourceVersionMatch Text
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"resourceVersionMatch", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "sendInitialEvents" - `sendInitialEvents=true` may be set together with `watch=true`. In that case, the watch stream will begin with synthetic events to produce the current state of objects in the collection. Once all such events have been sent, a synthetic \"Bookmark\" event  will be sent. The bookmark will report the ResourceVersion (RV) corresponding to the set of objects, and be marked with `\"k8s.io/initial-events-end\": \"true\"` annotation. Afterwards, the watch stream will proceed as usual, sending watch events corresponding to changes (subsequent to the RV) to objects watched.  When `sendInitialEvents` option is set, we require `resourceVersionMatch` option to also be set. The semantic of the watch request is as following: - `resourceVersionMatch` = NotOlderThan   is interpreted as \"data at least as new as the provided `resourceVersion`\"   and the bookmark event is send when the state is synced   to a `resourceVersion` at least as fresh as the one provided by the ListOptions.   If `resourceVersion` is unset, this is interpreted as \"consistent read\" and the   bookmark event is send when the state is synced at least to the moment   when request started being processed. - `resourceVersionMatch` set to any other value or unset   Invalid error is returned.  Defaults to true if `resourceVersion=\"\"` or `resourceVersion=\"0\"` (for backward compatibility reasons) and to false otherwise.
instance HasOptionalParam ListStorageVersion SendInitialEvents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> SendInitialEvents
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (SendInitialEvents Bool
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"sendInitialEvents", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | /Optional Param/ "timeoutSeconds" - Timeout for the list/watch call. This limits the duration of the call, regardless of any activity or inactivity.
instance HasOptionalParam ListStorageVersion TimeoutSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> TimeoutSeconds
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (TimeoutSeconds Int
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Int) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"timeoutSeconds", Int -> Maybe Int
forall a. a -> Maybe a
Just Int
xs)

-- | /Optional Param/ "watch" - Watch for changes to the described resources and return them as a stream of add, update, and remove notifications. Specify resourceVersion.
instance HasOptionalParam ListStorageVersion Watch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ListStorageVersion contentType res accept
-> Watch
-> KubernetesRequest ListStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ListStorageVersion contentType res accept
req (Watch Bool
xs) =
    KubernetesRequest ListStorageVersion contentType res accept
req KubernetesRequest ListStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ListStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"watch", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)
-- | @application/cbor-seq@
instance Produces ListStorageVersion MimeCborSeq
-- | @application/json@
instance Produces ListStorageVersion MimeJSON
-- | @application/json;stream=watch@
instance Produces ListStorageVersion MimeJsonstreamwatch
-- | @application/vnd.kubernetes.protobuf@
instance Produces ListStorageVersion MimeVndKubernetesProtobuf
-- | @application/vnd.kubernetes.protobuf;stream=watch@
instance Produces ListStorageVersion MimeVndKubernetesProtobufstreamwatch
-- | @application/cbor@
instance Produces ListStorageVersion MimeCbor
-- | @application/yaml@
instance Produces ListStorageVersion MimeYaml


-- *** patchStorageVersion

-- | @PATCH \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}@
-- 
-- partially update the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
patchStorageVersion
  :: (Consumes PatchStorageVersion contentType, MimeRender contentType Body)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Body -- ^ "body"
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest PatchStorageVersion contentType V1alpha1StorageVersion accept
patchStorageVersion :: forall contentType accept.
(Consumes PatchStorageVersion contentType,
 MimeRender contentType Body) =>
ContentType contentType
-> Accept accept
-> Body
-> Name
-> KubernetesRequest
     PatchStorageVersion contentType V1alpha1StorageVersion accept
patchStorageVersion ContentType contentType
_  Accept accept
_ Body
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     PatchStorageVersion contentType V1alpha1StorageVersion accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PATCH" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  PatchStorageVersion contentType V1alpha1StorageVersion accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     PatchStorageVersion contentType V1alpha1StorageVersion accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)
    KubernetesRequest
  PatchStorageVersion contentType V1alpha1StorageVersion accept
-> Body
-> KubernetesRequest
     PatchStorageVersion contentType V1alpha1StorageVersion accept
forall req param contentType res accept.
(HasBodyParam req param, Consumes req contentType,
 MimeRender contentType param) =>
KubernetesRequest req contentType res accept
-> param -> KubernetesRequest req contentType res accept
forall contentType res accept.
(Consumes PatchStorageVersion contentType,
 MimeRender contentType Body) =>
KubernetesRequest PatchStorageVersion contentType res accept
-> Body
-> KubernetesRequest PatchStorageVersion contentType res accept
`setBodyParam` Body
body

data PatchStorageVersion 
instance HasBodyParam PatchStorageVersion Body 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam PatchStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest PatchStorageVersion contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest PatchStorageVersion contentType res accept
req KubernetesRequest PatchStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest PatchStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam PatchStorageVersion DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersion contentType res accept
-> DryRun
-> KubernetesRequest PatchStorageVersion contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersion contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest PatchStorageVersion contentType res accept
req KubernetesRequest PatchStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest PatchStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldManager" - fieldManager is a name associated with the actor or entity that is making these changes. The value must be less than or 128 characters long, and only contain printable characters, as defined by https://golang.org/pkg/unicode/#IsPrint. This field is required for apply requests (application/apply-patch) but optional for non-apply patch types (JsonPatch, MergePatch, StrategicMergePatch).
instance HasOptionalParam PatchStorageVersion FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersion contentType res accept
-> FieldManager
-> KubernetesRequest PatchStorageVersion contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersion contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest PatchStorageVersion contentType res accept
req KubernetesRequest PatchStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest PatchStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldManager", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldValidation" - fieldValidation instructs the server on how to handle objects in the request (POST/PUT/PATCH) containing unknown or duplicate fields. Valid values are: - Ignore: This will ignore any unknown fields that are silently dropped from the object, and will ignore all but the last duplicate field that the decoder encounters. This is the default behavior prior to v1.23. - Warn: This will send a warning via the standard warning response header for each unknown field that is dropped from the object, and for each duplicate field that is encountered. The request will still succeed if there are no other errors, and will only persist the last of any duplicate fields. This is the default in v1.23+ - Strict: This will fail the request with a BadRequest error if any unknown fields would be dropped from the object, or if any duplicate fields are present. The error returned from the server will contain all unknown and duplicate fields encountered.
instance HasOptionalParam PatchStorageVersion FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersion contentType res accept
-> FieldValidation
-> KubernetesRequest PatchStorageVersion contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersion contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest PatchStorageVersion contentType res accept
req KubernetesRequest PatchStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest PatchStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldValidation", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "force" - Force is going to \"force\" Apply requests. It means user will re-acquire conflicting fields owned by other people. Force flag must be unset for non-apply patch requests.
instance HasOptionalParam PatchStorageVersion Force where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersion contentType res accept
-> Force
-> KubernetesRequest PatchStorageVersion contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersion contentType res accept
req (Force Bool
xs) =
    KubernetesRequest PatchStorageVersion contentType res accept
req KubernetesRequest PatchStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest PatchStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"force", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | @application/apply-patch+yaml@
instance Consumes PatchStorageVersion MimeApplyPatchyaml
-- | @application/json-patch+json@
instance Consumes PatchStorageVersion MimeJsonPatchjson
-- | @application/merge-patch+json@
instance Consumes PatchStorageVersion MimeMergePatchjson
-- | @application/strategic-merge-patch+json@
instance Consumes PatchStorageVersion MimeStrategicMergePatchjson
-- | @application/apply-patch+cbor@
instance Consumes PatchStorageVersion MimeApplyPatchcbor

-- | @application/json@
instance Produces PatchStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces PatchStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces PatchStorageVersion MimeCbor
-- | @application/yaml@
instance Produces PatchStorageVersion MimeYaml


-- *** patchStorageVersionStatus

-- | @PATCH \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}\/status@
-- 
-- partially update status of the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
patchStorageVersionStatus
  :: (Consumes PatchStorageVersionStatus contentType, MimeRender contentType Body)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Body -- ^ "body"
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
patchStorageVersionStatus :: forall contentType accept.
(Consumes PatchStorageVersionStatus contentType,
 MimeRender contentType Body) =>
ContentType contentType
-> Accept accept
-> Body
-> Name
-> KubernetesRequest
     PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
patchStorageVersionStatus ContentType contentType
_  Accept accept
_ Body
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PATCH" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)
    KubernetesRequest
  PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
-> Body
-> KubernetesRequest
     PatchStorageVersionStatus contentType V1alpha1StorageVersion accept
forall req param contentType res accept.
(HasBodyParam req param, Consumes req contentType,
 MimeRender contentType param) =>
KubernetesRequest req contentType res accept
-> param -> KubernetesRequest req contentType res accept
forall contentType res accept.
(Consumes PatchStorageVersionStatus contentType,
 MimeRender contentType Body) =>
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> Body
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
`setBodyParam` Body
body

data PatchStorageVersionStatus 
instance HasBodyParam PatchStorageVersionStatus Body 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam PatchStorageVersionStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> Pretty
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersionStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest PatchStorageVersionStatus contentType res accept
req KubernetesRequest PatchStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam PatchStorageVersionStatus DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> DryRun
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersionStatus contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest PatchStorageVersionStatus contentType res accept
req KubernetesRequest PatchStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldManager" - fieldManager is a name associated with the actor or entity that is making these changes. The value must be less than or 128 characters long, and only contain printable characters, as defined by https://golang.org/pkg/unicode/#IsPrint. This field is required for apply requests (application/apply-patch) but optional for non-apply patch types (JsonPatch, MergePatch, StrategicMergePatch).
instance HasOptionalParam PatchStorageVersionStatus FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> FieldManager
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersionStatus contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest PatchStorageVersionStatus contentType res accept
req KubernetesRequest PatchStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldManager", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldValidation" - fieldValidation instructs the server on how to handle objects in the request (POST/PUT/PATCH) containing unknown or duplicate fields. Valid values are: - Ignore: This will ignore any unknown fields that are silently dropped from the object, and will ignore all but the last duplicate field that the decoder encounters. This is the default behavior prior to v1.23. - Warn: This will send a warning via the standard warning response header for each unknown field that is dropped from the object, and for each duplicate field that is encountered. The request will still succeed if there are no other errors, and will only persist the last of any duplicate fields. This is the default in v1.23+ - Strict: This will fail the request with a BadRequest error if any unknown fields would be dropped from the object, or if any duplicate fields are present. The error returned from the server will contain all unknown and duplicate fields encountered.
instance HasOptionalParam PatchStorageVersionStatus FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> FieldValidation
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersionStatus contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest PatchStorageVersionStatus contentType res accept
req KubernetesRequest PatchStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldValidation", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "force" - Force is going to \"force\" Apply requests. It means user will re-acquire conflicting fields owned by other people. Force flag must be unset for non-apply patch requests.
instance HasOptionalParam PatchStorageVersionStatus Force where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest PatchStorageVersionStatus contentType res accept
-> Force
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest PatchStorageVersionStatus contentType res accept
req (Force Bool
xs) =
    KubernetesRequest PatchStorageVersionStatus contentType res accept
req KubernetesRequest PatchStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Bool) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"force", Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
xs)

-- | @application/apply-patch+yaml@
instance Consumes PatchStorageVersionStatus MimeApplyPatchyaml
-- | @application/json-patch+json@
instance Consumes PatchStorageVersionStatus MimeJsonPatchjson
-- | @application/merge-patch+json@
instance Consumes PatchStorageVersionStatus MimeMergePatchjson
-- | @application/strategic-merge-patch+json@
instance Consumes PatchStorageVersionStatus MimeStrategicMergePatchjson
-- | @application/apply-patch+cbor@
instance Consumes PatchStorageVersionStatus MimeApplyPatchcbor

-- | @application/json@
instance Produces PatchStorageVersionStatus MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces PatchStorageVersionStatus MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces PatchStorageVersionStatus MimeCbor
-- | @application/yaml@
instance Produces PatchStorageVersionStatus MimeYaml


-- *** readStorageVersion

-- | @GET \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}@
-- 
-- read the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
readStorageVersion
  :: Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest ReadStorageVersion MimeNoContent V1alpha1StorageVersion accept
readStorageVersion :: forall accept.
Accept accept
-> Name
-> KubernetesRequest
     ReadStorageVersion MimeNoContent V1alpha1StorageVersion accept
readStorageVersion  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReadStorageVersion MimeNoContent V1alpha1StorageVersion accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  ReadStorageVersion MimeNoContent V1alpha1StorageVersion accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReadStorageVersion MimeNoContent V1alpha1StorageVersion accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data ReadStorageVersion  

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam ReadStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReadStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest ReadStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ReadStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest ReadStorageVersion contentType res accept
req KubernetesRequest ReadStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ReadStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)
-- | @application/json@
instance Produces ReadStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReadStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReadStorageVersion MimeCbor
-- | @application/yaml@
instance Produces ReadStorageVersion MimeYaml


-- *** readStorageVersionStatus

-- | @GET \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}\/status@
-- 
-- read status of the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
readStorageVersionStatus
  :: Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest ReadStorageVersionStatus MimeNoContent V1alpha1StorageVersion accept
readStorageVersionStatus :: forall accept.
Accept accept
-> Name
-> KubernetesRequest
     ReadStorageVersionStatus
     MimeNoContent
     V1alpha1StorageVersion
     accept
readStorageVersionStatus  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReadStorageVersionStatus
     MimeNoContent
     V1alpha1StorageVersion
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  ReadStorageVersionStatus
  MimeNoContent
  V1alpha1StorageVersion
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReadStorageVersionStatus
     MimeNoContent
     V1alpha1StorageVersion
     accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)

data ReadStorageVersionStatus  

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam ReadStorageVersionStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReadStorageVersionStatus contentType res accept
-> Pretty
-> KubernetesRequest
     ReadStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest ReadStorageVersionStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest ReadStorageVersionStatus contentType res accept
req KubernetesRequest ReadStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReadStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)
-- | @application/json@
instance Produces ReadStorageVersionStatus MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReadStorageVersionStatus MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReadStorageVersionStatus MimeCbor
-- | @application/yaml@
instance Produces ReadStorageVersionStatus MimeYaml


-- *** replaceStorageVersion

-- | @PUT \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}@
-- 
-- replace the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
replaceStorageVersion
  :: (Consumes ReplaceStorageVersion contentType, MimeRender contentType V1alpha1StorageVersion)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1alpha1StorageVersion -- ^ "body"
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest ReplaceStorageVersion contentType V1alpha1StorageVersion accept
replaceStorageVersion :: forall contentType accept.
(Consumes ReplaceStorageVersion contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
ContentType contentType
-> Accept accept
-> V1alpha1StorageVersion
-> Name
-> KubernetesRequest
     ReplaceStorageVersion contentType V1alpha1StorageVersion accept
replaceStorageVersion ContentType contentType
_  Accept accept
_ V1alpha1StorageVersion
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReplaceStorageVersion contentType V1alpha1StorageVersion accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PUT" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  ReplaceStorageVersion contentType V1alpha1StorageVersion accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReplaceStorageVersion contentType V1alpha1StorageVersion accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)
    KubernetesRequest
  ReplaceStorageVersion contentType V1alpha1StorageVersion accept
-> V1alpha1StorageVersion
-> KubernetesRequest
     ReplaceStorageVersion contentType V1alpha1StorageVersion accept
forall req param contentType res accept.
(HasBodyParam req param, Consumes req contentType,
 MimeRender contentType param) =>
KubernetesRequest req contentType res accept
-> param -> KubernetesRequest req contentType res accept
forall contentType res accept.
(Consumes ReplaceStorageVersion contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
KubernetesRequest ReplaceStorageVersion contentType res accept
-> V1alpha1StorageVersion
-> KubernetesRequest ReplaceStorageVersion contentType res accept
`setBodyParam` V1alpha1StorageVersion
body

data ReplaceStorageVersion 
instance HasBodyParam ReplaceStorageVersion V1alpha1StorageVersion 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam ReplaceStorageVersion Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReplaceStorageVersion contentType res accept
-> Pretty
-> KubernetesRequest ReplaceStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ReplaceStorageVersion contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest ReplaceStorageVersion contentType res accept
req KubernetesRequest ReplaceStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ReplaceStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam ReplaceStorageVersion DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReplaceStorageVersion contentType res accept
-> DryRun
-> KubernetesRequest ReplaceStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ReplaceStorageVersion contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest ReplaceStorageVersion contentType res accept
req KubernetesRequest ReplaceStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ReplaceStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldManager" - fieldManager is a name associated with the actor or entity that is making these changes. The value must be less than or 128 characters long, and only contain printable characters, as defined by https://golang.org/pkg/unicode/#IsPrint.
instance HasOptionalParam ReplaceStorageVersion FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReplaceStorageVersion contentType res accept
-> FieldManager
-> KubernetesRequest ReplaceStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ReplaceStorageVersion contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest ReplaceStorageVersion contentType res accept
req KubernetesRequest ReplaceStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ReplaceStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldManager", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldValidation" - fieldValidation instructs the server on how to handle objects in the request (POST/PUT/PATCH) containing unknown or duplicate fields. Valid values are: - Ignore: This will ignore any unknown fields that are silently dropped from the object, and will ignore all but the last duplicate field that the decoder encounters. This is the default behavior prior to v1.23. - Warn: This will send a warning via the standard warning response header for each unknown field that is dropped from the object, and for each duplicate field that is encountered. The request will still succeed if there are no other errors, and will only persist the last of any duplicate fields. This is the default in v1.23+ - Strict: This will fail the request with a BadRequest error if any unknown fields would be dropped from the object, or if any duplicate fields are present. The error returned from the server will contain all unknown and duplicate fields encountered.
instance HasOptionalParam ReplaceStorageVersion FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest ReplaceStorageVersion contentType res accept
-> FieldValidation
-> KubernetesRequest ReplaceStorageVersion contentType res accept
applyOptionalParam KubernetesRequest ReplaceStorageVersion contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest ReplaceStorageVersion contentType res accept
req KubernetesRequest ReplaceStorageVersion contentType res accept
-> [QueryItem]
-> KubernetesRequest ReplaceStorageVersion contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldValidation", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | @*/*@
instance MimeType mtype => Consumes ReplaceStorageVersion mtype

-- | @application/json@
instance Produces ReplaceStorageVersion MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReplaceStorageVersion MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReplaceStorageVersion MimeCbor
-- | @application/yaml@
instance Produces ReplaceStorageVersion MimeYaml


-- *** replaceStorageVersionStatus

-- | @PUT \/apis\/internal.apiserver.k8s.io\/v1alpha1\/storageversions\/{name}\/status@
-- 
-- replace status of the specified StorageVersion
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
replaceStorageVersionStatus
  :: (Consumes ReplaceStorageVersionStatus contentType, MimeRender contentType V1alpha1StorageVersion)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1alpha1StorageVersion -- ^ "body"
  -> Name -- ^ "name" -  name of the StorageVersion
  -> KubernetesRequest ReplaceStorageVersionStatus contentType V1alpha1StorageVersion accept
replaceStorageVersionStatus :: forall contentType accept.
(Consumes ReplaceStorageVersionStatus contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
ContentType contentType
-> Accept accept
-> V1alpha1StorageVersion
-> Name
-> KubernetesRequest
     ReplaceStorageVersionStatus
     contentType
     V1alpha1StorageVersion
     accept
replaceStorageVersionStatus ContentType contentType
_  Accept accept
_ V1alpha1StorageVersion
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReplaceStorageVersionStatus
     contentType
     V1alpha1StorageVersion
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PUT" [ByteString
"/apis/internal.apiserver.k8s.io/v1alpha1/storageversions/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  ReplaceStorageVersionStatus
  contentType
  V1alpha1StorageVersion
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReplaceStorageVersionStatus
     contentType
     V1alpha1StorageVersion
     accept
forall authMethod req contentType res accept.
AuthMethod authMethod =>
KubernetesRequest req contentType res accept
-> Proxy authMethod -> KubernetesRequest req contentType res accept
`_hasAuthType` (Proxy AuthApiKeyBearerToken
forall {k} (t :: k). Proxy t
P.Proxy :: P.Proxy AuthApiKeyBearerToken)
    KubernetesRequest
  ReplaceStorageVersionStatus
  contentType
  V1alpha1StorageVersion
  accept
-> V1alpha1StorageVersion
-> KubernetesRequest
     ReplaceStorageVersionStatus
     contentType
     V1alpha1StorageVersion
     accept
forall req param contentType res accept.
(HasBodyParam req param, Consumes req contentType,
 MimeRender contentType param) =>
KubernetesRequest req contentType res accept
-> param -> KubernetesRequest req contentType res accept
forall contentType res accept.
(Consumes ReplaceStorageVersionStatus contentType,
 MimeRender contentType V1alpha1StorageVersion) =>
KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> V1alpha1StorageVersion
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
`setBodyParam` V1alpha1StorageVersion
body

data ReplaceStorageVersionStatus 
instance HasBodyParam ReplaceStorageVersionStatus V1alpha1StorageVersion 

-- | /Optional Param/ "pretty" - If 'true', then the output is pretty printed. Defaults to 'false' unless the user-agent indicates a browser or command-line HTTP tool (curl and wget).
instance HasOptionalParam ReplaceStorageVersionStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> Pretty
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"pretty", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "dryRun" - When present, indicates that modifications should not be persisted. An invalid or unrecognized dryRun directive will result in an error response and no further processing of the request. Valid values are: - All: all dry run stages will be processed
instance HasOptionalParam ReplaceStorageVersionStatus DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> DryRun
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"dryRun", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldManager" - fieldManager is a name associated with the actor or entity that is making these changes. The value must be less than or 128 characters long, and only contain printable characters, as defined by https://golang.org/pkg/unicode/#IsPrint.
instance HasOptionalParam ReplaceStorageVersionStatus FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> FieldManager
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldManager", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | /Optional Param/ "fieldValidation" - fieldValidation instructs the server on how to handle objects in the request (POST/PUT/PATCH) containing unknown or duplicate fields. Valid values are: - Ignore: This will ignore any unknown fields that are silently dropped from the object, and will ignore all but the last duplicate field that the decoder encounters. This is the default behavior prior to v1.23. - Warn: This will send a warning via the standard warning response header for each unknown field that is dropped from the object, and for each duplicate field that is encountered. The request will still succeed if there are no other errors, and will only persist the last of any duplicate fields. This is the default in v1.23+ - Strict: This will fail the request with a BadRequest error if any unknown fields would be dropped from the object, or if any duplicate fields are present. The error returned from the server will contain all unknown and duplicate fields encountered.
instance HasOptionalParam ReplaceStorageVersionStatus FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> FieldValidation
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
req KubernetesRequest
  ReplaceStorageVersionStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceStorageVersionStatus contentType res accept
forall req contentType res accept.
KubernetesRequest req contentType res accept
-> [QueryItem] -> KubernetesRequest req contentType res accept
`addQuery` (Method, Maybe Text) -> [QueryItem]
forall a. ToHttpApiData a => (Method, Maybe a) -> [QueryItem]
toQuery (Method
"fieldValidation", Text -> Maybe Text
forall a. a -> Maybe a
Just Text
xs)

-- | @*/*@
instance MimeType mtype => Consumes ReplaceStorageVersionStatus mtype

-- | @application/json@
instance Produces ReplaceStorageVersionStatus MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReplaceStorageVersionStatus MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReplaceStorageVersionStatus MimeCbor
-- | @application/yaml@
instance Produces ReplaceStorageVersionStatus MimeYaml