{-# 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.CloudWatchLogs.DeleteQueryDefinition -- 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 saved CloudWatch Logs Insights query definition. A query -- definition contains details about a saved CloudWatch Logs Insights -- query. -- -- Each @DeleteQueryDefinition@ operation can delete one query definition. -- -- You must have the @logs:DeleteQueryDefinition@ permission to be able to -- perform this operation. module Amazonka.CloudWatchLogs.DeleteQueryDefinition ( -- * Creating a Request DeleteQueryDefinition (..), newDeleteQueryDefinition, -- * Request Lenses deleteQueryDefinition_queryDefinitionId, -- * Destructuring the Response DeleteQueryDefinitionResponse (..), newDeleteQueryDefinitionResponse, -- * Response Lenses deleteQueryDefinitionResponse_success, deleteQueryDefinitionResponse_httpStatus, ) where import Amazonka.CloudWatchLogs.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:/ 'newDeleteQueryDefinition' smart constructor. data DeleteQueryDefinition = DeleteQueryDefinition' { -- | The ID of the query definition that you want to delete. You can use -- -- to retrieve the IDs of your saved query definitions. queryDefinitionId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteQueryDefinition' 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: -- -- 'queryDefinitionId', 'deleteQueryDefinition_queryDefinitionId' - The ID of the query definition that you want to delete. You can use -- -- to retrieve the IDs of your saved query definitions. newDeleteQueryDefinition :: -- | 'queryDefinitionId' Prelude.Text -> DeleteQueryDefinition newDeleteQueryDefinition pQueryDefinitionId_ = DeleteQueryDefinition' { queryDefinitionId = pQueryDefinitionId_ } -- | The ID of the query definition that you want to delete. You can use -- -- to retrieve the IDs of your saved query definitions. deleteQueryDefinition_queryDefinitionId :: Lens.Lens' DeleteQueryDefinition Prelude.Text deleteQueryDefinition_queryDefinitionId = Lens.lens (\DeleteQueryDefinition' {queryDefinitionId} -> queryDefinitionId) (\s@DeleteQueryDefinition' {} a -> s {queryDefinitionId = a} :: DeleteQueryDefinition) instance Core.AWSRequest DeleteQueryDefinition where type AWSResponse DeleteQueryDefinition = DeleteQueryDefinitionResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteQueryDefinitionResponse' Prelude.<$> (x Data..?> "success") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteQueryDefinition where hashWithSalt _salt DeleteQueryDefinition' {..} = _salt `Prelude.hashWithSalt` queryDefinitionId instance Prelude.NFData DeleteQueryDefinition where rnf DeleteQueryDefinition' {..} = Prelude.rnf queryDefinitionId instance Data.ToHeaders DeleteQueryDefinition where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Logs_20140328.DeleteQueryDefinition" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteQueryDefinition where toJSON DeleteQueryDefinition' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("queryDefinitionId" Data..= queryDefinitionId) ] ) instance Data.ToPath DeleteQueryDefinition where toPath = Prelude.const "/" instance Data.ToQuery DeleteQueryDefinition where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteQueryDefinitionResponse' smart constructor. data DeleteQueryDefinitionResponse = DeleteQueryDefinitionResponse' { -- | A value of TRUE indicates that the operation succeeded. FALSE indicates -- that the operation failed. success :: Prelude.Maybe Prelude.Bool, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteQueryDefinitionResponse' 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: -- -- 'success', 'deleteQueryDefinitionResponse_success' - A value of TRUE indicates that the operation succeeded. FALSE indicates -- that the operation failed. -- -- 'httpStatus', 'deleteQueryDefinitionResponse_httpStatus' - The response's http status code. newDeleteQueryDefinitionResponse :: -- | 'httpStatus' Prelude.Int -> DeleteQueryDefinitionResponse newDeleteQueryDefinitionResponse pHttpStatus_ = DeleteQueryDefinitionResponse' { success = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A value of TRUE indicates that the operation succeeded. FALSE indicates -- that the operation failed. deleteQueryDefinitionResponse_success :: Lens.Lens' DeleteQueryDefinitionResponse (Prelude.Maybe Prelude.Bool) deleteQueryDefinitionResponse_success = Lens.lens (\DeleteQueryDefinitionResponse' {success} -> success) (\s@DeleteQueryDefinitionResponse' {} a -> s {success = a} :: DeleteQueryDefinitionResponse) -- | The response's http status code. deleteQueryDefinitionResponse_httpStatus :: Lens.Lens' DeleteQueryDefinitionResponse Prelude.Int deleteQueryDefinitionResponse_httpStatus = Lens.lens (\DeleteQueryDefinitionResponse' {httpStatus} -> httpStatus) (\s@DeleteQueryDefinitionResponse' {} a -> s {httpStatus = a} :: DeleteQueryDefinitionResponse) instance Prelude.NFData DeleteQueryDefinitionResponse where rnf DeleteQueryDefinitionResponse' {..} = Prelude.rnf success `Prelude.seq` Prelude.rnf httpStatus