{-# 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.Support.RefreshTrustedAdvisorCheck -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Refreshes the Trusted Advisor check that you specify using the check ID. -- You can get the check IDs by calling the DescribeTrustedAdvisorChecks -- operation. -- -- Some checks are refreshed automatically. If you call the -- @RefreshTrustedAdvisorCheck@ operation to refresh them, you might see -- the @InvalidParameterValue@ error. -- -- The response contains a TrustedAdvisorCheckRefreshStatus object. -- -- - You must have a Business, Enterprise On-Ramp, or Enterprise Support -- plan to use the Amazon Web Services Support API. -- -- - If you call the Amazon Web Services Support API from an account that -- doesn\'t have a Business, Enterprise On-Ramp, or Enterprise Support -- plan, the @SubscriptionRequiredException@ error message appears. For -- information about changing your support plan, see -- . -- -- To call the Trusted Advisor operations in the Amazon Web Services -- Support API, you must use the US East (N. Virginia) endpoint. Currently, -- the US West (Oregon) and Europe (Ireland) endpoints don\'t support the -- Trusted Advisor operations. For more information, see -- -- in the /Amazon Web Services Support User Guide/. module Amazonka.Support.RefreshTrustedAdvisorCheck ( -- * Creating a Request RefreshTrustedAdvisorCheck (..), newRefreshTrustedAdvisorCheck, -- * Request Lenses refreshTrustedAdvisorCheck_checkId, -- * Destructuring the Response RefreshTrustedAdvisorCheckResponse (..), newRefreshTrustedAdvisorCheckResponse, -- * Response Lenses refreshTrustedAdvisorCheckResponse_httpStatus, refreshTrustedAdvisorCheckResponse_status, ) where 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 import Amazonka.Support.Types -- | -- -- /See:/ 'newRefreshTrustedAdvisorCheck' smart constructor. data RefreshTrustedAdvisorCheck = RefreshTrustedAdvisorCheck' { -- | The unique identifier for the Trusted Advisor check to refresh. -- -- Specifying the check ID of a check that is automatically refreshed -- causes an @InvalidParameterValue@ error. checkId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RefreshTrustedAdvisorCheck' 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: -- -- 'checkId', 'refreshTrustedAdvisorCheck_checkId' - The unique identifier for the Trusted Advisor check to refresh. -- -- Specifying the check ID of a check that is automatically refreshed -- causes an @InvalidParameterValue@ error. newRefreshTrustedAdvisorCheck :: -- | 'checkId' Prelude.Text -> RefreshTrustedAdvisorCheck newRefreshTrustedAdvisorCheck pCheckId_ = RefreshTrustedAdvisorCheck' {checkId = pCheckId_} -- | The unique identifier for the Trusted Advisor check to refresh. -- -- Specifying the check ID of a check that is automatically refreshed -- causes an @InvalidParameterValue@ error. refreshTrustedAdvisorCheck_checkId :: Lens.Lens' RefreshTrustedAdvisorCheck Prelude.Text refreshTrustedAdvisorCheck_checkId = Lens.lens (\RefreshTrustedAdvisorCheck' {checkId} -> checkId) (\s@RefreshTrustedAdvisorCheck' {} a -> s {checkId = a} :: RefreshTrustedAdvisorCheck) instance Core.AWSRequest RefreshTrustedAdvisorCheck where type AWSResponse RefreshTrustedAdvisorCheck = RefreshTrustedAdvisorCheckResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> RefreshTrustedAdvisorCheckResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "status") ) instance Prelude.Hashable RefreshTrustedAdvisorCheck where hashWithSalt _salt RefreshTrustedAdvisorCheck' {..} = _salt `Prelude.hashWithSalt` checkId instance Prelude.NFData RefreshTrustedAdvisorCheck where rnf RefreshTrustedAdvisorCheck' {..} = Prelude.rnf checkId instance Data.ToHeaders RefreshTrustedAdvisorCheck where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSSupport_20130415.RefreshTrustedAdvisorCheck" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON RefreshTrustedAdvisorCheck where toJSON RefreshTrustedAdvisorCheck' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("checkId" Data..= checkId)] ) instance Data.ToPath RefreshTrustedAdvisorCheck where toPath = Prelude.const "/" instance Data.ToQuery RefreshTrustedAdvisorCheck where toQuery = Prelude.const Prelude.mempty -- | The current refresh status of a Trusted Advisor check. -- -- /See:/ 'newRefreshTrustedAdvisorCheckResponse' smart constructor. data RefreshTrustedAdvisorCheckResponse = RefreshTrustedAdvisorCheckResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | The current refresh status for a check, including the amount of time -- until the check is eligible for refresh. status :: TrustedAdvisorCheckRefreshStatus } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RefreshTrustedAdvisorCheckResponse' 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', 'refreshTrustedAdvisorCheckResponse_httpStatus' - The response's http status code. -- -- 'status', 'refreshTrustedAdvisorCheckResponse_status' - The current refresh status for a check, including the amount of time -- until the check is eligible for refresh. newRefreshTrustedAdvisorCheckResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'status' TrustedAdvisorCheckRefreshStatus -> RefreshTrustedAdvisorCheckResponse newRefreshTrustedAdvisorCheckResponse pHttpStatus_ pStatus_ = RefreshTrustedAdvisorCheckResponse' { httpStatus = pHttpStatus_, status = pStatus_ } -- | The response's http status code. refreshTrustedAdvisorCheckResponse_httpStatus :: Lens.Lens' RefreshTrustedAdvisorCheckResponse Prelude.Int refreshTrustedAdvisorCheckResponse_httpStatus = Lens.lens (\RefreshTrustedAdvisorCheckResponse' {httpStatus} -> httpStatus) (\s@RefreshTrustedAdvisorCheckResponse' {} a -> s {httpStatus = a} :: RefreshTrustedAdvisorCheckResponse) -- | The current refresh status for a check, including the amount of time -- until the check is eligible for refresh. refreshTrustedAdvisorCheckResponse_status :: Lens.Lens' RefreshTrustedAdvisorCheckResponse TrustedAdvisorCheckRefreshStatus refreshTrustedAdvisorCheckResponse_status = Lens.lens (\RefreshTrustedAdvisorCheckResponse' {status} -> status) (\s@RefreshTrustedAdvisorCheckResponse' {} a -> s {status = a} :: RefreshTrustedAdvisorCheckResponse) instance Prelude.NFData RefreshTrustedAdvisorCheckResponse where rnf RefreshTrustedAdvisorCheckResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf status