{-# 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.Lightsail.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 the specified domain recordset and all of its domain records. -- -- The @delete domain@ operation supports tag-based access control via -- resource tags applied to the resource identified by @domain name@. For -- more information, see the -- . module Amazonka.Lightsail.DeleteDomain ( -- * Creating a Request DeleteDomain (..), newDeleteDomain, -- * Request Lenses deleteDomain_domainName, -- * Destructuring the Response DeleteDomainResponse (..), newDeleteDomainResponse, -- * Response Lenses deleteDomainResponse_operation, deleteDomainResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Lightsail.Types 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 specific domain name to delete. domainName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteDomain' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'domainName', 'deleteDomain_domainName' - The specific domain name to delete. newDeleteDomain :: -- | 'domainName' Prelude.Text -> DeleteDomain newDeleteDomain pDomainName_ = DeleteDomain' {domainName = pDomainName_} -- | The specific domain name to delete. deleteDomain_domainName :: Lens.Lens' DeleteDomain Prelude.Text deleteDomain_domainName = Lens.lens (\DeleteDomain' {domainName} -> domainName) (\s@DeleteDomain' {} a -> s {domainName = a} :: DeleteDomain) instance Core.AWSRequest DeleteDomain where type AWSResponse DeleteDomain = DeleteDomainResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteDomainResponse' Prelude.<$> (x Data..?> "operation") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteDomain where hashWithSalt _salt DeleteDomain' {..} = _salt `Prelude.hashWithSalt` domainName instance Prelude.NFData DeleteDomain where rnf DeleteDomain' {..} = Prelude.rnf domainName instance Data.ToHeaders DeleteDomain where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Lightsail_20161128.DeleteDomain" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteDomain where toJSON DeleteDomain' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("domainName" Data..= domainName)] ) instance Data.ToPath DeleteDomain where toPath = Prelude.const "/" instance Data.ToQuery DeleteDomain where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteDomainResponse' smart constructor. data DeleteDomainResponse = DeleteDomainResponse' { -- | An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. operation :: Prelude.Maybe Operation, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteDomainResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'operation', 'deleteDomainResponse_operation' - An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. -- -- 'httpStatus', 'deleteDomainResponse_httpStatus' - The response's http status code. newDeleteDomainResponse :: -- | 'httpStatus' Prelude.Int -> DeleteDomainResponse newDeleteDomainResponse pHttpStatus_ = DeleteDomainResponse' { operation = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | An array of objects that describe the result of the action, such as the -- status of the request, the timestamp of the request, and the resources -- affected by the request. deleteDomainResponse_operation :: Lens.Lens' DeleteDomainResponse (Prelude.Maybe Operation) deleteDomainResponse_operation = Lens.lens (\DeleteDomainResponse' {operation} -> operation) (\s@DeleteDomainResponse' {} a -> s {operation = a} :: DeleteDomainResponse) -- | The response's http status code. deleteDomainResponse_httpStatus :: Lens.Lens' DeleteDomainResponse Prelude.Int deleteDomainResponse_httpStatus = Lens.lens (\DeleteDomainResponse' {httpStatus} -> httpStatus) (\s@DeleteDomainResponse' {} a -> s {httpStatus = a} :: DeleteDomainResponse) instance Prelude.NFData DeleteDomainResponse where rnf DeleteDomainResponse' {..} = Prelude.rnf operation `Prelude.seq` Prelude.rnf httpStatus