{-# 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.DirectoryService.DeleteTrust
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deletes an existing trust relationship between your Managed Microsoft AD
-- directory and an external domain.
module Amazonka.DirectoryService.DeleteTrust
  ( -- * Creating a Request
    DeleteTrust (..),
    newDeleteTrust,

    -- * Request Lenses
    deleteTrust_deleteAssociatedConditionalForwarder,
    deleteTrust_trustId,

    -- * Destructuring the Response
    DeleteTrustResponse (..),
    newDeleteTrustResponse,

    -- * Response Lenses
    deleteTrustResponse_trustId,
    deleteTrustResponse_httpStatus,
  )
where

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

-- | Deletes the local side of an existing trust relationship between the
-- Managed Microsoft AD directory and the external domain.
--
-- /See:/ 'newDeleteTrust' smart constructor.
data DeleteTrust = DeleteTrust'
  { -- | Delete a conditional forwarder as part of a DeleteTrustRequest.
    DeleteTrust -> Maybe Bool
deleteAssociatedConditionalForwarder :: Prelude.Maybe Prelude.Bool,
    -- | The Trust ID of the trust relationship to be deleted.
    DeleteTrust -> Text
trustId :: Prelude.Text
  }
  deriving (DeleteTrust -> DeleteTrust -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteTrust -> DeleteTrust -> Bool
$c/= :: DeleteTrust -> DeleteTrust -> Bool
== :: DeleteTrust -> DeleteTrust -> Bool
$c== :: DeleteTrust -> DeleteTrust -> Bool
Prelude.Eq, ReadPrec [DeleteTrust]
ReadPrec DeleteTrust
Int -> ReadS DeleteTrust
ReadS [DeleteTrust]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteTrust]
$creadListPrec :: ReadPrec [DeleteTrust]
readPrec :: ReadPrec DeleteTrust
$creadPrec :: ReadPrec DeleteTrust
readList :: ReadS [DeleteTrust]
$creadList :: ReadS [DeleteTrust]
readsPrec :: Int -> ReadS DeleteTrust
$creadsPrec :: Int -> ReadS DeleteTrust
Prelude.Read, Int -> DeleteTrust -> ShowS
[DeleteTrust] -> ShowS
DeleteTrust -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteTrust] -> ShowS
$cshowList :: [DeleteTrust] -> ShowS
show :: DeleteTrust -> String
$cshow :: DeleteTrust -> String
showsPrec :: Int -> DeleteTrust -> ShowS
$cshowsPrec :: Int -> DeleteTrust -> ShowS
Prelude.Show, forall x. Rep DeleteTrust x -> DeleteTrust
forall x. DeleteTrust -> Rep DeleteTrust x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteTrust x -> DeleteTrust
$cfrom :: forall x. DeleteTrust -> Rep DeleteTrust x
Prelude.Generic)

-- |
-- Create a value of 'DeleteTrust' 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:
--
-- 'deleteAssociatedConditionalForwarder', 'deleteTrust_deleteAssociatedConditionalForwarder' - Delete a conditional forwarder as part of a DeleteTrustRequest.
--
-- 'trustId', 'deleteTrust_trustId' - The Trust ID of the trust relationship to be deleted.
newDeleteTrust ::
  -- | 'trustId'
  Prelude.Text ->
  DeleteTrust
newDeleteTrust :: Text -> DeleteTrust
newDeleteTrust Text
pTrustId_ =
  DeleteTrust'
    { $sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: Maybe Bool
deleteAssociatedConditionalForwarder =
        forall a. Maybe a
Prelude.Nothing,
      $sel:trustId:DeleteTrust' :: Text
trustId = Text
pTrustId_
    }

-- | Delete a conditional forwarder as part of a DeleteTrustRequest.
deleteTrust_deleteAssociatedConditionalForwarder :: Lens.Lens' DeleteTrust (Prelude.Maybe Prelude.Bool)
deleteTrust_deleteAssociatedConditionalForwarder :: Lens' DeleteTrust (Maybe Bool)
deleteTrust_deleteAssociatedConditionalForwarder = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteTrust' {Maybe Bool
deleteAssociatedConditionalForwarder :: Maybe Bool
$sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: DeleteTrust -> Maybe Bool
deleteAssociatedConditionalForwarder} -> Maybe Bool
deleteAssociatedConditionalForwarder) (\s :: DeleteTrust
s@DeleteTrust' {} Maybe Bool
a -> DeleteTrust
s {$sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: Maybe Bool
deleteAssociatedConditionalForwarder = Maybe Bool
a} :: DeleteTrust)

-- | The Trust ID of the trust relationship to be deleted.
deleteTrust_trustId :: Lens.Lens' DeleteTrust Prelude.Text
deleteTrust_trustId :: Lens' DeleteTrust Text
deleteTrust_trustId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteTrust' {Text
trustId :: Text
$sel:trustId:DeleteTrust' :: DeleteTrust -> Text
trustId} -> Text
trustId) (\s :: DeleteTrust
s@DeleteTrust' {} Text
a -> DeleteTrust
s {$sel:trustId:DeleteTrust' :: Text
trustId = Text
a} :: DeleteTrust)

instance Core.AWSRequest DeleteTrust where
  type AWSResponse DeleteTrust = DeleteTrustResponse
  request :: (Service -> Service) -> DeleteTrust -> Request DeleteTrust
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeleteTrust
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteTrust)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Text -> Int -> DeleteTrustResponse
DeleteTrustResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"TrustId")
            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 DeleteTrust where
  hashWithSalt :: Int -> DeleteTrust -> Int
