{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.EC2.DetachVerifiedAccessTrustProvider
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Detach a trust provider from an Amazon Web Services Verified Access
-- instance.
module Amazonka.EC2.DetachVerifiedAccessTrustProvider
  ( -- * Creating a Request
    DetachVerifiedAccessTrustProvider (..),
    newDetachVerifiedAccessTrustProvider,

    -- * Request Lenses
    detachVerifiedAccessTrustProvider_clientToken,
    detachVerifiedAccessTrustProvider_dryRun,
    detachVerifiedAccessTrustProvider_verifiedAccessInstanceId,
    detachVerifiedAccessTrustProvider_verifiedAccessTrustProviderId,

    -- * Destructuring the Response
    DetachVerifiedAccessTrustProviderResponse (..),
    newDetachVerifiedAccessTrustProviderResponse,

    -- * Response Lenses
    detachVerifiedAccessTrustProviderResponse_verifiedAccessInstance,
    detachVerifiedAccessTrustProviderResponse_verifiedAccessTrustProvider,
    detachVerifiedAccessTrustProviderResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDetachVerifiedAccessTrustProvider' smart constructor.
data DetachVerifiedAccessTrustProvider = DetachVerifiedAccessTrustProvider'
  { -- | A unique, case-sensitive token that you provide to ensure idempotency of
    -- your modification request. For more information, see
    -- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
    DetachVerifiedAccessTrustProvider -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
    -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    DetachVerifiedAccessTrustProvider -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The ID of the Amazon Web Services Verified Access instance.
    DetachVerifiedAccessTrustProvider -> Text
verifiedAccessInstanceId :: Prelude.Text,
    -- | The ID of the Amazon Web Services Verified Access trust provider.
    DetachVerifiedAccessTrustProvider -> Text
verifiedAccessTrustProviderId :: Prelude.Text
  }
  deriving (DetachVerifiedAccessTrustProvider
-> DetachVerifiedAccessTrustProvider -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DetachVerifiedAccessTrustProvider
-> DetachVerifiedAccessTrustProvider -> Bool
$c/= :: DetachVerifiedAccessTrustProvider
-> DetachVerifiedAccessTrustProvider -> Bool
== :: DetachVerifiedAccessTrustProvider
-> DetachVerifiedAccessTrustProvider -> Bool
$c== :: DetachVerifiedAccessTrustProvider
-> DetachVerifiedAccessTrustProvider -> Bool
Prelude.Eq, ReadPrec [DetachVerifiedAccessTrustProvider]
ReadPrec DetachVerifiedAccessTrustProvider
Int -> ReadS DetachVerifiedAccessTrustProvider
ReadS [DetachVerifiedAccessTrustProvider]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DetachVerifiedAccessTrustProvider]
$creadListPrec :: ReadPrec [DetachVerifiedAccessTrustProvider]
readPrec :: ReadPrec DetachVerifiedAccessTrustProvider
$creadPrec :: ReadPrec DetachVerifiedAccessTrustProvider
readList :: ReadS [DetachVerifiedAccessTrustProvider]
$creadList :: ReadS [DetachVerifiedAccessTrustProvider]
readsPrec :: Int -> ReadS DetachVerifiedAccessTrustProvider
$creadsPrec :: Int -> ReadS DetachVerifiedAccessTrustProvider
Prelude.Read, Int -> DetachVerifiedAccessTrustProvider -> ShowS
[DetachVerifiedAccessTrustProvider] -> ShowS
DetachVerifiedAccessTrustProvider -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DetachVerifiedAccessTrustProvider] -> ShowS
$cshowList :: [DetachVerifiedAccessTrustProvider] -> ShowS
show :: DetachVerifiedAccessTrustProvider -> String
$cshow :: DetachVerifiedAccessTrustProvider -> String
showsPrec :: Int -> DetachVerifiedAccessTrustProvider -> ShowS
$cshowsPrec :: Int -> DetachVerifiedAccessTrustProvider -> ShowS
Prelude.Show, forall x.
Rep DetachVerifiedAccessTrustProvider x
-> DetachVerifiedAccessTrustProvider
forall x.
DetachVerifiedAccessTrustProvider
-> Rep DetachVerifiedAccessTrustProvider x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DetachVerifiedAccessTrustProvider x
-> DetachVerifiedAccessTrustProvider
$cfrom :: forall x.
DetachVerifiedAccessTrustProvider
-> Rep DetachVerifiedAccessTrustProvider x
Prelude.Generic)

