{-# 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.DeleteLaunchTemplate
-- 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 a launch template. Deleting a launch template deletes all of its
-- versions.
module Amazonka.EC2.DeleteLaunchTemplate
  ( -- * Creating a Request
    DeleteLaunchTemplate (..),
    newDeleteLaunchTemplate,

    -- * Request Lenses
    deleteLaunchTemplate_dryRun,
    deleteLaunchTemplate_launchTemplateId,
    deleteLaunchTemplate_launchTemplateName,

    -- * Destructuring the Response
    DeleteLaunchTemplateResponse (..),
    newDeleteLaunchTemplateResponse,

    -- * Response Lenses
    deleteLaunchTemplateResponse_launchTemplate,
    deleteLaunchTemplateResponse_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:/ 'newDeleteLaunchTemplate' smart constructor.
data DeleteLaunchTemplate = DeleteLaunchTemplate'
  { -- | 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@.
    DeleteLaunchTemplate -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The ID of the launch template.
    --
    -- You must specify either the @LaunchTemplateId@ or the
    -- @LaunchTemplateName@, but not both.
    DeleteLaunchTemplate -> Maybe Text
launchTemplateId :: Prelude.Maybe Prelude.Text,
    -- | The name of the launch template.
    --
    -- You must specify either the @LaunchTemplateName@ or the
    -- @LaunchTemplateId@, but not both.
    DeleteLaunchTemplate -> Maybe Text
launchTemplateName :: Prelude.Maybe Prelude.Text
  }
  deriving (DeleteLaunchTemplate -> DeleteLaunchTemplate -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteLaunchTemplate -> DeleteLaunchTemplate -> Bool
$c/= :: DeleteLaunchTemplate -> DeleteLaunchTemplate -> Bool
== :: DeleteLaunchTemplate -> DeleteLaunchTemplate -> Bool
$c== :: DeleteLaunchTemplate -> DeleteLaunchTemplate -> Bool
Prelude.Eq, ReadPrec [DeleteLaunchTemplate]
ReadPrec DeleteLaunchTemplate
Int -> ReadS DeleteLaunchTemplate
ReadS [DeleteLaunchTemplate]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteLaunchTemplate]
$creadListPrec :: ReadPrec [DeleteLaunchTemplate]
readPrec :: ReadPrec DeleteLaunchTemplate
$creadPrec :: ReadPrec DeleteLaunchTemplate
readList :: ReadS [DeleteLaunchTemplate]
$creadList :: ReadS [DeleteLaunchTemplate]
readsPrec :: Int -> ReadS DeleteLaunchTemplate
$creadsPrec :: Int -> ReadS DeleteLaunchTemplate
Prelude.Read, Int -> DeleteLaunchTemplate -> ShowS
[DeleteLaunchTemplate] -> ShowS
DeleteLaunchTemplate -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteLaunchTemplate] -> ShowS
$cshowList :: [DeleteLaunchTemplate] -> ShowS
show :: DeleteLaunchTemplate -> String
$cshow :: DeleteLaunchTemplate -> String
showsPrec :: Int -> DeleteLaunchTemplate -> ShowS
$cshowsPrec :: Int -> DeleteLaunchTemplate -> ShowS
Prelude.Show, forall x. Rep DeleteLaunchTemplate x -> DeleteLaunchTemplate
forall x. DeleteLaunchTemplate -> Rep DeleteLaunchTemplate x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteLaunchTemplate x -> DeleteLaunchTemplate
$cfrom :: forall x. DeleteLaunchTemplate -> Rep DeleteLaunchTemplate x
Prelude.Generic)

-- |
-- Create a value of 'DeleteLaunchTemplate' 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:
--
-- 'dryRun', 'deleteLaunchTemplate_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@.
--
-- 'launchTemplateId', 'deleteLaunchTemplate_launchTemplateId' - The ID of the launch template.
--
-- You must specify either the @LaunchTemplateId@ or the
-- @LaunchTemplateName@, but not both.
--
-- 'launchTemplateName', 'deleteLaunchTemplate_launchTemplateName' - The name of the launch template.
--
-- You must specify either the @LaunchTemplateName@ or the
-- @LaunchTemplateId@, but not both.
newDeleteLaunchTemplate ::
  DeleteLaunchTemplate
newDeleteLaunchTemplate :: DeleteLaunchTemplate
newDeleteLaunchTemplate =
  DeleteLaunchTemplate'
    { $sel:dryRun:DeleteLaunchTemplate' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
      $sel:launchTemplateId:DeleteLaunchTemplate' :: Maybe Text
launchTemplateId = forall a. Maybe a
Prelude.Nothing,
      $sel:launchTemplateName:DeleteLaunchTemplate' :: Maybe Text
launchTemplateName = forall a. Maybe a
Prelude.Nothing
    }

