{-# 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.RBin.CreateRule -- 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 a Recycle Bin retention rule. For more information, see -- -- in the /Amazon Elastic Compute Cloud User Guide/. module Amazonka.RBin.CreateRule ( -- * Creating a Request CreateRule (..), newCreateRule, -- * Request Lenses createRule_description, createRule_lockConfiguration, createRule_resourceTags, createRule_tags, createRule_retentionPeriod, createRule_resourceType, -- * Destructuring the Response CreateRuleResponse (..), newCreateRuleResponse, -- * Response Lenses createRuleResponse_description, createRuleResponse_identifier, createRuleResponse_lockConfiguration, createRuleResponse_lockState, createRuleResponse_resourceTags, createRuleResponse_resourceType, createRuleResponse_retentionPeriod, createRuleResponse_status, createRuleResponse_tags, createRuleResponse_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 Amazonka.RBin.Types import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newCreateRule' smart constructor. data CreateRule = CreateRule' { -- | The retention rule description. description :: Prelude.Maybe Prelude.Text, -- | Information about the retention rule lock configuration. lockConfiguration :: Prelude.Maybe LockConfiguration, -- | Specifies the resource tags to use to identify resources that are to be -- retained by a tag-level retention rule. For tag-level retention rules, -- only deleted resources, of the specified resource type, that have one or -- more of the specified tag key and value pairs are retained. If a -- resource is deleted, but it does not have any of the specified tag key -- and value pairs, it is immediately deleted without being retained by the -- retention rule. -- -- You can add the same tag key and value pair to a maximum or five -- retention rules. -- -- To create a Region-level retention rule, omit this parameter. A -- Region-level retention rule does not have any resource tags specified. -- It retains all deleted resources of the specified resource type in the -- Region in which the rule is created, even if the resources are not -- tagged. resourceTags :: Prelude.Maybe [ResourceTag], -- | Information about the tags to assign to the retention rule. tags :: Prelude.Maybe [Tag], -- | Information about the retention period for which the retention rule is -- to retain resources. retentionPeriod :: RetentionPeriod, -- | The resource type to be retained by the retention rule. Currently, only -- Amazon EBS snapshots and EBS-backed AMIs are supported. To retain -- snapshots, specify @EBS_SNAPSHOT@. To retain EBS-backed AMIs, specify -- @EC2_IMAGE@. resourceType :: ResourceType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateRule' 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: -- -- 'description', 'createRule_description' - The retention rule description. -- -- 'lockConfiguration', 'createRule_lockConfiguration' - Information about the retention rule lock configuration. -- -- 'resourceTags', 'createRule_resourceTags' - Specifies the resource tags to use to identify resources that are to be -- retained by a tag-level retention rule. For tag-level retention rules, -- only deleted resources, of the specified resource type, that have one or -- more of the specified tag key and value pairs are retained. If a -- resource is deleted, but it does not have any of the specified tag key -- and value pairs, it is immediately deleted without being retained by the -- retention rule. -- -- You can add the same tag key and value pair to a maximum or five -- retention rules. -- -- To create a Region-level retention rule, omit this parameter. A -- Region-level retention rule does not have any resource tags specified. -- It retains all deleted resources of the specified resource type in the -- Region in which the rule is created, even if the resources are not -- tagged. -- -- 'tags', 'createRule_tags' - Information about the tags to assign to the retention rule. -- -- 'retentionPeriod', 'createRule_retentionPeriod' - Information about the retention period for which the retention rule is -- to retain resources. -- -- 'resourceType', 'createRule_resourceType' - The resource type to be retained by the retention rule. Currently, only -- Amazon EBS snapshots and EBS-backed AMIs are supported. To retain -- snapshots, specify @EBS_SNAPSHOT@. To retain EBS-backed AMIs, specify -- @EC2_IMAGE@. newCreateRule :: -- | 'retentionPeriod' RetentionPeriod -> -- | 'resourceType' ResourceType -> CreateRule newCreateRule pRetentionPeriod_ pResourceType_ = CreateRule' { description = Prelude.Nothing, lockConfiguration = Prelude.Nothing, resourceTags = Prelude.Nothing, tags = Prelude.Nothing, retentionPeriod = pRetentionPeriod_, resourceType = pResourceType_ } -- | The retention rule description. createRule_description :: Lens.Lens' CreateRule (Prelude.Maybe Prelude.Text) createRule_description = Lens.lens (\CreateRule' {description} -> description) (\s@CreateRule' {} a -> s {description = a} :: CreateRule) -- | Information about the retention rule lock configuration. createRule_lockConfiguration :: Lens.Lens' CreateRule (Prelude.Maybe LockConfiguration) createRule_lockConfiguration = Lens.lens (\CreateRule' {lockConfiguration} -> lockConfiguration) (\s@CreateRule' {} a -> s {lockConfiguration = a} :: CreateRule) -- | Specifies the resource tags to use to identify resources that are to be -- retained by a tag-level retention rule. For tag-level retention rules, -- only deleted resources, of the specified resource type, that have one or -- more of the specified tag key and value pairs are retained. If a -- resource is deleted, but it does not have any of the specified tag key -- and value pairs, it is immediately deleted without being retained by the -- retention rule. -- -- You can add the same tag key and value pair to a maximum or five -- retention rules. -- -- To create a Region-level retention rule, omit this parameter. A -- Region-level retention rule does not have any resource tags specified. -- It retains all deleted resources of the specified resource type in the -- Region in which the rule is created, even if the resources are not -- tagged. createRule_resourceTags :: Lens.Lens' CreateRule (Prelude.Maybe [ResourceTag]) createRule_resourceTags = Lens.lens (\CreateRule' {resourceTags} -> resourceTags) (\s@CreateRule' {} a -> s {resourceTags = a} :: CreateRule) Prelude.. Lens.mapping Lens.coerced -- | Information about the tags to assign to the retention rule. createRule_tags :: Lens.Lens' CreateRule (Prelude.Maybe [Tag]) createRule_tags = Lens.lens (\CreateRule' {tags} -> tags) (\s@CreateRule' {} a -> s {tags = a} :: CreateRule) Prelude.. Lens.mapping Lens.coerced -- | Information about the retention period for which the retention rule is -- to retain resources. createRule_retentionPeriod :: Lens.Lens' CreateRule RetentionPeriod createRule_retentionPeriod = Lens.lens (\CreateRule' {retentionPeriod} -> retentionPeriod) (\s@CreateRule' {} a -> s {retentionPeriod = a} :: CreateRule) -- | The resource type to be retained by the retention rule. Currently, only -- Amazon EBS snapshots and EBS-backed AMIs are supported. To retain -- snapshots, specify @EBS_SNAPSHOT@. To retain EBS-backed AMIs, specify -- @EC2_IMAGE@. createRule_resourceType :: Lens.Lens' CreateRule ResourceType createRule_resourceType = Lens.lens (\CreateRule' {resourceType} -> resourceType) (\s@CreateRule' {} a -> s {resourceType = a} :: CreateRule) instance Core.AWSRequest CreateRule where type AWSResponse CreateRule = CreateRuleResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateRuleResponse' Prelude.<$> (x Data..?> "Description") Prelude.<*> (x Data..?> "Identifier") Prelude.<*> (x Data..?> "LockConfiguration") Prelude.<*> (x Data..?> "LockState") Prelude.<*> (x Data..?> "ResourceTags" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "ResourceType") Prelude.<*> (x Data..?> "RetentionPeriod") Prelude.<*> (x Data..?> "Status") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateRule where hashWithSalt _salt CreateRule' {..} = _salt `Prelude.hashWithSalt` description `Prelude.hashWithSalt` lockConfiguration `Prelude.hashWithSalt` resourceTags `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` retentionPeriod `Prelude.hashWithSalt` resourceType instance Prelude.NFData CreateRule where rnf CreateRule' {..} = Prelude.rnf description `Prelude.seq` Prelude.rnf lockConfiguration `Prelude.seq` Prelude.rnf resourceTags `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf retentionPeriod `Prelude.seq` Prelude.rnf resourceType instance Data.ToHeaders CreateRule where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateRule where toJSON CreateRule' {..} = Data.object ( Prelude.catMaybes [ ("Description" Data..=) Prelude.<$> description, ("LockConfiguration" Data..=) Prelude.<$> lockConfiguration, ("ResourceTags" Data..=) Prelude.<$> resourceTags, ("Tags" Data..=) Prelude.<$> tags, Prelude.Just ("RetentionPeriod" Data..= retentionPeriod), Prelude.Just ("ResourceType" Data..= resourceType) ] ) instance Data.ToPath CreateRule where toPath = Prelude.const "/rules" instance Data.ToQuery CreateRule where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateRuleResponse' smart constructor. data CreateRuleResponse = CreateRuleResponse' { -- | The retention rule description. description :: Prelude.Maybe Prelude.Text, -- | The unique ID of the retention rule. identifier :: Prelude.Maybe Prelude.Text, -- | Information about the retention rule lock configuration. lockConfiguration :: Prelude.Maybe LockConfiguration, -- | The lock state for the retention rule. -- -- - @locked@ - The retention rule is locked and can\'t be modified or -- deleted. -- -- - @pending_unlock@ - The retention rule has been unlocked but it is -- still within the unlock delay period. The retention rule can be -- modified or deleted only after the unlock delay period has expired. -- -- - @unlocked@ - The retention rule is unlocked and it can be modified -- or deleted by any user with the required permissions. -- -- - @null@ - The retention rule has never been locked. Once a retention -- rule has been locked, it can transition between the @locked@ and -- @unlocked@ states only; it can never transition back to @null@. lockState :: Prelude.Maybe LockState, -- | Information about the resource tags used to identify resources that are -- retained by the retention rule. resourceTags :: Prelude.Maybe [ResourceTag], -- | The resource type retained by the retention rule. resourceType :: Prelude.Maybe ResourceType, retentionPeriod :: Prelude.Maybe RetentionPeriod, -- | The state of the retention rule. Only retention rules that are in the -- @available@ state retain resources. status :: Prelude.Maybe RuleStatus, -- | Information about the tags assigned to the retention rule. tags :: Prelude.Maybe [Tag], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateRuleResponse' 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: -- -- 'description', 'createRuleResponse_description' - The retention rule description. -- -- 'identifier', 'createRuleResponse_identifier' - The unique ID of the retention rule. -- -- 'lockConfiguration', 'createRuleResponse_lockConfiguration' - Information about the retention rule lock configuration. -- -- 'lockState', 'createRuleResponse_lockState' - The lock state for the retention rule. -- -- - @locked@ - The retention rule is locked and can\'t be modified or -- deleted. -- -- - @pending_unlock@ - The retention rule has been unlocked but it is -- still within the unlock delay period. The retention rule can be -- modified or deleted only after the unlock delay period has expired. -- -- - @unlocked@ - The retention rule is unlocked and it can be modified -- or deleted by any user with the required permissions. -- -- - @null@ - The retention rule has never been locked. Once a retention -- rule has been locked, it can transition between the @locked@ and -- @unlocked@ states only; it can never transition back to @null@. -- -- 'resourceTags', 'createRuleResponse_resourceTags' - Information about the resource tags used to identify resources that are -- retained by the retention rule. -- -- 'resourceType', 'createRuleResponse_resourceType' - The resource type retained by the retention rule. -- -- 'retentionPeriod', 'createRuleResponse_retentionPeriod' - Undocumented member. -- -- 'status', 'createRuleResponse_status' - The state of the retention rule. Only retention rules that are in the -- @available@ state retain resources. -- -- 'tags', 'createRuleResponse_tags' - Information about the tags assigned to the retention rule. -- -- 'httpStatus', 'createRuleResponse_httpStatus' - The response's http status code. newCreateRuleResponse :: -- | 'httpStatus' Prelude.Int -> CreateRuleResponse newCreateRuleResponse pHttpStatus_ = CreateRuleResponse' { description = Prelude.Nothing, identifier = Prelude.Nothing, lockConfiguration = Prelude.Nothing, lockState = Prelude.Nothing, resourceTags = Prelude.Nothing, resourceType = Prelude.Nothing, retentionPeriod = Prelude.Nothing, status = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The retention rule description. createRuleResponse_description :: Lens.Lens' CreateRuleResponse (Prelude.Maybe Prelude.Text) createRuleResponse_description = Lens.lens (\CreateRuleResponse' {description} -> description) (\s@CreateRuleResponse' {} a -> s {description = a} :: CreateRuleResponse) -- | The unique ID of the retention rule. createRuleResponse_identifier :: Lens.Lens' CreateRuleResponse (Prelude.Maybe Prelude.Text) createRuleResponse_identifier = Lens.lens (\CreateRuleResponse' {identifier} -> identifier) (\s@CreateRuleResponse' {} a -> s {identifier = a} :: CreateRuleResponse) -- | Information about the retention rule lock configuration. createRuleResponse_lockConfiguration :: Lens.Lens' CreateRuleResponse (Prelude.Maybe LockConfiguration) createRuleResponse_lockConfiguration = Lens.lens (\CreateRuleResponse' {lockConfiguration} -> lockConfiguration) (\s@CreateRuleResponse' {} a -> s {lockConfiguration = a} :: CreateRuleResponse) -- | The lock state for the retention rule. -- -- - @locked@ - The retention rule is locked and can\'t be modified or -- deleted. -- -- - @pending_unlock@ - The retention rule has been unlocked but it is -- still within the unlock delay period. The retention rule can be -- modified or deleted only after the unlock delay period has expired. -- -- - @unlocked@ - The retention rule is unlocked and it can be modified -- or deleted by any user with the required permissions. -- -- - @null@ - The retention rule has never been locked. Once a retention -- rule has been locked, it can transition between the @locked@ and -- @unlocked@ states only; it can never transition back to @null@. createRuleResponse_lockState :: Lens.Lens' CreateRuleResponse (Prelude.Maybe LockState) createRuleResponse_lockState = Lens.lens (\CreateRuleResponse' {lockState} -> lockState) (\s@CreateRuleResponse' {} a -> s {lockState = a} :: CreateRuleResponse) -- | Information about the resource tags used to identify resources that are -- retained by the retention rule. createRuleResponse_resourceTags :: Lens.Lens' CreateRuleResponse (Prelude.Maybe [ResourceTag]) createRuleResponse_resourceTags = Lens.lens (\CreateRuleResponse' {resourceTags} -> resourceTags) (\s@CreateRuleResponse' {} a -> s {resourceTags = a} :: CreateRuleResponse) Prelude.. Lens.mapping Lens.coerced -- | The resource type retained by the retention rule. createRuleResponse_resourceType :: Lens.Lens' CreateRuleResponse (Prelude.Maybe ResourceType) createRuleResponse_resourceType = Lens.lens (\CreateRuleResponse' {resourceType} -> resourceType) (\s@CreateRuleResponse' {} a -> s {resourceType = a} :: CreateRuleResponse) -- | Undocumented member. createRuleResponse_retentionPeriod :: Lens.Lens' CreateRuleResponse (Prelude.Maybe RetentionPeriod) createRuleResponse_retentionPeriod = Lens.lens (\CreateRuleResponse' {retentionPeriod} -> retentionPeriod) (\s@CreateRuleResponse' {} a -> s {retentionPeriod = a} :: CreateRuleResponse) -- | The state of the retention rule. Only retention rules that are in the -- @available@ state retain resources. createRuleResponse_status :: Lens.Lens' CreateRuleResponse (Prelude.Maybe RuleStatus) createRuleResponse_status = Lens.lens (\CreateRuleResponse' {status} -> status) (\s@CreateRuleResponse' {} a -> s {status = a} :: CreateRuleResponse) -- | Information about the tags assigned to the retention rule. createRuleResponse_tags :: Lens.Lens' CreateRuleResponse (Prelude.Maybe [Tag]) createRuleResponse_tags = Lens.lens (\CreateRuleResponse' {tags} -> tags) (\s@CreateRuleResponse' {} a -> s {tags = a} :: CreateRuleResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. createRuleResponse_httpStatus :: Lens.Lens' CreateRuleResponse Prelude.Int createRuleResponse_httpStatus = Lens.lens (\CreateRuleResponse' {httpStatus} -> httpStatus) (\s@CreateRuleResponse' {} a -> s {httpStatus = a} :: CreateRuleResponse) instance Prelude.NFData CreateRuleResponse where rnf CreateRuleResponse' {..} = Prelude.rnf description `Prelude.seq` Prelude.rnf identifier `Prelude.seq` Prelude.rnf lockConfiguration `Prelude.seq` Prelude.rnf lockState `Prelude.seq` Prelude.rnf resourceTags `Prelude.seq` Prelude.rnf resourceType `Prelude.seq` Prelude.rnf retentionPeriod `Prelude.seq` Prelude.rnf status `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus