{-# 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.GuardDuty.DeleteFilter -- 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 filter specified by the filter name. module Amazonka.GuardDuty.DeleteFilter ( -- * Creating a Request DeleteFilter (..), newDeleteFilter, -- * Request Lenses deleteFilter_detectorId, deleteFilter_filterName, -- * Destructuring the Response DeleteFilterResponse (..), newDeleteFilterResponse, -- * Response Lenses deleteFilterResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.GuardDuty.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteFilter' smart constructor. data DeleteFilter = DeleteFilter' { -- | The unique ID of the detector that the filter is associated with. detectorId :: Prelude.Text, -- | The name of the filter that you want to delete. filterName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteFilter' 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: -- -- 'detectorId', 'deleteFilter_detectorId' - The unique ID of the detector that the filter is associated with. -- -- 'filterName', 'deleteFilter_filterName' - The name of the filter that you want to delete. newDeleteFilter :: -- | 'detectorId' Prelude.Text -> -- | 'filterName' Prelude.Text -> DeleteFilter newDeleteFilter pDetectorId_ pFilterName_ = DeleteFilter' { detectorId = pDetectorId_, filterName = pFilterName_ } -- | The unique ID of the detector that the filter is associated with. deleteFilter_detectorId :: Lens.Lens' DeleteFilter Prelude.Text deleteFilter_detectorId = Lens.lens (\DeleteFilter' {detectorId} -> detectorId) (\s@DeleteFilter' {} a -> s {detectorId = a} :: DeleteFilter) -- | The name of the filter that you want to delete. deleteFilter_filterName :: Lens.Lens' DeleteFilter Prelude.Text deleteFilter_filterName = Lens.lens (\DeleteFilter' {filterName} -> filterName) (\s@DeleteFilter' {} a -> s {filterName = a} :: DeleteFilter) instance Core.AWSRequest DeleteFilter where type AWSResponse DeleteFilter = DeleteFilterResponse request overrides = Request.delete (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteFilterResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteFilter where hashWithSalt _salt DeleteFilter' {..} = _salt `Prelude.hashWithSalt` detectorId `Prelude.hashWithSalt` filterName instance Prelude.NFData DeleteFilter where rnf DeleteFilter' {..} = Prelude.rnf detectorId `Prelude.seq` Prelude.rnf filterName instance Data.ToHeaders DeleteFilter where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath DeleteFilter where toPath DeleteFilter' {..} = Prelude.mconcat [ "/detector/", Data.toBS detectorId, "/filter/", Data.toBS filterName ] instance Data.ToQuery DeleteFilter where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteFilterResponse' smart constructor. data DeleteFilterResponse = DeleteFilterResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteFilterResponse' 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: -- -- 'httpStatus', 'deleteFilterResponse_httpStatus' - The response's http status code. newDeleteFilterResponse :: -- | 'httpStatus' Prelude.Int -> DeleteFilterResponse newDeleteFilterResponse pHttpStatus_ = DeleteFilterResponse' {httpStatus = pHttpStatus_} -- | The response's http status code. deleteFilterResponse_httpStatus :: Lens.Lens' DeleteFilterResponse Prelude.Int deleteFilterResponse_httpStatus = Lens.lens (\DeleteFilterResponse' {httpStatus} -> httpStatus) (\s@DeleteFilterResponse' {} a -> s {httpStatus = a} :: DeleteFilterResponse) instance Prelude.NFData DeleteFilterResponse where rnf DeleteFilterResponse' {..} = Prelude.rnf httpStatus