-- | 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@.
deleteLaunchTemplate_dryRun :: Lens.Lens' DeleteLaunchTemplate (Prelude.Maybe Prelude.Bool)
deleteLaunchTemplate_dryRun :: Lens' DeleteLaunchTemplate (Maybe Bool)
deleteLaunchTemplate_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLaunchTemplate' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DeleteLaunchTemplate
s@DeleteLaunchTemplate' {} Maybe Bool
a -> DeleteLaunchTemplate
s {$sel:dryRun:DeleteLaunchTemplate' :: Maybe Bool
dryRun = Maybe Bool
a} :: DeleteLaunchTemplate)

-- | The ID of the launch template.
--
-- You must specify either the @LaunchTemplateId@ or the
-- @LaunchTemplateName@, but not both.
deleteLaunchTemplate_launchTemplateId :: Lens.Lens' DeleteLaunchTemplate (Prelude.Maybe Prelude.Text)
deleteLaunchTemplate_launchTemplateId :: Lens' DeleteLaunchTemplate (Maybe Text)
deleteLaunchTemplate_launchTemplateId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLaunchTemplate' {Maybe Text
launchTemplateId :: Maybe Text
$sel:launchTemplateId:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
launchTemplateId} -> Maybe Text
launchTemplateId) (\s :: DeleteLaunchTemplate
s@DeleteLaunchTemplate' {} Maybe Text
a -> DeleteLaunchTemplate
s {$sel:launchTemplateId:DeleteLaunchTemplate' :: Maybe Text
launchTemplateId = Maybe Text
a} :: DeleteLaunchTemplate)

-- | The name of the launch template.
--
-- You must specify either the @LaunchTemplateName@ or the
-- @LaunchTemplateId@, but not both.
deleteLaunchTemplate_launchTemplateName :: Lens.Lens' DeleteLaunchTemplate (Prelude.Maybe Prelude.Text)
deleteLaunchTemplate_launchTemplateName :: Lens' DeleteLaunchTemplate (Maybe Text)
deleteLaunchTemplate_launchTemplateName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLaunchTemplate' {Maybe Text
launchTemplateName :: Maybe Text
$sel:launchTemplateName:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
launchTemplateName} -> Maybe Text
launchTemplateName) (\s :: DeleteLaunchTemplate
s@DeleteLaunchTemplate' {} Maybe Text
a -> DeleteLaunchTemplate
s {$sel:launchTemplateName:DeleteLaunchTemplate' :: Maybe Text
launchTemplateName = Maybe Text
a} :: DeleteLaunchTemplate)

instance Core.AWSRequest DeleteLaunchTemplate where
  type
    AWSResponse DeleteLaunchTemplate =
      DeleteLaunchTemplateResponse
  request :: (Service -> Service)
-> DeleteLaunchTemplate -> Request DeleteLaunchTemplate
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 DeleteLaunchTemplate
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeleteLaunchTemplate)))
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 LaunchTemplate -> Int -> DeleteLaunchTemplateResponse
DeleteLaunchTemplateResponse'
            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
"launchTemplate")
            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 DeleteLaunchTemplate where
  hashWithSalt :: Int -> DeleteLaunchTemplate -> Int
hashWithSalt Int
_salt DeleteLaunchTemplate' {Maybe Bool
Maybe Text
launchTemplateName :: Maybe Text
launchTemplateId :: Maybe Text
dryRun :: Maybe Bool
$sel:launchTemplateName:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:launchTemplateId:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:dryRun:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Bool
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
launchTemplateId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
launchTemplateName

instance Prelude.NFData DeleteLaunchTemplate where
  rnf :: DeleteLaunchTemplate -> ()
rnf DeleteLaunchTemplate' {Maybe Bool
Maybe Text
launchTemplateName :: Maybe Text
launchTemplateId :: Maybe Text
dryRun :: Maybe Bool
$sel:launchTemplateName:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:launchTemplateId:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:dryRun:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Bool
..} =
    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 Maybe Text
launchTemplateId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
launchTemplateName

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

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

instance Data.ToQuery DeleteLaunchTemplate where
  toQuery :: DeleteLaunchTemplate -> QueryString
toQuery DeleteLaunchTemplate' {Maybe Bool
Maybe Text
launchTemplateName :: Maybe Text
launchTemplateId :: Maybe Text
dryRun :: Maybe Bool
$sel:launchTemplateName:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:launchTemplateId:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Text
$sel:dryRun:DeleteLaunchTemplate' :: DeleteLaunchTemplate -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DeleteLaunchTemplate" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        ByteString
"LaunchTemplateId" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
launchTemplateId,
        ByteString
"LaunchTemplateName" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
launchTemplateName
      ]

-- | /See:/ 'newDeleteLaunchTemplateResponse' smart constructor.
data DeleteLaunchTemplateResponse = DeleteLaunchTemplateResponse'
  { -- | Information about the launch template.
    DeleteLaunchTemplateResponse -> Maybe LaunchTemplate
launchTemplate :: Prelude.Maybe LaunchTemplate,
    -- | The response's http status code.
    DeleteLaunchTemplateResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteLaunchTemplateResponse
-> DeleteLaunchTemplateResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteLaunchTemplateResponse
-> DeleteLaunchTemplateResponse -> Bool
$c/= :: DeleteLaunchTemplateResponse
-> DeleteLaunchTemplateResponse -> Bool
== :: DeleteLaunchTemplateResponse
-> DeleteLaunchTemplateResponse -> Bool
$c== :: DeleteLaunchTemplateResponse
-> DeleteLaunchTemplateResponse -> Bool
Prelude.Eq, ReadPrec [DeleteLaunchTemplateResponse]
ReadPrec DeleteLaunchTemplateResponse
Int -> ReadS DeleteLaunchTemplateResponse
ReadS [DeleteLaunchTemplateResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteLaunchTemplateResponse]
$creadListPrec :: ReadPrec [DeleteLaunchTemplateResponse]
readPrec :: ReadPrec DeleteLaunchTemplateResponse
$creadPrec :: ReadPrec DeleteLaunchTemplateResponse
readList :: ReadS [DeleteLaunchTemplateResponse]
$creadList :: ReadS [DeleteLaunchTemplateResponse]
readsPrec :: Int -> ReadS DeleteLaunchTemplateResponse
$creadsPrec :: Int -> ReadS DeleteLaunchTemplateResponse
Prelude.Read, Int -> DeleteLaunchTemplateResponse -> ShowS
[DeleteLaunchTemplateResponse] -> ShowS
DeleteLaunchTemplateResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteLaunchTemplateResponse] -> ShowS
$cshowList :: [DeleteLaunchTemplateResponse] -> ShowS
show :: DeleteLaunchTemplateResponse -> String
$cshow :: DeleteLaunchTemplateResponse -> String
showsPrec :: Int -> DeleteLaunchTemplateResponse -> ShowS
$cshowsPrec :: Int -> DeleteLaunchTemplateResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteLaunchTemplateResponse x -> DeleteLaunchTemplateResponse
forall x.
DeleteLaunchTemplateResponse -> Rep DeleteLaunchTemplateResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteLaunchTemplateResponse x -> DeleteLaunchTemplateResponse
$cfrom :: forall x.
DeleteLaunchTemplateResponse -> Rep DeleteLaunchTemplateResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteLaunchTemplateResponse' 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:
--
-- 'launchTemplate', 'deleteLaunchTemplateResponse_launchTemplate' - Information about the launch template.
--
-- 'httpStatus', 'deleteLaunchTemplateResponse_httpStatus' - The response's http status code.
newDeleteLaunchTemplateResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteLaunchTemplateResponse
newDeleteLaunchTemplateResponse :: Int -> DeleteLaunchTemplateResponse
newDeleteLaunchTemplateResponse Int
pHttpStatus_ =
  DeleteLaunchTemplateResponse'
    { $sel:launchTemplate:DeleteLaunchTemplateResponse' :: Maybe LaunchTemplate
launchTemplate =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DeleteLaunchTemplateResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Information about the launch template.
deleteLaunchTemplateResponse_launchTemplate :: Lens.Lens' DeleteLaunchTemplateResponse (Prelude.Maybe LaunchTemplate)
deleteLaunchTemplateResponse_launchTemplate :: Lens' DeleteLaunchTemplateResponse (Maybe LaunchTemplate)
deleteLaunchTemplateResponse_launchTemplate = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLaunchTemplateResponse' {Maybe LaunchTemplate
launchTemplate :: Maybe LaunchTemplate
$sel:launchTemplate:DeleteLaunchTemplateResponse' :: DeleteLaunchTemplateResponse -> Maybe LaunchTemplate
launchTemplate} -> Maybe LaunchTemplate
launchTemplate) (\s :: DeleteLaunchTemplateResponse
s@DeleteLaunchTemplateResponse' {} Maybe LaunchTemplate
a -> DeleteLaunchTemplateResponse
s {$sel:launchTemplate:DeleteLaunchTemplateResponse' :: Maybe LaunchTemplate
launchTemplate = Maybe LaunchTemplate
a} :: DeleteLaunchTemplateResponse)

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

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