{-# 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.DAX.DeleteSubnetGroup -- 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 subnet group. -- -- You cannot delete a subnet group if it is associated with any DAX -- clusters. module Amazonka.DAX.DeleteSubnetGroup ( -- * Creating a Request DeleteSubnetGroup (..), newDeleteSubnetGroup, -- * Request Lenses deleteSubnetGroup_subnetGroupName, -- * Destructuring the Response DeleteSubnetGroupResponse (..), newDeleteSubnetGroupResponse, -- * Response Lenses deleteSubnetGroupResponse_deletionMessage, deleteSubnetGroupResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import Amazonka.DAX.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:/ 'newDeleteSubnetGroup' smart constructor. data DeleteSubnetGroup = DeleteSubnetGroup' { -- | The name of the subnet group to delete. subnetGroupName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSubnetGroup' 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: -- -- 'subnetGroupName', 'deleteSubnetGroup_subnetGroupName' - The name of the subnet group to delete. newDeleteSubnetGroup :: -- | 'subnetGroupName' Prelude.Text -> DeleteSubnetGroup newDeleteSubnetGroup pSubnetGroupName_ = DeleteSubnetGroup' { subnetGroupName = pSubnetGroupName_ } -- | The name of the subnet group to delete. deleteSubnetGroup_subnetGroupName :: Lens.Lens' DeleteSubnetGroup Prelude.Text deleteSubnetGroup_subnetGroupName = Lens.lens (\DeleteSubnetGroup' {subnetGroupName} -> subnetGroupName) (\s@DeleteSubnetGroup' {} a -> s {subnetGroupName = a} :: DeleteSubnetGroup) instance Core.AWSRequest DeleteSubnetGroup where type AWSResponse DeleteSubnetGroup = DeleteSubnetGroupResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteSubnetGroupResponse' Prelude.<$> (x Data..?> "DeletionMessage") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteSubnetGroup where hashWithSalt _salt DeleteSubnetGroup' {..} = _salt `Prelude.hashWithSalt` subnetGroupName instance Prelude.NFData DeleteSubnetGroup where rnf DeleteSubnetGroup' {..} = Prelude.rnf subnetGroupName instance Data.ToHeaders DeleteSubnetGroup where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonDAXV3.DeleteSubnetGroup" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteSubnetGroup where toJSON DeleteSubnetGroup' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("SubnetGroupName" Data..= subnetGroupName) ] ) instance Data.ToPath DeleteSubnetGroup where toPath = Prelude.const "/" instance Data.ToQuery DeleteSubnetGroup where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteSubnetGroupResponse' smart constructor. data DeleteSubnetGroupResponse = DeleteSubnetGroupResponse' { -- | A user-specified message for this action (i.e., a reason for deleting -- the subnet group). deletionMessage :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteSubnetGroupResponse' 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: -- -- 'deletionMessage', 'deleteSubnetGroupResponse_deletionMessage' - A user-specified message for this action (i.e., a reason for deleting -- the subnet group). -- -- 'httpStatus', 'deleteSubnetGroupResponse_httpStatus' - The response's http status code. newDeleteSubnetGroupResponse :: -- | 'httpStatus' Prelude.Int -> DeleteSubnetGroupResponse newDeleteSubnetGroupResponse pHttpStatus_ = DeleteSubnetGroupResponse' { deletionMessage = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A user-specified message for this action (i.e., a reason for deleting -- the subnet group). deleteSubnetGroupResponse_deletionMessage :: Lens.Lens' DeleteSubnetGroupResponse (Prelude.Maybe Prelude.Text) deleteSubnetGroupResponse_deletionMessage = Lens.lens (\DeleteSubnetGroupResponse' {deletionMessage} -> deletionMessage) (\s@DeleteSubnetGroupResponse' {} a -> s {deletionMessage = a} :: DeleteSubnetGroupResponse) -- | The response's http status code. deleteSubnetGroupResponse_httpStatus :: Lens.Lens' DeleteSubnetGroupResponse Prelude.Int deleteSubnetGroupResponse_httpStatus = Lens.lens (\DeleteSubnetGroupResponse' {httpStatus} -> httpStatus) (\s@DeleteSubnetGroupResponse' {} a -> s {httpStatus = a} :: DeleteSubnetGroupResponse) instance Prelude.NFData DeleteSubnetGroupResponse where rnf DeleteSubnetGroupResponse' {..} = Prelude.rnf deletionMessage `Prelude.seq` Prelude.rnf httpStatus