{-# 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.AccessAnalyzer.ApplyArchiveRule -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retroactively applies the archive rule to existing findings that meet -- the archive rule criteria. module Amazonka.AccessAnalyzer.ApplyArchiveRule ( -- * Creating a Request ApplyArchiveRule (..), newApplyArchiveRule, -- * Request Lenses applyArchiveRule_clientToken, applyArchiveRule_analyzerArn, applyArchiveRule_ruleName, -- * Destructuring the Response ApplyArchiveRuleResponse (..), newApplyArchiveRuleResponse, ) where import Amazonka.AccessAnalyzer.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 -- | Retroactively applies an archive rule. -- -- /See:/ 'newApplyArchiveRule' smart constructor. data ApplyArchiveRule = ApplyArchiveRule' { -- | A client token. clientToken :: Prelude.Maybe Prelude.Text, -- | The Amazon resource name (ARN) of the analyzer. analyzerArn :: Prelude.Text, -- | The name of the rule to apply. ruleName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ApplyArchiveRule' 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: -- -- 'clientToken', 'applyArchiveRule_clientToken' - A client token. -- -- 'analyzerArn', 'applyArchiveRule_analyzerArn' - The Amazon resource name (ARN) of the analyzer. -- -- 'ruleName', 'applyArchiveRule_ruleName' - The name of the rule to apply. newApplyArchiveRule :: -- | 'analyzerArn' Prelude.Text -> -- | 'ruleName' Prelude.Text -> ApplyArchiveRule newApplyArchiveRule pAnalyzerArn_ pRuleName_ = ApplyArchiveRule' { clientToken = Prelude.Nothing, analyzerArn = pAnalyzerArn_, ruleName = pRuleName_ } -- | A client token. applyArchiveRule_clientToken :: Lens.Lens' ApplyArchiveRule (Prelude.Maybe Prelude.Text) applyArchiveRule_clientToken = Lens.lens (\ApplyArchiveRule' {clientToken} -> clientToken) (\s@ApplyArchiveRule' {} a -> s {clientToken = a} :: ApplyArchiveRule) -- | The Amazon resource name (ARN) of the analyzer. applyArchiveRule_analyzerArn :: Lens.Lens' ApplyArchiveRule Prelude.Text applyArchiveRule_analyzerArn = Lens.lens (\ApplyArchiveRule' {analyzerArn} -> analyzerArn) (\s@ApplyArchiveRule' {} a -> s {analyzerArn = a} :: ApplyArchiveRule) -- | The name of the rule to apply. applyArchiveRule_ruleName :: Lens.Lens' ApplyArchiveRule Prelude.Text applyArchiveRule_ruleName = Lens.lens (\ApplyArchiveRule' {ruleName} -> ruleName) (\s@ApplyArchiveRule' {} a -> s {ruleName = a} :: ApplyArchiveRule) instance Core.AWSRequest ApplyArchiveRule where type AWSResponse ApplyArchiveRule = ApplyArchiveRuleResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveNull ApplyArchiveRuleResponse' instance Prelude.Hashable ApplyArchiveRule where hashWithSalt _salt ApplyArchiveRule' {..} = _salt `Prelude.hashWithSalt` clientToken `Prelude.hashWithSalt` analyzerArn `Prelude.hashWithSalt` ruleName instance Prelude.NFData ApplyArchiveRule where rnf ApplyArchiveRule' {..} = Prelude.rnf clientToken `Prelude.seq` Prelude.rnf analyzerArn `Prelude.seq` Prelude.rnf ruleName instance Data.ToHeaders ApplyArchiveRule where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ApplyArchiveRule where toJSON ApplyArchiveRule' {..} = Data.object ( Prelude.catMaybes [ ("clientToken" Data..=) Prelude.<$> clientToken, Prelude.Just ("analyzerArn" Data..= analyzerArn), Prelude.Just ("ruleName" Data..= ruleName) ] ) instance Data.ToPath ApplyArchiveRule where toPath = Prelude.const "/archive-rule" instance Data.ToQuery ApplyArchiveRule where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newApplyArchiveRuleResponse' smart constructor. data ApplyArchiveRuleResponse = ApplyArchiveRuleResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ApplyArchiveRuleResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newApplyArchiveRuleResponse :: ApplyArchiveRuleResponse newApplyArchiveRuleResponse = ApplyArchiveRuleResponse' instance Prelude.NFData ApplyArchiveRuleResponse where rnf _ = ()