{-
   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.CertificatesV1
-}

{-# 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.CertificatesV1 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


-- ** CertificatesV1

-- *** createCertificateSigningRequest

-- | @POST \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests@
-- 
-- create a CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
createCertificateSigningRequest
  :: (Consumes CreateCertificateSigningRequest contentType, MimeRender contentType V1CertificateSigningRequest)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1CertificateSigningRequest -- ^ "body"
  -> KubernetesRequest CreateCertificateSigningRequest contentType V1CertificateSigningRequest accept
createCertificateSigningRequest :: forall contentType accept.
(Consumes CreateCertificateSigningRequest contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
ContentType contentType
-> Accept accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     CreateCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
createCertificateSigningRequest ContentType contentType
_  Accept accept
_ V1CertificateSigningRequest
body =
  Method
-> [ByteString]
-> KubernetesRequest
     CreateCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"POST" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests"]
    KubernetesRequest
  CreateCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     CreateCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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
  CreateCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     CreateCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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 CreateCertificateSigningRequest contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     CreateCertificateSigningRequest contentType res accept
`setBodyParam` V1CertificateSigningRequest
body

data CreateCertificateSigningRequest 
instance HasBodyParam CreateCertificateSigningRequest V1CertificateSigningRequest 

-- | /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 CreateCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     CreateCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     CreateCertificateSigningRequest 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 CreateCertificateSigningRequest DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> DryRun
-> KubernetesRequest
     CreateCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     CreateCertificateSigningRequest 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 CreateCertificateSigningRequest FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> FieldManager
-> KubernetesRequest
     CreateCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     CreateCertificateSigningRequest 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 CreateCertificateSigningRequest FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> FieldValidation
-> KubernetesRequest
     CreateCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
req KubernetesRequest
  CreateCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     CreateCertificateSigningRequest 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 CreateCertificateSigningRequest mtype

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


-- *** deleteCertificateSigningRequest

-- | @DELETE \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}@
-- 
-- delete a CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
deleteCertificateSigningRequest
  :: (Consumes DeleteCertificateSigningRequest contentType)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest DeleteCertificateSigningRequest contentType V1Status accept
deleteCertificateSigningRequest :: forall contentType accept.
Consumes DeleteCertificateSigningRequest contentType =>
ContentType contentType
-> Accept accept
-> Name
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType V1Status accept
deleteCertificateSigningRequest ContentType contentType
_  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType V1Status accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"DELETE" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  DeleteCertificateSigningRequest contentType V1Status accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest 
instance HasBodyParam DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> DryRun
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest GracePeriodSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> GracePeriodSeconds
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (GracePeriodSeconds Int
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest IgnoreStoreReadErrorWithClusterBreakingPotential where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> IgnoreStoreReadErrorWithClusterBreakingPotential
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (IgnoreStoreReadErrorWithClusterBreakingPotential Bool
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest OrphanDependents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> OrphanDependents
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (OrphanDependents Bool
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest PropagationPolicy where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> PropagationPolicy
-> KubernetesRequest
     DeleteCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req (PropagationPolicy Text
xs) =
    KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCertificateSigningRequest 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 DeleteCertificateSigningRequest mtype

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


-- *** deleteCollectionCertificateSigningRequest

-- | @DELETE \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests@
-- 
-- delete collection of CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
deleteCollectionCertificateSigningRequest
  :: (Consumes DeleteCollectionCertificateSigningRequest contentType)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> KubernetesRequest DeleteCollectionCertificateSigningRequest contentType V1Status accept
deleteCollectionCertificateSigningRequest :: forall contentType accept.
Consumes DeleteCollectionCertificateSigningRequest contentType =>
ContentType contentType
-> Accept accept
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest
     contentType
     V1Status
     accept
deleteCollectionCertificateSigningRequest ContentType contentType
_  Accept accept
_ =
  Method
-> [ByteString]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest
     contentType
     V1Status
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"DELETE" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests"]
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest
  contentType
  V1Status
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest
     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 DeleteCollectionCertificateSigningRequest 
instance HasBodyParam DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest Continue where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> Continue
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (Continue Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> DryRun
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest FieldSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> FieldSelector
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (FieldSelector Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest GracePeriodSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> GracePeriodSeconds
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (GracePeriodSeconds Int
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest IgnoreStoreReadErrorWithClusterBreakingPotential where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> IgnoreStoreReadErrorWithClusterBreakingPotential
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (IgnoreStoreReadErrorWithClusterBreakingPotential Bool
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest LabelSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> LabelSelector
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (LabelSelector Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest Limit where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> Limit
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (Limit Int
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest OrphanDependents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> OrphanDependents
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (OrphanDependents Bool
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest PropagationPolicy where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> PropagationPolicy
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (PropagationPolicy Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest ResourceVersion where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> ResourceVersion
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (ResourceVersion Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest ResourceVersionMatch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> ResourceVersionMatch
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (ResourceVersionMatch Text
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest SendInitialEvents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> SendInitialEvents
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (SendInitialEvents Bool
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest TimeoutSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> TimeoutSeconds
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req (TimeoutSeconds Int
xs) =
    KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
req KubernetesRequest
  DeleteCollectionCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     DeleteCollectionCertificateSigningRequest 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 DeleteCollectionCertificateSigningRequest mtype

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


-- *** getAPIResources

-- | @GET \/apis\/certificates.k8s.io\/v1\/@
-- 
-- 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/certificates.k8s.io/v1/"]
    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


-- *** listCertificateSigningRequest

-- | @GET \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests@
-- 
-- list or watch objects of kind CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
listCertificateSigningRequest
  :: Accept accept -- ^ request accept ('MimeType')
  -> KubernetesRequest ListCertificateSigningRequest MimeNoContent V1CertificateSigningRequestList accept
listCertificateSigningRequest :: forall accept.
Accept accept
-> KubernetesRequest
     ListCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequestList
     accept
listCertificateSigningRequest  Accept accept
_ =
  Method
-> [ByteString]
-> KubernetesRequest
     ListCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequestList
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests"]
    KubernetesRequest
  ListCertificateSigningRequest
  MimeNoContent
  V1CertificateSigningRequestList
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ListCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequestList
     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 ListCertificateSigningRequest  

-- | /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 ListCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest AllowWatchBookmarks where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> AllowWatchBookmarks
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (AllowWatchBookmarks Bool
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest Continue where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> Continue
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (Continue Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest FieldSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> FieldSelector
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (FieldSelector Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest LabelSelector where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> LabelSelector
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (LabelSelector Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest Limit where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> Limit
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (Limit Int
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest ResourceVersion where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> ResourceVersion
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (ResourceVersion Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest ResourceVersionMatch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> ResourceVersionMatch
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (ResourceVersionMatch Text
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest SendInitialEvents where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> SendInitialEvents
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (SendInitialEvents Bool
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest TimeoutSeconds where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> TimeoutSeconds
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (TimeoutSeconds Int
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest Watch where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> Watch
-> KubernetesRequest
     ListCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req (Watch Bool
xs) =
    KubernetesRequest
  ListCertificateSigningRequest contentType res accept
req KubernetesRequest
  ListCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ListCertificateSigningRequest 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 ListCertificateSigningRequest MimeCborSeq
-- | @application/json@
instance Produces ListCertificateSigningRequest MimeJSON
-- | @application/json;stream=watch@
instance Produces ListCertificateSigningRequest MimeJsonstreamwatch
-- | @application/vnd.kubernetes.protobuf@
instance Produces ListCertificateSigningRequest MimeVndKubernetesProtobuf
-- | @application/vnd.kubernetes.protobuf;stream=watch@
instance Produces ListCertificateSigningRequest MimeVndKubernetesProtobufstreamwatch
-- | @application/cbor@
instance Produces ListCertificateSigningRequest MimeCbor
-- | @application/yaml@
instance Produces ListCertificateSigningRequest MimeYaml


-- *** patchCertificateSigningRequest

-- | @PATCH \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}@
-- 
-- partially update the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
patchCertificateSigningRequest
  :: (Consumes PatchCertificateSigningRequest contentType, MimeRender contentType Body)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Body -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest PatchCertificateSigningRequest contentType V1CertificateSigningRequest accept
patchCertificateSigningRequest :: forall contentType accept.
(Consumes PatchCertificateSigningRequest contentType,
 MimeRender contentType Body) =>
ContentType contentType
-> Accept accept
-> Body
-> Name
-> KubernetesRequest
     PatchCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
patchCertificateSigningRequest ContentType contentType
_  Accept accept
_ Body
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     PatchCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PATCH" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  PatchCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     PatchCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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
  PatchCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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 PatchCertificateSigningRequest contentType,
 MimeRender contentType Body) =>
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
`setBodyParam` Body
body

data PatchCertificateSigningRequest 
instance HasBodyParam PatchCertificateSigningRequest 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 PatchCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequest 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 PatchCertificateSigningRequest DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> DryRun
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequest 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 PatchCertificateSigningRequest FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> FieldManager
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequest 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 PatchCertificateSigningRequest FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> FieldValidation
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequest 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 PatchCertificateSigningRequest Force where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> Force
-> KubernetesRequest
     PatchCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req (Force Bool
xs) =
    KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequest 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 PatchCertificateSigningRequest MimeApplyPatchyaml
-- | @application/json-patch+json@
instance Consumes PatchCertificateSigningRequest MimeJsonPatchjson
-- | @application/merge-patch+json@
instance Consumes PatchCertificateSigningRequest MimeMergePatchjson
-- | @application/strategic-merge-patch+json@
instance Consumes PatchCertificateSigningRequest MimeStrategicMergePatchjson
-- | @application/apply-patch+cbor@
instance Consumes PatchCertificateSigningRequest MimeApplyPatchcbor

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


-- *** patchCertificateSigningRequestApproval

-- | @PATCH \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/approval@
-- 
-- partially update approval of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
patchCertificateSigningRequestApproval
  :: (Consumes PatchCertificateSigningRequestApproval contentType, MimeRender contentType Body)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Body -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest PatchCertificateSigningRequestApproval contentType V1CertificateSigningRequest accept
patchCertificateSigningRequestApproval :: forall contentType accept.
(Consumes PatchCertificateSigningRequestApproval contentType,
 MimeRender contentType Body) =>
ContentType contentType
-> Accept accept
-> Body
-> Name
-> KubernetesRequest
     PatchCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     accept
patchCertificateSigningRequestApproval ContentType contentType
_  Accept accept
_ Body
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PATCH" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/approval"]
    KubernetesRequest
  PatchCertificateSigningRequestApproval
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     PatchCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     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
  PatchCertificateSigningRequestApproval
  contentType
  V1CertificateSigningRequest
  accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     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 PatchCertificateSigningRequestApproval contentType,
 MimeRender contentType Body) =>
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
`setBodyParam` Body
body

data PatchCertificateSigningRequestApproval 
instance HasBodyParam PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> Pretty
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> DryRun
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> FieldManager
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> FieldValidation
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval Force where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> Force
-> KubernetesRequest
     PatchCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req (Force Bool
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestApproval 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 PatchCertificateSigningRequestApproval MimeApplyPatchyaml
-- | @application/json-patch+json@
instance Consumes PatchCertificateSigningRequestApproval MimeJsonPatchjson
-- | @application/merge-patch+json@
instance Consumes PatchCertificateSigningRequestApproval MimeMergePatchjson
-- | @application/strategic-merge-patch+json@
instance Consumes PatchCertificateSigningRequestApproval MimeStrategicMergePatchjson
-- | @application/apply-patch+cbor@
instance Consumes PatchCertificateSigningRequestApproval MimeApplyPatchcbor

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


-- *** patchCertificateSigningRequestStatus

-- | @PATCH \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/status@
-- 
-- partially update status of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
patchCertificateSigningRequestStatus
  :: (Consumes PatchCertificateSigningRequestStatus contentType, MimeRender contentType Body)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> Body -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest PatchCertificateSigningRequestStatus contentType V1CertificateSigningRequest accept
patchCertificateSigningRequestStatus :: forall contentType accept.
(Consumes PatchCertificateSigningRequestStatus contentType,
 MimeRender contentType Body) =>
ContentType contentType
-> Accept accept
-> Body
-> Name
-> KubernetesRequest
     PatchCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     accept
patchCertificateSigningRequestStatus ContentType contentType
_  Accept accept
_ Body
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PATCH" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  PatchCertificateSigningRequestStatus
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     PatchCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     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
  PatchCertificateSigningRequestStatus
  contentType
  V1CertificateSigningRequest
  accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     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 PatchCertificateSigningRequestStatus contentType,
 MimeRender contentType Body) =>
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> Body
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
`setBodyParam` Body
body

data PatchCertificateSigningRequestStatus 
instance HasBodyParam PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> Pretty
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> DryRun
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> FieldManager
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> FieldValidation
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus Force where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> Force
-> KubernetesRequest
     PatchCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req (Force Bool
xs) =
    KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  PatchCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     PatchCertificateSigningRequestStatus 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 PatchCertificateSigningRequestStatus MimeApplyPatchyaml
-- | @application/json-patch+json@
instance Consumes PatchCertificateSigningRequestStatus MimeJsonPatchjson
-- | @application/merge-patch+json@
instance Consumes PatchCertificateSigningRequestStatus MimeMergePatchjson
-- | @application/strategic-merge-patch+json@
instance Consumes PatchCertificateSigningRequestStatus MimeStrategicMergePatchjson
-- | @application/apply-patch+cbor@
instance Consumes PatchCertificateSigningRequestStatus MimeApplyPatchcbor

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


-- *** readCertificateSigningRequest

-- | @GET \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}@
-- 
-- read the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
readCertificateSigningRequest
  :: Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReadCertificateSigningRequest MimeNoContent V1CertificateSigningRequest accept
readCertificateSigningRequest :: forall accept.
Accept accept
-> Name
-> KubernetesRequest
     ReadCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequest
     accept
readCertificateSigningRequest  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReadCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  ReadCertificateSigningRequest
  MimeNoContent
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReadCertificateSigningRequest
     MimeNoContent
     V1CertificateSigningRequest
     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 ReadCertificateSigningRequest  

-- | /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 ReadCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReadCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     ReadCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ReadCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReadCertificateSigningRequest contentType res accept
req KubernetesRequest
  ReadCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReadCertificateSigningRequest 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 ReadCertificateSigningRequest MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReadCertificateSigningRequest MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReadCertificateSigningRequest MimeCbor
-- | @application/yaml@
instance Produces ReadCertificateSigningRequest MimeYaml


-- *** readCertificateSigningRequestApproval

-- | @GET \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/approval@
-- 
-- read approval of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
readCertificateSigningRequestApproval
  :: Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReadCertificateSigningRequestApproval MimeNoContent V1CertificateSigningRequest accept
readCertificateSigningRequestApproval :: forall accept.
Accept accept
-> Name
-> KubernetesRequest
     ReadCertificateSigningRequestApproval
     MimeNoContent
     V1CertificateSigningRequest
     accept
readCertificateSigningRequestApproval  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReadCertificateSigningRequestApproval
     MimeNoContent
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/approval"]
    KubernetesRequest
  ReadCertificateSigningRequestApproval
  MimeNoContent
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReadCertificateSigningRequestApproval
     MimeNoContent
     V1CertificateSigningRequest
     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 ReadCertificateSigningRequestApproval  

-- | /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 ReadCertificateSigningRequestApproval Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReadCertificateSigningRequestApproval contentType res accept
-> Pretty
-> KubernetesRequest
     ReadCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  ReadCertificateSigningRequestApproval contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReadCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  ReadCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReadCertificateSigningRequestApproval 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 ReadCertificateSigningRequestApproval MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReadCertificateSigningRequestApproval MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReadCertificateSigningRequestApproval MimeCbor
-- | @application/yaml@
instance Produces ReadCertificateSigningRequestApproval MimeYaml


-- *** readCertificateSigningRequestStatus

-- | @GET \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/status@
-- 
-- read status of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
readCertificateSigningRequestStatus
  :: Accept accept -- ^ request accept ('MimeType')
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReadCertificateSigningRequestStatus MimeNoContent V1CertificateSigningRequest accept
readCertificateSigningRequestStatus :: forall accept.
Accept accept
-> Name
-> KubernetesRequest
     ReadCertificateSigningRequestStatus
     MimeNoContent
     V1CertificateSigningRequest
     accept
readCertificateSigningRequestStatus  Accept accept
_ (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReadCertificateSigningRequestStatus
     MimeNoContent
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"GET" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  ReadCertificateSigningRequestStatus
  MimeNoContent
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReadCertificateSigningRequestStatus
     MimeNoContent
     V1CertificateSigningRequest
     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 ReadCertificateSigningRequestStatus  

-- | /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 ReadCertificateSigningRequestStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReadCertificateSigningRequestStatus contentType res accept
-> Pretty
-> KubernetesRequest
     ReadCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReadCertificateSigningRequestStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReadCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  ReadCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReadCertificateSigningRequestStatus 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 ReadCertificateSigningRequestStatus MimeJSON
-- | @application/vnd.kubernetes.protobuf@
instance Produces ReadCertificateSigningRequestStatus MimeVndKubernetesProtobuf
-- | @application/cbor@
instance Produces ReadCertificateSigningRequestStatus MimeCbor
-- | @application/yaml@
instance Produces ReadCertificateSigningRequestStatus MimeYaml


-- *** replaceCertificateSigningRequest

-- | @PUT \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}@
-- 
-- replace the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
replaceCertificateSigningRequest
  :: (Consumes ReplaceCertificateSigningRequest contentType, MimeRender contentType V1CertificateSigningRequest)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1CertificateSigningRequest -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReplaceCertificateSigningRequest contentType V1CertificateSigningRequest accept
replaceCertificateSigningRequest :: forall contentType accept.
(Consumes ReplaceCertificateSigningRequest contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
ContentType contentType
-> Accept accept
-> V1CertificateSigningRequest
-> Name
-> KubernetesRequest
     ReplaceCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
replaceCertificateSigningRequest ContentType contentType
_  Accept accept
_ V1CertificateSigningRequest
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReplaceCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PUT" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name]
    KubernetesRequest
  ReplaceCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReplaceCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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
  ReplaceCertificateSigningRequest
  contentType
  V1CertificateSigningRequest
  accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequest
     contentType
     V1CertificateSigningRequest
     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 ReplaceCertificateSigningRequest contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequest contentType res accept
`setBodyParam` V1CertificateSigningRequest
body

data ReplaceCertificateSigningRequest 
instance HasBodyParam ReplaceCertificateSigningRequest V1CertificateSigningRequest 

-- | /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 ReplaceCertificateSigningRequest Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> Pretty
-> KubernetesRequest
     ReplaceCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequest 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 ReplaceCertificateSigningRequest DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> DryRun
-> KubernetesRequest
     ReplaceCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequest 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 ReplaceCertificateSigningRequest FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> FieldManager
-> KubernetesRequest
     ReplaceCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequest 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 ReplaceCertificateSigningRequest FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> FieldValidation
-> KubernetesRequest
     ReplaceCertificateSigningRequest contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequest contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequest 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 ReplaceCertificateSigningRequest mtype

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


-- *** replaceCertificateSigningRequestApproval

-- | @PUT \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/approval@
-- 
-- replace approval of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
replaceCertificateSigningRequestApproval
  :: (Consumes ReplaceCertificateSigningRequestApproval contentType, MimeRender contentType V1CertificateSigningRequest)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1CertificateSigningRequest -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReplaceCertificateSigningRequestApproval contentType V1CertificateSigningRequest accept
replaceCertificateSigningRequestApproval :: forall contentType accept.
(Consumes ReplaceCertificateSigningRequestApproval contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
ContentType contentType
-> Accept accept
-> V1CertificateSigningRequest
-> Name
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     accept
replaceCertificateSigningRequestApproval ContentType contentType
_  Accept accept
_ V1CertificateSigningRequest
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PUT" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/approval"]
    KubernetesRequest
  ReplaceCertificateSigningRequestApproval
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     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
  ReplaceCertificateSigningRequestApproval
  contentType
  V1CertificateSigningRequest
  accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval
     contentType
     V1CertificateSigningRequest
     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 ReplaceCertificateSigningRequestApproval contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval contentType res accept
`setBodyParam` V1CertificateSigningRequest
body

data ReplaceCertificateSigningRequestApproval 
instance HasBodyParam ReplaceCertificateSigningRequestApproval V1CertificateSigningRequest 

-- | /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 ReplaceCertificateSigningRequestApproval Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> Pretty
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval 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 ReplaceCertificateSigningRequestApproval DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> DryRun
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval 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 ReplaceCertificateSigningRequestApproval FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> FieldManager
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval 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 ReplaceCertificateSigningRequestApproval FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> FieldValidation
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestApproval contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestApproval 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 ReplaceCertificateSigningRequestApproval mtype

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


-- *** replaceCertificateSigningRequestStatus

-- | @PUT \/apis\/certificates.k8s.io\/v1\/certificatesigningrequests\/{name}\/status@
-- 
-- replace status of the specified CertificateSigningRequest
-- 
-- AuthMethod: 'AuthApiKeyBearerToken'
-- 
replaceCertificateSigningRequestStatus
  :: (Consumes ReplaceCertificateSigningRequestStatus contentType, MimeRender contentType V1CertificateSigningRequest)
  => ContentType contentType -- ^ request content-type ('MimeType')
  -> Accept accept -- ^ request accept ('MimeType')
  -> V1CertificateSigningRequest -- ^ "body"
  -> Name -- ^ "name" -  name of the CertificateSigningRequest
  -> KubernetesRequest ReplaceCertificateSigningRequestStatus contentType V1CertificateSigningRequest accept
replaceCertificateSigningRequestStatus :: forall contentType accept.
(Consumes ReplaceCertificateSigningRequestStatus contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
ContentType contentType
-> Accept accept
-> V1CertificateSigningRequest
-> Name
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     accept
replaceCertificateSigningRequestStatus ContentType contentType
_  Accept accept
_ V1CertificateSigningRequest
body (Name Text
name) =
  Method
-> [ByteString]
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     accept
forall req contentType res accept.
Method
-> [ByteString] -> KubernetesRequest req contentType res accept
_mkRequest Method
"PUT" [ByteString
"/apis/certificates.k8s.io/v1/certificatesigningrequests/",Text -> ByteString
forall a. ToHttpApiData a => a -> ByteString
toPath Text
name,ByteString
"/status"]
    KubernetesRequest
  ReplaceCertificateSigningRequestStatus
  contentType
  V1CertificateSigningRequest
  accept
-> Proxy AuthApiKeyBearerToken
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     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
  ReplaceCertificateSigningRequestStatus
  contentType
  V1CertificateSigningRequest
  accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus
     contentType
     V1CertificateSigningRequest
     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 ReplaceCertificateSigningRequestStatus contentType,
 MimeRender contentType V1CertificateSigningRequest) =>
KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> V1CertificateSigningRequest
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus contentType res accept
`setBodyParam` V1CertificateSigningRequest
body

data ReplaceCertificateSigningRequestStatus 
instance HasBodyParam ReplaceCertificateSigningRequestStatus V1CertificateSigningRequest 

-- | /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 ReplaceCertificateSigningRequestStatus Pretty where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> Pretty
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req (Pretty Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus 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 ReplaceCertificateSigningRequestStatus DryRun where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> DryRun
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req (DryRun Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus 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 ReplaceCertificateSigningRequestStatus FieldManager where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> FieldManager
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req (FieldManager Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus 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 ReplaceCertificateSigningRequestStatus FieldValidation where
  applyOptionalParam :: forall contentType res accept.
KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> FieldValidation
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus contentType res accept
applyOptionalParam KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req (FieldValidation Text
xs) =
    KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
req KubernetesRequest
  ReplaceCertificateSigningRequestStatus contentType res accept
-> [QueryItem]
-> KubernetesRequest
     ReplaceCertificateSigningRequestStatus 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 ReplaceCertificateSigningRequestStatus mtype

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