-- |
-- Create a value of 'DetachVerifiedAccessTrustProvider' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'clientToken', 'detachVerifiedAccessTrustProvider_clientToken' - A unique, case-sensitive token that you provide to ensure idempotency of
-- your modification request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
--
-- 'dryRun', 'detachVerifiedAccessTrustProvider_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
--
-- 'verifiedAccessInstanceId', 'detachVerifiedAccessTrustProvider_verifiedAccessInstanceId' - The ID of the Amazon Web Services Verified Access instance.
--
-- 'verifiedAccessTrustProviderId', 'detachVerifiedAccessTrustProvider_verifiedAccessTrustProviderId' - The ID of the Amazon Web Services Verified Access trust provider.
newDetachVerifiedAccessTrustProvider ::
  -- | 'verifiedAccessInstanceId'
  Prelude.Text ->
  -- | 'verifiedAccessTrustProviderId'
  Prelude.Text ->
  DetachVerifiedAccessTrustProvider
newDetachVerifiedAccessTrustProvider :: Text -> Text -> DetachVerifiedAccessTrustProvider
newDetachVerifiedAccessTrustProvider
  Text
pVerifiedAccessInstanceId_
  Text
pVerifiedAccessTrustProviderId_ =
    DetachVerifiedAccessTrustProvider'
      { $sel:clientToken:DetachVerifiedAccessTrustProvider' :: Maybe Text
clientToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:dryRun:DetachVerifiedAccessTrustProvider' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
        $sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: Text
verifiedAccessInstanceId =
          Text
pVerifiedAccessInstanceId_,
        $sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: Text
verifiedAccessTrustProviderId =
          Text
pVerifiedAccessTrustProviderId_
      }

-- | A unique, case-sensitive token that you provide to ensure idempotency of
-- your modification request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html Ensuring Idempotency>.
detachVerifiedAccessTrustProvider_clientToken :: Lens.Lens' DetachVerifiedAccessTrustProvider (Prelude.Maybe Prelude.Text)
detachVerifiedAccessTrustProvider_clientToken :: Lens' DetachVerifiedAccessTrustProvider (Maybe Text)
detachVerifiedAccessTrustProvider_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProvider' {Maybe Text
clientToken :: Maybe Text
$sel:clientToken:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Text
clientToken} -> Maybe Text
clientToken) (\s :: DetachVerifiedAccessTrustProvider
s@DetachVerifiedAccessTrustProvider' {} Maybe Text
a -> DetachVerifiedAccessTrustProvider
s {$sel:clientToken:DetachVerifiedAccessTrustProvider' :: Maybe Text
clientToken = Maybe Text
a} :: DetachVerifiedAccessTrustProvider)

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
detachVerifiedAccessTrustProvider_dryRun :: Lens.Lens' DetachVerifiedAccessTrustProvider (Prelude.Maybe Prelude.Bool)
detachVerifiedAccessTrustProvider_dryRun :: Lens' DetachVerifiedAccessTrustProvider (Maybe Bool)
detachVerifiedAccessTrustProvider_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProvider' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DetachVerifiedAccessTrustProvider
s@DetachVerifiedAccessTrustProvider' {} Maybe Bool
a -> DetachVerifiedAccessTrustProvider
s {$sel:dryRun:DetachVerifiedAccessTrustProvider' :: Maybe Bool
dryRun = Maybe Bool
a} :: DetachVerifiedAccessTrustProvider)

-- | The ID of the Amazon Web Services Verified Access instance.
detachVerifiedAccessTrustProvider_verifiedAccessInstanceId :: Lens.Lens' DetachVerifiedAccessTrustProvider Prelude.Text
detachVerifiedAccessTrustProvider_verifiedAccessInstanceId :: Lens' DetachVerifiedAccessTrustProvider Text
detachVerifiedAccessTrustProvider_verifiedAccessInstanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProvider' {Text
verifiedAccessInstanceId :: Text
$sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
verifiedAccessInstanceId} -> Text
verifiedAccessInstanceId) (\s :: DetachVerifiedAccessTrustProvider
s@DetachVerifiedAccessTrustProvider' {} Text
a -> DetachVerifiedAccessTrustProvider
s {$sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: Text
verifiedAccessInstanceId = Text
a} :: DetachVerifiedAccessTrustProvider)