hashWithSalt Int
_salt DeleteTrust' {Maybe Bool
Text
trustId :: Text
deleteAssociatedConditionalForwarder :: Maybe Bool
$sel:trustId:DeleteTrust' :: DeleteTrust -> Text
$sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: DeleteTrust -> Maybe Bool
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
deleteAssociatedConditionalForwarder
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
trustId

instance Prelude.NFData DeleteTrust where
  rnf :: DeleteTrust -> ()
rnf DeleteTrust' {Maybe Bool
Text
trustId :: Text
deleteAssociatedConditionalForwarder :: Maybe Bool
$sel:trustId:DeleteTrust' :: DeleteTrust -> Text
$sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: DeleteTrust -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
deleteAssociatedConditionalForwarder
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
trustId

instance Data.ToHeaders DeleteTrust where
  toHeaders :: DeleteTrust -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"DirectoryService_20150416.DeleteTrust" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DeleteTrust where
  toJSON :: DeleteTrust -> Value
toJSON DeleteTrust' {Maybe Bool
Text
trustId :: Text
deleteAssociatedConditionalForwarder :: Maybe Bool
$sel:trustId:DeleteTrust' :: DeleteTrust -> Text
$sel:deleteAssociatedConditionalForwarder:DeleteTrust' :: DeleteTrust -> Maybe Bool
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"DeleteAssociatedConditionalForwarder" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
              forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Bool
deleteAssociatedConditionalForwarder,
            forall a. a -> Maybe a
Prelude.Just (Key
"TrustId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
trustId)
          ]
      )

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

instance Data.ToQuery DeleteTrust where
  toQuery :: DeleteTrust -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | The result of a DeleteTrust request.
--
-- /See:/ 'newDeleteTrustResponse' smart constructor.
data DeleteTrustResponse = DeleteTrustResponse'
  { -- | The Trust ID of the trust relationship that was deleted.
    DeleteTrustResponse -> Maybe Text
trustId :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    DeleteTrustResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteTrustResponse -> DeleteTrustResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteTrustResponse -> DeleteTrustResponse -> Bool
$c/= :: DeleteTrustResponse -> DeleteTrustResponse -> Bool
== :: DeleteTrustResponse -> DeleteTrustResponse -> Bool
$c== :: DeleteTrustResponse -> DeleteTrustResponse -> Bool
Prelude.Eq, ReadPrec [DeleteTrustResponse]
ReadPrec DeleteTrustResponse
Int -> ReadS DeleteTrustResponse
ReadS [DeleteTrustResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteTrustResponse]
$creadListPrec :: ReadPrec [DeleteTrustResponse]
readPrec :: ReadPrec DeleteTrustResponse
$creadPrec :: ReadPrec DeleteTrustResponse
readList :: ReadS [DeleteTrustResponse]
$creadList :: ReadS [DeleteTrustResponse]
readsPrec :: Int -> ReadS DeleteTrustResponse
$creadsPrec :: Int -> ReadS DeleteTrustResponse
Prelude.Read, Int -> DeleteTrustResponse -> ShowS
[DeleteTrustResponse] -> ShowS
DeleteTrustResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteTrustResponse] -> ShowS
$cshowList :: [DeleteTrustResponse] -> ShowS
show :: DeleteTrustResponse -> String
$cshow :: DeleteTrustResponse -> String
showsPrec :: Int -> DeleteTrustResponse -> ShowS
$cshowsPrec :: Int -> DeleteTrustResponse -> ShowS
Prelude.Show, forall x. Rep DeleteTrustResponse x -> DeleteTrustResponse
forall x. DeleteTrustResponse -> Rep DeleteTrustResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteTrustResponse x -> DeleteTrustResponse
$cfrom :: forall x. DeleteTrustResponse -> Rep DeleteTrustResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteTrustResponse' 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:
--
-- 'trustId', 'deleteTrustResponse_trustId' - The Trust ID of the trust relationship that was deleted.
--
-- 'httpStatus', 'deleteTrustResponse_httpStatus' - The response's http status code.
newDeleteTrustResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteTrustResponse
newDeleteTrustResponse :: Int -> DeleteTrustResponse
newDeleteTrustResponse Int
pHttpStatus_ =
  DeleteTrustResponse'
    { $sel:trustId:DeleteTrustResponse' :: Maybe Text
trustId = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DeleteTrustResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The Trust ID of the trust relationship that was deleted.
deleteTrustResponse_trustId :: Lens.Lens' DeleteTrustResponse (Prelude.Maybe Prelude.Text)
deleteTrustResponse_trustId :: Lens' DeleteTrustResponse (Maybe Text)
deleteTrustResponse_trustId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteTrustResponse' {Maybe Text
trustId :: Maybe Text
$sel:trustId:DeleteTrustResponse' :: DeleteTrustResponse -> Maybe Text
trustId} -> Maybe Text
trustId) (\s :: DeleteTrustResponse
s@DeleteTrustResponse' {} Maybe Text
a -> DeleteTrustResponse
s {$sel:trustId:DeleteTrustResponse' :: Maybe Text
trustId = Maybe Text
a} :: DeleteTrustResponse)

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

instance Prelude.NFData DeleteTrustResponse where
  rnf :: DeleteTrustResponse -> ()
rnf DeleteTrustResponse' {Int
Maybe Text
httpStatus :: Int
trustId :: Maybe Text
$sel:httpStatus:DeleteTrustResponse' :: DeleteTrustResponse -> Int
$sel:trustId:DeleteTrustResponse' :: DeleteTrustResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
trustId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus