{-# 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.Route53Resolver.UpdateResolverRule -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates settings for a specified Resolver rule. @ResolverRuleId@ is -- required, and all other parameters are optional. If you don\'t specify a -- parameter, it retains its current value. module Amazonka.Route53Resolver.UpdateResolverRule ( -- * Creating a Request UpdateResolverRule (..), newUpdateResolverRule, -- * Request Lenses updateResolverRule_resolverRuleId, updateResolverRule_config, -- * Destructuring the Response UpdateResolverRuleResponse (..), newUpdateResolverRuleResponse, -- * Response Lenses updateResolverRuleResponse_resolverRule, updateResolverRuleResponse_httpStatus, ) 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.Route53Resolver.Types -- | /See:/ 'newUpdateResolverRule' smart constructor. data UpdateResolverRule = UpdateResolverRule' { -- | The ID of the Resolver rule that you want to update. resolverRuleId :: Prelude.Text, -- | The new settings for the Resolver rule. config :: ResolverRuleConfig } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateResolverRule' 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: -- -- 'resolverRuleId', 'updateResolverRule_resolverRuleId' - The ID of the Resolver rule that you want to update. -- -- 'config', 'updateResolverRule_config' - The new settings for the Resolver rule. newUpdateResolverRule :: -- | 'resolverRuleId' Prelude.Text -> -- | 'config' ResolverRuleConfig -> UpdateResolverRule newUpdateResolverRule pResolverRuleId_ pConfig_ = UpdateResolverRule' { resolverRuleId = pResolverRuleId_, config = pConfig_ } -- | The ID of the Resolver rule that you want to update. updateResolverRule_resolverRuleId :: Lens.Lens' UpdateResolverRule Prelude.Text updateResolverRule_resolverRuleId = Lens.lens (\UpdateResolverRule' {resolverRuleId} -> resolverRuleId) (\s@UpdateResolverRule' {} a -> s {resolverRuleId = a} :: UpdateResolverRule) -- | The new settings for the Resolver rule. updateResolverRule_config :: Lens.Lens' UpdateResolverRule ResolverRuleConfig updateResolverRule_config = Lens.lens (\UpdateResolverRule' {config} -> config) (\s@UpdateResolverRule' {} a -> s {config = a} :: UpdateResolverRule) instance Core.AWSRequest UpdateResolverRule where type AWSResponse UpdateResolverRule = UpdateResolverRuleResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateResolverRuleResponse' Prelude.<$> (x Data..?> "ResolverRule") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateResolverRule where hashWithSalt _salt UpdateResolverRule' {..} = _salt `Prelude.hashWithSalt` resolverRuleId `Prelude.hashWithSalt` config instance Prelude.NFData UpdateResolverRule where rnf UpdateResolverRule' {..} = Prelude.rnf resolverRuleId `Prelude.seq` Prelude.rnf config instance Data.ToHeaders UpdateResolverRule where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "Route53Resolver.UpdateResolverRule" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateResolverRule where toJSON UpdateResolverRule' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("ResolverRuleId" Data..= resolverRuleId), Prelude.Just ("Config" Data..= config) ] ) instance Data.ToPath UpdateResolverRule where toPath = Prelude.const "/" instance Data.ToQuery UpdateResolverRule where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateResolverRuleResponse' smart constructor. data UpdateResolverRuleResponse = UpdateResolverRuleResponse' { -- | The response to an @UpdateResolverRule@ request. resolverRule :: Prelude.Maybe ResolverRule, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateResolverRuleResponse' 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: -- -- 'resolverRule', 'updateResolverRuleResponse_resolverRule' - The response to an @UpdateResolverRule@ request. -- -- 'httpStatus', 'updateResolverRuleResponse_httpStatus' - The response's http status code. newUpdateResolverRuleResponse :: -- | 'httpStatus' Prelude.Int -> UpdateResolverRuleResponse newUpdateResolverRuleResponse pHttpStatus_ = UpdateResolverRuleResponse' { resolverRule = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The response to an @UpdateResolverRule@ request. updateResolverRuleResponse_resolverRule :: Lens.Lens' UpdateResolverRuleResponse (Prelude.Maybe ResolverRule) updateResolverRuleResponse_resolverRule = Lens.lens (\UpdateResolverRuleResponse' {resolverRule} -> resolverRule) (\s@UpdateResolverRuleResponse' {} a -> s {resolverRule = a} :: UpdateResolverRuleResponse) -- | The response's http status code. updateResolverRuleResponse_httpStatus :: Lens.Lens' UpdateResolverRuleResponse Prelude.Int updateResolverRuleResponse_httpStatus = Lens.lens (\UpdateResolverRuleResponse' {httpStatus} -> httpStatus) (\s@UpdateResolverRuleResponse' {} a -> s {httpStatus = a} :: UpdateResolverRuleResponse) instance Prelude.NFData UpdateResolverRuleResponse where rnf UpdateResolverRuleResponse' {..} = Prelude.rnf resolverRule `Prelude.seq` Prelude.rnf httpStatus