-- | The ID of the Amazon Web Services Verified Access trust provider.
detachVerifiedAccessTrustProvider_verifiedAccessTrustProviderId :: Lens.Lens' DetachVerifiedAccessTrustProvider Prelude.Text
detachVerifiedAccessTrustProvider_verifiedAccessTrustProviderId :: Lens' DetachVerifiedAccessTrustProvider Text
detachVerifiedAccessTrustProvider_verifiedAccessTrustProviderId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProvider' {Text
verifiedAccessTrustProviderId :: Text
$sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
verifiedAccessTrustProviderId} -> Text
verifiedAccessTrustProviderId) (\s :: DetachVerifiedAccessTrustProvider
s@DetachVerifiedAccessTrustProvider' {} Text
a -> DetachVerifiedAccessTrustProvider
s {$sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: Text
verifiedAccessTrustProviderId = Text
a} :: DetachVerifiedAccessTrustProvider)

instance
  Core.AWSRequest
    DetachVerifiedAccessTrustProvider
  where
  type
    AWSResponse DetachVerifiedAccessTrustProvider =
      DetachVerifiedAccessTrustProviderResponse
  request :: (Service -> Service)
-> DetachVerifiedAccessTrustProvider
-> Request DetachVerifiedAccessTrustProvider
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DetachVerifiedAccessTrustProvider
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse DetachVerifiedAccessTrustProvider)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe VerifiedAccessInstance
-> Maybe VerifiedAccessTrustProvider
-> Int
-> DetachVerifiedAccessTrustProviderResponse
DetachVerifiedAccessTrustProviderResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"verifiedAccessInstance")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"verifiedAccessTrustProvider")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance
  Prelude.Hashable
    DetachVerifiedAccessTrustProvider
  where
  hashWithSalt :: Int -> DetachVerifiedAccessTrustProvider -> Int
hashWithSalt
    Int
_salt
    DetachVerifiedAccessTrustProvider' {Maybe Bool
Maybe Text
Text
verifiedAccessTrustProviderId :: Text
verifiedAccessInstanceId :: Text
dryRun :: Maybe Bool
clientToken :: Maybe Text
$sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:dryRun:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Bool
$sel:clientToken:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Text
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientToken
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
verifiedAccessInstanceId
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
verifiedAccessTrustProviderId

instance
  Prelude.NFData
    DetachVerifiedAccessTrustProvider
  where
  rnf :: DetachVerifiedAccessTrustProvider -> ()
rnf DetachVerifiedAccessTrustProvider' {Maybe Bool
Maybe Text
Text
verifiedAccessTrustProviderId :: Text
verifiedAccessInstanceId :: Text
dryRun :: Maybe Bool
clientToken :: Maybe Text
$sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:dryRun:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Bool
$sel:clientToken:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
verifiedAccessInstanceId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
verifiedAccessTrustProviderId

instance
  Data.ToHeaders
    DetachVerifiedAccessTrustProvider
  where
  toHeaders :: DetachVerifiedAccessTrustProvider -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

instance
  Data.ToPath
    DetachVerifiedAccessTrustProvider
  where
  toPath :: DetachVerifiedAccessTrustProvider -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance
  Data.ToQuery
    DetachVerifiedAccessTrustProvider
  where
  toQuery :: DetachVerifiedAccessTrustProvider -> QueryString
toQuery DetachVerifiedAccessTrustProvider' {Maybe Bool
Maybe Text
Text
verifiedAccessTrustProviderId :: Text
verifiedAccessInstanceId :: Text
dryRun :: Maybe Bool
clientToken :: Maybe Text
$sel:verifiedAccessTrustProviderId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:verifiedAccessInstanceId:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Text
$sel:dryRun:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Bool
$sel:clientToken:DetachVerifiedAccessTrustProvider' :: DetachVerifiedAccessTrustProvider -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: ( ByteString
"DetachVerifiedAccessTrustProvider" ::
                      Prelude.ByteString
                  ),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"ClientToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
clientToken,
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        ByteString
"VerifiedAccessInstanceId"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
verifiedAccessInstanceId,
        ByteString
"VerifiedAccessTrustProviderId"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
verifiedAccessTrustProviderId
      ]

