{-# 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.FMS.PutPolicy -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates an Firewall Manager policy. -- -- Firewall Manager provides the following types of policies: -- -- - An WAF policy (type WAFV2), which defines rule groups to run first -- in the corresponding WAF web ACL and rule groups to run last in the -- web ACL. -- -- - An WAF Classic policy (type WAF), which defines a rule group. -- -- - A Shield Advanced policy, which applies Shield Advanced protection -- to specified accounts and resources. -- -- - A security group policy, which manages VPC security groups across -- your Amazon Web Services organization. -- -- - An Network Firewall policy, which provides firewall rules to filter -- network traffic in specified Amazon VPCs. -- -- - A DNS Firewall policy, which provides RouteĀ 53 Resolver DNS Firewall -- rules to filter DNS queries for specified VPCs. -- -- Each policy is specific to one of the types. If you want to enforce more -- than one policy type across accounts, create multiple policies. You can -- create multiple policies for each type. -- -- You must be subscribed to Shield Advanced to create a Shield Advanced -- policy. For more information about subscribing to Shield Advanced, see -- . module Amazonka.FMS.PutPolicy ( -- * Creating a Request PutPolicy (..), newPutPolicy, -- * Request Lenses putPolicy_tagList, putPolicy_policy, -- * Destructuring the Response PutPolicyResponse (..), newPutPolicyResponse, -- * Response Lenses putPolicyResponse_policy, putPolicyResponse_policyArn, putPolicyResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.FMS.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newPutPolicy' smart constructor. data PutPolicy = PutPolicy' { -- | The tags to add to the Amazon Web Services resource. tagList :: Prelude.Maybe [Tag], -- | The details of the Firewall Manager policy to be created. policy :: Policy } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'PutPolicy' 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: -- -- 'tagList', 'putPolicy_tagList' - The tags to add to the Amazon Web Services resource. -- -- 'policy', 'putPolicy_policy' - The details of the Firewall Manager policy to be created. newPutPolicy :: -- | 'policy' Policy -> PutPolicy newPutPolicy pPolicy_ = PutPolicy' { tagList = Prelude.Nothing, policy = pPolicy_ } -- | The tags to add to the Amazon Web Services resource. putPolicy_tagList :: Lens.Lens' PutPolicy (Prelude.Maybe [Tag]) putPolicy_tagList = Lens.lens (\PutPolicy' {tagList} -> tagList) (\s@PutPolicy' {} a -> s {tagList = a} :: PutPolicy) Prelude.. Lens.mapping Lens.coerced -- | The details of the Firewall Manager policy to be created. putPolicy_policy :: Lens.Lens' PutPolicy Policy putPolicy_policy = Lens.lens (\PutPolicy' {policy} -> policy) (\s@PutPolicy' {} a -> s {policy = a} :: PutPolicy) instance Core.AWSRequest PutPolicy where type AWSResponse PutPolicy = PutPolicyResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> PutPolicyResponse' Prelude.<$> (x Data..?> "Policy") Prelude.<*> (x Data..?> "PolicyArn") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable PutPolicy where hashWithSalt _salt PutPolicy' {..} = _salt `Prelude.hashWithSalt` tagList `Prelude.hashWithSalt` policy instance Prelude.NFData PutPolicy where rnf PutPolicy' {..} = Prelude.rnf tagList `Prelude.seq` Prelude.rnf policy instance Data.ToHeaders PutPolicy where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("AWSFMS_20180101.PutPolicy" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON PutPolicy where toJSON PutPolicy' {..} = Data.object ( Prelude.catMaybes [ ("TagList" Data..=) Prelude.<$> tagList, Prelude.Just ("Policy" Data..= policy) ] ) instance Data.ToPath PutPolicy where toPath = Prelude.const "/" instance Data.ToQuery PutPolicy where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newPutPolicyResponse' smart constructor. data PutPolicyResponse = PutPolicyResponse' { -- | The details of the Firewall Manager policy. policy :: Prelude.Maybe Policy, -- | The Amazon Resource Name (ARN) of the policy. policyArn :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'PutPolicyResponse' 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: -- -- 'policy', 'putPolicyResponse_policy' - The details of the Firewall Manager policy. -- -- 'policyArn', 'putPolicyResponse_policyArn' - The Amazon Resource Name (ARN) of the policy. -- -- 'httpStatus', 'putPolicyResponse_httpStatus' - The response's http status code. newPutPolicyResponse :: -- | 'httpStatus' Prelude.Int -> PutPolicyResponse newPutPolicyResponse pHttpStatus_ = PutPolicyResponse' { policy = Prelude.Nothing, policyArn = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The details of the Firewall Manager policy. putPolicyResponse_policy :: Lens.Lens' PutPolicyResponse (Prelude.Maybe Policy) putPolicyResponse_policy = Lens.lens (\PutPolicyResponse' {policy} -> policy) (\s@PutPolicyResponse' {} a -> s {policy = a} :: PutPolicyResponse) -- | The Amazon Resource Name (ARN) of the policy. putPolicyResponse_policyArn :: Lens.Lens' PutPolicyResponse (Prelude.Maybe Prelude.Text) putPolicyResponse_policyArn = Lens.lens (\PutPolicyResponse' {policyArn} -> policyArn) (\s@PutPolicyResponse' {} a -> s {policyArn = a} :: PutPolicyResponse) -- | The response's http status code. putPolicyResponse_httpStatus :: Lens.Lens' PutPolicyResponse Prelude.Int putPolicyResponse_httpStatus = Lens.lens (\PutPolicyResponse' {httpStatus} -> httpStatus) (\s@PutPolicyResponse' {} a -> s {httpStatus = a} :: PutPolicyResponse) instance Prelude.NFData PutPolicyResponse where rnf PutPolicyResponse' {..} = Prelude.rnf policy `Prelude.seq` Prelude.rnf policyArn `Prelude.seq` Prelude.rnf httpStatus