{-# 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.DMS.DeleteReplicationInstance
-- 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 the specified replication instance.
--
-- You must delete any migration tasks that are associated with the
-- replication instance before you can delete it.
module Amazonka.DMS.DeleteReplicationInstance
  ( -- * Creating a Request
    DeleteReplicationInstance (..),
    newDeleteReplicationInstance,

    -- * Request Lenses
    deleteReplicationInstance_replicationInstanceArn,

    -- * Destructuring the Response
    DeleteReplicationInstanceResponse (..),
    newDeleteReplicationInstanceResponse,

    -- * Response Lenses
    deleteReplicationInstanceResponse_replicationInstance,
    deleteReplicationInstanceResponse_httpStatus,
  )
where

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

-- |
--
-- /See:/ 'newDeleteReplicationInstance' smart constructor.
data DeleteReplicationInstance = DeleteReplicationInstance'
  { -- | The Amazon Resource Name (ARN) of the replication instance to be
    -- deleted.
    DeleteReplicationInstance -> Text
replicationInstanceArn :: Prelude.Text
  }
  deriving (DeleteReplicationInstance -> DeleteReplicationInstance -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteReplicationInstance -> DeleteReplicationInstance -> Bool
$c/= :: DeleteReplicationInstance -> DeleteReplicationInstance -> Bool
== :: DeleteReplicationInstance -> DeleteReplicationInstance -> Bool
$c== :: DeleteReplicationInstance -> DeleteReplicationInstance -> Bool
Prelude.Eq, ReadPrec [DeleteReplicationInstance]
ReadPrec DeleteReplicationInstance
Int -> ReadS DeleteReplicationInstance
ReadS [DeleteReplicationInstance]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteReplicationInstance]
$creadListPrec :: ReadPrec [DeleteReplicationInstance]
readPrec :: ReadPrec DeleteReplicationInstance
$creadPrec :: ReadPrec DeleteReplicationInstance
readList :: ReadS [DeleteReplicationInstance]
$creadList :: ReadS [DeleteReplicationInstance]
readsPrec :: Int -> ReadS DeleteReplicationInstance
$creadsPrec :: Int -> ReadS DeleteReplicationInstance
Prelude.Read, Int -> DeleteReplicationInstance -> ShowS
[DeleteReplicationInstance] -> ShowS
DeleteReplicationInstance -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteReplicationInstance] -> ShowS
$cshowList :: [DeleteReplicationInstance] -> ShowS
show :: DeleteReplicationInstance -> String
$cshow :: DeleteReplicationInstance -> String
showsPrec :: Int -> DeleteReplicationInstance -> ShowS
$cshowsPrec :: Int -> DeleteReplicationInstance -> ShowS
Prelude.Show, forall x.
Rep DeleteReplicationInstance x -> DeleteReplicationInstance
forall x.
DeleteReplicationInstance -> Rep DeleteReplicationInstance x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteReplicationInstance x -> DeleteReplicationInstance
$cfrom :: forall x.
DeleteReplicationInstance -> Rep DeleteReplicationInstance x
Prelude.Generic)

-- |
-- Create a value of 'DeleteReplicationInstance' 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:
--
-- 'replicationInstanceArn', 'deleteReplicationInstance_replicationInstanceArn' - The Amazon Resource Name (ARN) of the replication instance to be
-- deleted.
newDeleteReplicationInstance ::
  -- | 'replicationInstanceArn'
  Prelude.Text ->
  DeleteReplicationInstance
newDeleteReplicationInstance :: Text -> DeleteReplicationInstance
newDeleteReplicationInstance Text
pReplicationInstanceArn_ =
  DeleteReplicationInstance'
    { $sel:replicationInstanceArn:DeleteReplicationInstance' :: Text
replicationInstanceArn =
        Text
pReplicationInstanceArn_
    }

-- | The Amazon Resource Name (ARN) of the replication instance to be
-- deleted.
deleteReplicationInstance_replicationInstanceArn :: Lens.Lens' DeleteReplicationInstance Prelude.Text
deleteReplicationInstance_replicationInstanceArn :: Lens' DeleteReplicationInstance Text
deleteReplicationInstance_replicationInstanceArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteReplicationInstance' {Text
replicationInstanceArn :: Text
$sel:replicationInstanceArn:DeleteReplicationInstance' :: DeleteReplicationInstance -> Text
replicationInstanceArn} -> Text
replicationInstanceArn) (\s :: DeleteReplicationInstance
s@DeleteReplicationInstance' {} Text
a -> DeleteReplicationInstance
s {$sel:replicationInstanceArn:DeleteReplicationInstance' :: Text
replicationInstanceArn = Text
a} :: DeleteReplicationInstance)

instance Core.AWSRequest DeleteReplicationInstance where
  type
    AWSResponse DeleteReplicationInstance =
      DeleteReplicationInstanceResponse
  request :: (Service -> Service)
-> DeleteReplicationInstance -> Request DeleteReplicationInstance
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 DeleteReplicationInstance
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeleteReplicationInstance)))
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 ReplicationInstance
-> Int -> DeleteReplicationInstanceResponse
DeleteReplicationInstanceResponse'
            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
"ReplicationInstance")
            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 DeleteReplicationInstance where
  hashWithSalt :: Int -> DeleteReplicationInstance -> Int
hashWithSalt Int
_salt DeleteReplicationInstance' {Text
replicationInstanceArn :: Text
$sel:replicationInstanceArn:DeleteReplicationInstance' :: DeleteReplicationInstance -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
replicationInstanceArn