-- | /See:/ 'newDetachVerifiedAccessTrustProviderResponse' smart constructor.
data DetachVerifiedAccessTrustProviderResponse = DetachVerifiedAccessTrustProviderResponse'
  { -- | The ID of the Amazon Web Services Verified Access instance.
    DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessInstance
verifiedAccessInstance :: Prelude.Maybe VerifiedAccessInstance,
    -- | The ID of the Amazon Web Services Verified Access trust provider.
    DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider :: Prelude.Maybe VerifiedAccessTrustProvider,
    -- | The response's http status code.
    DetachVerifiedAccessTrustProviderResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DetachVerifiedAccessTrustProviderResponse
-> DetachVerifiedAccessTrustProviderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DetachVerifiedAccessTrustProviderResponse
-> DetachVerifiedAccessTrustProviderResponse -> Bool
$c/= :: DetachVerifiedAccessTrustProviderResponse
-> DetachVerifiedAccessTrustProviderResponse -> Bool
== :: DetachVerifiedAccessTrustProviderResponse
-> DetachVerifiedAccessTrustProviderResponse -> Bool
$c== :: DetachVerifiedAccessTrustProviderResponse
-> DetachVerifiedAccessTrustProviderResponse -> Bool
Prelude.Eq, ReadPrec [DetachVerifiedAccessTrustProviderResponse]
ReadPrec DetachVerifiedAccessTrustProviderResponse
Int -> ReadS DetachVerifiedAccessTrustProviderResponse
ReadS [DetachVerifiedAccessTrustProviderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DetachVerifiedAccessTrustProviderResponse]
$creadListPrec :: ReadPrec [DetachVerifiedAccessTrustProviderResponse]
readPrec :: ReadPrec DetachVerifiedAccessTrustProviderResponse
$creadPrec :: ReadPrec DetachVerifiedAccessTrustProviderResponse
readList :: ReadS [DetachVerifiedAccessTrustProviderResponse]
$creadList :: ReadS [DetachVerifiedAccessTrustProviderResponse]
readsPrec :: Int -> ReadS DetachVerifiedAccessTrustProviderResponse
$creadsPrec :: Int -> ReadS DetachVerifiedAccessTrustProviderResponse
Prelude.Read, Int -> DetachVerifiedAccessTrustProviderResponse -> ShowS
[DetachVerifiedAccessTrustProviderResponse] -> ShowS
DetachVerifiedAccessTrustProviderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DetachVerifiedAccessTrustProviderResponse] -> ShowS
$cshowList :: [DetachVerifiedAccessTrustProviderResponse] -> ShowS
show :: DetachVerifiedAccessTrustProviderResponse -> String
$cshow :: DetachVerifiedAccessTrustProviderResponse -> String
showsPrec :: Int -> DetachVerifiedAccessTrustProviderResponse -> ShowS
$cshowsPrec :: Int -> DetachVerifiedAccessTrustProviderResponse -> ShowS
Prelude.Show, forall x.
Rep DetachVerifiedAccessTrustProviderResponse x
-> DetachVerifiedAccessTrustProviderResponse
forall x.
DetachVerifiedAccessTrustProviderResponse
-> Rep DetachVerifiedAccessTrustProviderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DetachVerifiedAccessTrustProviderResponse x
-> DetachVerifiedAccessTrustProviderResponse
$cfrom :: forall x.
DetachVerifiedAccessTrustProviderResponse
-> Rep DetachVerifiedAccessTrustProviderResponse x
Prelude.Generic)

-- |
-- Create a value of 'DetachVerifiedAccessTrustProviderResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'verifiedAccessInstance', 'detachVerifiedAccessTrustProviderResponse_verifiedAccessInstance' - The ID of the Amazon Web Services Verified Access instance.
--
-- 'verifiedAccessTrustProvider', 'detachVerifiedAccessTrustProviderResponse_verifiedAccessTrustProvider' - The ID of the Amazon Web Services Verified Access trust provider.
--
-- 'httpStatus', 'detachVerifiedAccessTrustProviderResponse_httpStatus' - The response's http status code.
newDetachVerifiedAccessTrustProviderResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DetachVerifiedAccessTrustProviderResponse
newDetachVerifiedAccessTrustProviderResponse :: Int -> DetachVerifiedAccessTrustProviderResponse
newDetachVerifiedAccessTrustProviderResponse
  Int
pHttpStatus_ =
    DetachVerifiedAccessTrustProviderResponse'
      { $sel:verifiedAccessInstance:DetachVerifiedAccessTrustProviderResponse' :: Maybe VerifiedAccessInstance
verifiedAccessInstance =
          forall a. Maybe a
Prelude.Nothing,
        $sel:verifiedAccessTrustProvider:DetachVerifiedAccessTrustProviderResponse' :: Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:DetachVerifiedAccessTrustProviderResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | The ID of the Amazon Web Services Verified Access instance.
detachVerifiedAccessTrustProviderResponse_verifiedAccessInstance :: Lens.Lens' DetachVerifiedAccessTrustProviderResponse (Prelude.Maybe VerifiedAccessInstance)
detachVerifiedAccessTrustProviderResponse_verifiedAccessInstance :: Lens'
  DetachVerifiedAccessTrustProviderResponse
  (Maybe VerifiedAccessInstance)
detachVerifiedAccessTrustProviderResponse_verifiedAccessInstance = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProviderResponse' {Maybe VerifiedAccessInstance
verifiedAccessInstance :: Maybe VerifiedAccessInstance
$sel:verifiedAccessInstance:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessInstance
verifiedAccessInstance} -> Maybe VerifiedAccessInstance
verifiedAccessInstance) (\s :: DetachVerifiedAccessTrustProviderResponse
s@DetachVerifiedAccessTrustProviderResponse' {} Maybe VerifiedAccessInstance
a -> DetachVerifiedAccessTrustProviderResponse
s {$sel:verifiedAccessInstance:DetachVerifiedAccessTrustProviderResponse' :: Maybe VerifiedAccessInstance
verifiedAccessInstance = Maybe VerifiedAccessInstance
a} :: DetachVerifiedAccessTrustProviderResponse)

-- | The ID of the Amazon Web Services Verified Access trust provider.
detachVerifiedAccessTrustProviderResponse_verifiedAccessTrustProvider :: Lens.Lens' DetachVerifiedAccessTrustProviderResponse (Prelude.Maybe VerifiedAccessTrustProvider)
detachVerifiedAccessTrustProviderResponse_verifiedAccessTrustProvider :: Lens'
  DetachVerifiedAccessTrustProviderResponse
  (Maybe VerifiedAccessTrustProvider)
detachVerifiedAccessTrustProviderResponse_verifiedAccessTrustProvider = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProviderResponse' {Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider :: Maybe VerifiedAccessTrustProvider
$sel:verifiedAccessTrustProvider:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider} -> Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider) (\s :: DetachVerifiedAccessTrustProviderResponse
s@DetachVerifiedAccessTrustProviderResponse' {} Maybe VerifiedAccessTrustProvider
a -> DetachVerifiedAccessTrustProviderResponse
s {$sel:verifiedAccessTrustProvider:DetachVerifiedAccessTrustProviderResponse' :: Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider = Maybe VerifiedAccessTrustProvider
a} :: DetachVerifiedAccessTrustProviderResponse)

-- | The response's http status code.
detachVerifiedAccessTrustProviderResponse_httpStatus :: Lens.Lens' DetachVerifiedAccessTrustProviderResponse Prelude.Int
detachVerifiedAccessTrustProviderResponse_httpStatus :: Lens' DetachVerifiedAccessTrustProviderResponse Int
detachVerifiedAccessTrustProviderResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DetachVerifiedAccessTrustProviderResponse' {Int
httpStatus :: Int
$sel:httpStatus:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DetachVerifiedAccessTrustProviderResponse
s@DetachVerifiedAccessTrustProviderResponse' {} Int
a -> DetachVerifiedAccessTrustProviderResponse
s {$sel:httpStatus:DetachVerifiedAccessTrustProviderResponse' :: Int
httpStatus = Int
a} :: DetachVerifiedAccessTrustProviderResponse)

instance
  Prelude.NFData
    DetachVerifiedAccessTrustProviderResponse
  where
  rnf :: DetachVerifiedAccessTrustProviderResponse -> ()
rnf DetachVerifiedAccessTrustProviderResponse' {Int
Maybe VerifiedAccessTrustProvider
Maybe VerifiedAccessInstance
httpStatus :: Int
verifiedAccessTrustProvider :: Maybe VerifiedAccessTrustProvider
verifiedAccessInstance :: Maybe VerifiedAccessInstance
$sel:httpStatus:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse -> Int
$sel:verifiedAccessTrustProvider:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessTrustProvider
$sel:verifiedAccessInstance:DetachVerifiedAccessTrustProviderResponse' :: DetachVerifiedAccessTrustProviderResponse
-> Maybe VerifiedAccessInstance
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe VerifiedAccessInstance
verifiedAccessInstance
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe VerifiedAccessTrustProvider
verifiedAccessTrustProvider
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus