{-# 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.CodeArtifact.DeleteDomain
-- 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 domain. You cannot delete a domain that contains repositories.
-- If you want to delete a domain with repositories, first delete its
-- repositories.
module Amazonka.CodeArtifact.DeleteDomain
  ( -- * Creating a Request
    DeleteDomain (..),
    newDeleteDomain,

    -- * Request Lenses
    deleteDomain_domainOwner,
    deleteDomain_domain,

    -- * Destructuring the Response
    DeleteDomainResponse (..),
    newDeleteDomainResponse,

    -- * Response Lenses
    deleteDomainResponse_domain,
    deleteDomainResponse_httpStatus,
  )
where

import Amazonka.CodeArtifact.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
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:/ 'newDeleteDomain' smart constructor.
data DeleteDomain = DeleteDomain'
  { -- | The 12-digit account number of the Amazon Web Services account that owns
    -- the domain. It does not include dashes or spaces.
    DeleteDomain -> Maybe Text
domainOwner :: Prelude.Maybe Prelude.Text,
    -- | The name of the domain to delete.
    DeleteDomain -> Text
domain :: Prelude.Text
  }
  deriving (DeleteDomain -> DeleteDomain -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDomain -> DeleteDomain -> Bool
$c/= :: DeleteDomain -> DeleteDomain -> Bool
== :: DeleteDomain -> DeleteDomain -> Bool
$c== :: DeleteDomain -> DeleteDomain -> Bool
Prelude.Eq, ReadPrec [DeleteDomain]
ReadPrec DeleteDomain
Int -> ReadS DeleteDomain
ReadS [DeleteDomain]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDomain]
$creadListPrec :: ReadPrec [DeleteDomain]
readPrec :: ReadPrec DeleteDomain
$creadPrec :: ReadPrec DeleteDomain
readList :: ReadS [DeleteDomain]
$creadList :: ReadS [DeleteDomain]
readsPrec :: Int -> ReadS DeleteDomain
$creadsPrec :: Int -> ReadS DeleteDomain
Prelude.Read, Int -> DeleteDomain -> ShowS
[DeleteDomain] -> ShowS
DeleteDomain -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDomain] -> ShowS
$cshowList :: [DeleteDomain] -> ShowS
show :: DeleteDomain -> String
$cshow :: DeleteDomain -> String
showsPrec :: Int -> DeleteDomain -> ShowS
$cshowsPrec :: Int -> DeleteDomain -> ShowS
Prelude.Show, forall x. Rep DeleteDomain x -> DeleteDomain
forall x. DeleteDomain -> Rep DeleteDomain x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDomain x -> DeleteDomain
$cfrom :: forall x. DeleteDomain -> Rep DeleteDomain x
Prelude.Generic)

-- |
-- Create a value of 'DeleteDomain' 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:
--
-- 'domainOwner', 'deleteDomain_domainOwner' - The 12-digit account number of the Amazon Web Services account that owns
-- the domain. It does not include dashes or spaces.
--
-- 'domain', 'deleteDomain_domain' - The name of the domain to delete.
newDeleteDomain ::
  -- | 'domain'
  Prelude.Text ->
  DeleteDomain
newDeleteDomain :: Text -> DeleteDomain
newDeleteDomain Text
pDomain_ =
  DeleteDomain'
    { $sel:domainOwner:DeleteDomain' :: Maybe Text
domainOwner = forall a. Maybe a
Prelude.Nothing,
      $sel:domain:DeleteDomain' :: Text
domain = Text
pDomain_
    }

-- | The 12-digit account number of the Amazon Web Services account that owns
-- the domain. It does not include dashes or spaces.
deleteDomain_domainOwner :: Lens.Lens' DeleteDomain (Prelude.Maybe Prelude.Text)
deleteDomain_domainOwner :: Lens' DeleteDomain (Maybe Text)
deleteDomain_domainOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomain' {Maybe Text
domainOwner :: Maybe Text
$sel:domainOwner:DeleteDomain' :: DeleteDomain -> Maybe Text
domainOwner} -> Maybe Text
domainOwner) (\s :: DeleteDomain
s@DeleteDomain' {} Maybe Text
a -> DeleteDomain
s {$sel:domainOwner:DeleteDomain' :: Maybe Text
domainOwner = Maybe Text
a} :: DeleteDomain)

-- | The name of the domain to delete.
deleteDomain_domain :: Lens.Lens' DeleteDomain Prelude.Text
deleteDomain_domain :: Lens' DeleteDomain Text
deleteDomain_domain = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomain' {Text
domain :: Text
$sel:domain:DeleteDomain' :: DeleteDomain -> Text
domain} -> Text
domain) (\s :: DeleteDomain
s@DeleteDomain' {} Text
a -> DeleteDomain
s {$sel:domain:DeleteDomain' :: Text
domain = Text
a} :: DeleteDomain)

instance Core.AWSRequest DeleteDomain where
  type AWSResponse DeleteDomain = DeleteDomainResponse
  request :: (Service -> Service) -> DeleteDomain -> Request DeleteDomain
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.delete (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeleteDomain
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteDomain)))
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 DomainDescription -> Int -> DeleteDomainResponse
DeleteDomainResponse'
            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
"domain")
            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 DeleteDomain where
  hashWithSalt :: Int -> DeleteDomain -> Int
hashWithSalt Int
_salt DeleteDomain' {Maybe Text
Text
domain :: Text
domainOwner :: Maybe Text
$sel:domain:DeleteDomain' :: DeleteDomain -> Text
$sel:domainOwner:DeleteDomain' :: DeleteDomain -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
domainOwner
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
domain

instance Prelude.NFData DeleteDomain where
  rnf :: DeleteDomain -> ()
rnf DeleteDomain' {Maybe Text
Text
domain :: Text
domainOwner :: Maybe Text
$sel:domain:DeleteDomain' :: DeleteDomain -> Text
$sel:domainOwner:DeleteDomain' :: DeleteDomain -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
domainOwner
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
domain

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

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

instance Data.ToQuery DeleteDomain where
  toQuery :: DeleteDomain -> QueryString
toQuery DeleteDomain' {Maybe Text
Text
domain :: Text
domainOwner :: Maybe Text
$sel:domain:DeleteDomain' :: DeleteDomain -> Text
$sel:domainOwner:DeleteDomain' :: DeleteDomain -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"domain-owner" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
domainOwner,
        ByteString
"domain" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
domain
      ]

-- | /See:/ 'newDeleteDomainResponse' smart constructor.
data DeleteDomainResponse = DeleteDomainResponse'
  { -- | Contains information about the deleted domain after processing the
    -- request.
    DeleteDomainResponse -> Maybe DomainDescription
domain :: Prelude.Maybe DomainDescription,
    -- | The response's http status code.
    DeleteDomainResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteDomainResponse -> DeleteDomainResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
$c/= :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
== :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
$c== :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
Prelude.Eq, ReadPrec [DeleteDomainResponse]
ReadPrec DeleteDomainResponse
Int -> ReadS DeleteDomainResponse
ReadS [DeleteDomainResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDomainResponse]
$creadListPrec :: ReadPrec [DeleteDomainResponse]
readPrec :: ReadPrec DeleteDomainResponse
$creadPrec :: ReadPrec DeleteDomainResponse
readList :: ReadS [DeleteDomainResponse]
$creadList :: ReadS [DeleteDomainResponse]
readsPrec :: Int -> ReadS DeleteDomainResponse
$creadsPrec :: Int -> ReadS DeleteDomainResponse
Prelude.Read, Int -> DeleteDomainResponse -> ShowS
[DeleteDomainResponse] -> ShowS
DeleteDomainResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDomainResponse] -> ShowS
$cshowList :: [DeleteDomainResponse] -> ShowS
show :: DeleteDomainResponse -> String
$cshow :: DeleteDomainResponse -> String
showsPrec :: Int -> DeleteDomainResponse -> ShowS
$cshowsPrec :: Int -> DeleteDomainResponse -> ShowS
Prelude.Show, forall x. Rep DeleteDomainResponse x -> DeleteDomainResponse
forall x. DeleteDomainResponse -> Rep DeleteDomainResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDomainResponse x -> DeleteDomainResponse
$cfrom :: forall x. DeleteDomainResponse -> Rep DeleteDomainResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteDomainResponse' 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:
--
-- 'domain', 'deleteDomainResponse_domain' - Contains information about the deleted domain after processing the
-- request.
--
-- 'httpStatus', 'deleteDomainResponse_httpStatus' - The response's http status code.
newDeleteDomainResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteDomainResponse
newDeleteDomainResponse :: Int -> DeleteDomainResponse
newDeleteDomainResponse Int
pHttpStatus_ =
  DeleteDomainResponse'
    { $sel:domain:DeleteDomainResponse' :: Maybe DomainDescription
domain = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DeleteDomainResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Contains information about the deleted domain after processing the
-- request.
deleteDomainResponse_domain :: Lens.Lens' DeleteDomainResponse (Prelude.Maybe DomainDescription)
deleteDomainResponse_domain :: Lens' DeleteDomainResponse (Maybe DomainDescription)
deleteDomainResponse_domain = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomainResponse' {Maybe DomainDescription
domain :: Maybe DomainDescription
$sel:domain:DeleteDomainResponse' :: DeleteDomainResponse -> Maybe DomainDescription
domain} -> Maybe DomainDescription
domain) (\s :: DeleteDomainResponse
s@DeleteDomainResponse' {} Maybe DomainDescription
a -> DeleteDomainResponse
s {$sel:domain:DeleteDomainResponse' :: Maybe DomainDescription
domain = Maybe DomainDescription
a} :: DeleteDomainResponse)

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

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