instance Prelude.NFData DeleteReplicationInstance where
  rnf :: DeleteReplicationInstance -> ()
rnf DeleteReplicationInstance' {Text
replicationInstanceArn :: Text
$sel:replicationInstanceArn:DeleteReplicationInstance' :: DeleteReplicationInstance -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
replicationInstanceArn

instance Data.ToHeaders DeleteReplicationInstance where
  toHeaders :: DeleteReplicationInstance -> 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
"AmazonDMSv20160101.DeleteReplicationInstance" ::
                          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 DeleteReplicationInstance where
  toJSON :: DeleteReplicationInstance -> Value
toJSON DeleteReplicationInstance' {Text
replicationInstanceArn :: Text
$sel:replicationInstanceArn:DeleteReplicationInstance' :: DeleteReplicationInstance -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just
              ( Key
"ReplicationInstanceArn"
                  forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
replicationInstanceArn
              )
          ]
      )

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

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

-- |
--
-- /See:/ 'newDeleteReplicationInstanceResponse' smart constructor.
data DeleteReplicationInstanceResponse = DeleteReplicationInstanceResponse'
  { -- | The replication instance that was deleted.
    DeleteReplicationInstanceResponse -> Maybe ReplicationInstance
replicationInstance :: Prelude.Maybe ReplicationInstance,
    -- | The response's http status code.
    DeleteReplicationInstanceResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteReplicationInstanceResponse
-> DeleteReplicationInstanceResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteReplicationInstanceResponse
-> DeleteReplicationInstanceResponse -> Bool
$c/= :: DeleteReplicationInstanceResponse
-> DeleteReplicationInstanceResponse -> Bool
== :: DeleteReplicationInstanceResponse
-> DeleteReplicationInstanceResponse -> Bool
$c== :: DeleteReplicationInstanceResponse
-> DeleteReplicationInstanceResponse -> Bool
Prelude.Eq, ReadPrec [DeleteReplicationInstanceResponse]
ReadPrec DeleteReplicationInstanceResponse
Int -> ReadS DeleteReplicationInstanceResponse
ReadS [DeleteReplicationInstanceResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteReplicationInstanceResponse]
$creadListPrec :: ReadPrec [DeleteReplicationInstanceResponse]
readPrec :: ReadPrec DeleteReplicationInstanceResponse
$creadPrec :: ReadPrec DeleteReplicationInstanceResponse
readList :: ReadS [DeleteReplicationInstanceResponse]
$creadList :: ReadS [DeleteReplicationInstanceResponse]
readsPrec :: Int -> ReadS DeleteReplicationInstanceResponse
$creadsPrec :: Int -> ReadS DeleteReplicationInstanceResponse
Prelude.Read, Int -> DeleteReplicationInstanceResponse -> ShowS
[DeleteReplicationInstanceResponse] -> ShowS
DeleteReplicationInstanceResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteReplicationInstanceResponse] -> ShowS
$cshowList :: [DeleteReplicationInstanceResponse] -> ShowS
show :: DeleteReplicationInstanceResponse -> String
$cshow :: DeleteReplicationInstanceResponse -> String
showsPrec :: Int -> DeleteReplicationInstanceResponse -> ShowS
$cshowsPrec :: Int -> DeleteReplicationInstanceResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteReplicationInstanceResponse x
-> DeleteReplicationInstanceResponse
forall x.
DeleteReplicationInstanceResponse
-> Rep DeleteReplicationInstanceResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteReplicationInstanceResponse x
-> DeleteReplicationInstanceResponse
$cfrom :: forall x.
DeleteReplicationInstanceResponse
-> Rep DeleteReplicationInstanceResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteReplicationInstanceResponse' 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:
--
-- 'replicationInstance', 'deleteReplicationInstanceResponse_replicationInstance' - The replication instance that was deleted.
--
-- 'httpStatus', 'deleteReplicationInstanceResponse_httpStatus' - The response's http status code.
newDeleteReplicationInstanceResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteReplicationInstanceResponse
newDeleteReplicationInstanceResponse :: Int -> DeleteReplicationInstanceResponse
newDeleteReplicationInstanceResponse Int
pHttpStatus_ =
  DeleteReplicationInstanceResponse'
    { $sel:replicationInstance:DeleteReplicationInstanceResponse' :: Maybe ReplicationInstance
replicationInstance =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DeleteReplicationInstanceResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The replication instance that was deleted.
deleteReplicationInstanceResponse_replicationInstance :: Lens.Lens' DeleteReplicationInstanceResponse (Prelude.Maybe ReplicationInstance)
deleteReplicationInstanceResponse_replicationInstance :: Lens' DeleteReplicationInstanceResponse (Maybe ReplicationInstance)
deleteReplicationInstanceResponse_replicationInstance = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteReplicationInstanceResponse' {Maybe ReplicationInstance
replicationInstance :: Maybe ReplicationInstance
$sel:replicationInstance:DeleteReplicationInstanceResponse' :: DeleteReplicationInstanceResponse -> Maybe ReplicationInstance
replicationInstance} -> Maybe ReplicationInstance
replicationInstance) (\s :: DeleteReplicationInstanceResponse
s@DeleteReplicationInstanceResponse' {} Maybe ReplicationInstance
a -> DeleteReplicationInstanceResponse
s {$sel:replicationInstance:DeleteReplicationInstanceResponse' :: Maybe ReplicationInstance
replicationInstance = Maybe ReplicationInstance
a} :: DeleteReplicationInstanceResponse)

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

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