{-# 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.Connect.UpdateSecurityProfile -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- This API is in preview release for Amazon Connect and is subject to -- change. -- -- Updates a security profile. module Amazonka.Connect.UpdateSecurityProfile ( -- * Creating a Request UpdateSecurityProfile (..), newUpdateSecurityProfile, -- * Request Lenses updateSecurityProfile_allowedAccessControlTags, updateSecurityProfile_description, updateSecurityProfile_permissions, updateSecurityProfile_tagRestrictedResources, updateSecurityProfile_securityProfileId, updateSecurityProfile_instanceId, -- * Destructuring the Response UpdateSecurityProfileResponse (..), newUpdateSecurityProfileResponse, ) where import Amazonka.Connect.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 -- | /See:/ 'newUpdateSecurityProfile' smart constructor. data UpdateSecurityProfile = UpdateSecurityProfile' { -- | The list of tags that a security profile uses to restrict access to -- resources in Amazon Connect. allowedAccessControlTags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The description of the security profile. description :: Prelude.Maybe Prelude.Text, -- | The permissions granted to a security profile. For a list of valid -- permissions, see -- . permissions :: Prelude.Maybe [Prelude.Text], -- | The list of resources that a security profile applies tag restrictions -- to in Amazon Connect. tagRestrictedResources :: Prelude.Maybe [Prelude.Text], -- | The identifier for the security profle. securityProfileId :: Prelude.Text, -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. instanceId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateSecurityProfile' 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: -- -- 'allowedAccessControlTags', 'updateSecurityProfile_allowedAccessControlTags' - The list of tags that a security profile uses to restrict access to -- resources in Amazon Connect. -- -- 'description', 'updateSecurityProfile_description' - The description of the security profile. -- -- 'permissions', 'updateSecurityProfile_permissions' - The permissions granted to a security profile. For a list of valid -- permissions, see -- . -- -- 'tagRestrictedResources', 'updateSecurityProfile_tagRestrictedResources' - The list of resources that a security profile applies tag restrictions -- to in Amazon Connect. -- -- 'securityProfileId', 'updateSecurityProfile_securityProfileId' - The identifier for the security profle. -- -- 'instanceId', 'updateSecurityProfile_instanceId' - The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. newUpdateSecurityProfile :: -- | 'securityProfileId' Prelude.Text -> -- | 'instanceId' Prelude.Text -> UpdateSecurityProfile newUpdateSecurityProfile pSecurityProfileId_ pInstanceId_ = UpdateSecurityProfile' { allowedAccessControlTags = Prelude.Nothing, description = Prelude.Nothing, permissions = Prelude.Nothing, tagRestrictedResources = Prelude.Nothing, securityProfileId = pSecurityProfileId_, instanceId = pInstanceId_ } -- | The list of tags that a security profile uses to restrict access to -- resources in Amazon Connect. updateSecurityProfile_allowedAccessControlTags :: Lens.Lens' UpdateSecurityProfile (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) updateSecurityProfile_allowedAccessControlTags = Lens.lens (\UpdateSecurityProfile' {allowedAccessControlTags} -> allowedAccessControlTags) (\s@UpdateSecurityProfile' {} a -> s {allowedAccessControlTags = a} :: UpdateSecurityProfile) Prelude.. Lens.mapping Lens.coerced -- | The description of the security profile. updateSecurityProfile_description :: Lens.Lens' UpdateSecurityProfile (Prelude.Maybe Prelude.Text) updateSecurityProfile_description = Lens.lens (\UpdateSecurityProfile' {description} -> description) (\s@UpdateSecurityProfile' {} a -> s {description = a} :: UpdateSecurityProfile) -- | The permissions granted to a security profile. For a list of valid -- permissions, see -- . updateSecurityProfile_permissions :: Lens.Lens' UpdateSecurityProfile (Prelude.Maybe [Prelude.Text]) updateSecurityProfile_permissions = Lens.lens (\UpdateSecurityProfile' {permissions} -> permissions) (\s@UpdateSecurityProfile' {} a -> s {permissions = a} :: UpdateSecurityProfile) Prelude.. Lens.mapping Lens.coerced -- | The list of resources that a security profile applies tag restrictions -- to in Amazon Connect. updateSecurityProfile_tagRestrictedResources :: Lens.Lens' UpdateSecurityProfile (Prelude.Maybe [Prelude.Text]) updateSecurityProfile_tagRestrictedResources = Lens.lens (\UpdateSecurityProfile' {tagRestrictedResources} -> tagRestrictedResources) (\s@UpdateSecurityProfile' {} a -> s {tagRestrictedResources = a} :: UpdateSecurityProfile) Prelude.. Lens.mapping Lens.coerced -- | The identifier for the security profle. updateSecurityProfile_securityProfileId :: Lens.Lens' UpdateSecurityProfile Prelude.Text updateSecurityProfile_securityProfileId = Lens.lens (\UpdateSecurityProfile' {securityProfileId} -> securityProfileId) (\s@UpdateSecurityProfile' {} a -> s {securityProfileId = a} :: UpdateSecurityProfile) -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. updateSecurityProfile_instanceId :: Lens.Lens' UpdateSecurityProfile Prelude.Text updateSecurityProfile_instanceId = Lens.lens (\UpdateSecurityProfile' {instanceId} -> instanceId) (\s@UpdateSecurityProfile' {} a -> s {instanceId = a} :: UpdateSecurityProfile) instance Core.AWSRequest UpdateSecurityProfile where type AWSResponse UpdateSecurityProfile = UpdateSecurityProfileResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull UpdateSecurityProfileResponse' instance Prelude.Hashable UpdateSecurityProfile where hashWithSalt _salt UpdateSecurityProfile' {..} = _salt `Prelude.hashWithSalt` allowedAccessControlTags `Prelude.hashWithSalt` description `Prelude.hashWithSalt` permissions `Prelude.hashWithSalt` tagRestrictedResources `Prelude.hashWithSalt` securityProfileId `Prelude.hashWithSalt` instanceId instance Prelude.NFData UpdateSecurityProfile where rnf UpdateSecurityProfile' {..} = Prelude.rnf allowedAccessControlTags `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf permissions `Prelude.seq` Prelude.rnf tagRestrictedResources `Prelude.seq` Prelude.rnf securityProfileId `Prelude.seq` Prelude.rnf instanceId instance Data.ToHeaders UpdateSecurityProfile where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateSecurityProfile where toJSON UpdateSecurityProfile' {..} = Data.object ( Prelude.catMaybes [ ("AllowedAccessControlTags" Data..=) Prelude.<$> allowedAccessControlTags, ("Description" Data..=) Prelude.<$> description, ("Permissions" Data..=) Prelude.<$> permissions, ("TagRestrictedResources" Data..=) Prelude.<$> tagRestrictedResources ] ) instance Data.ToPath UpdateSecurityProfile where toPath UpdateSecurityProfile' {..} = Prelude.mconcat [ "/security-profiles/", Data.toBS instanceId, "/", Data.toBS securityProfileId ] instance Data.ToQuery UpdateSecurityProfile where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateSecurityProfileResponse' smart constructor. data UpdateSecurityProfileResponse = UpdateSecurityProfileResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateSecurityProfileResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newUpdateSecurityProfileResponse :: UpdateSecurityProfileResponse newUpdateSecurityProfileResponse = UpdateSecurityProfileResponse' instance Prelude.NFData UpdateSecurityProfileResponse where rnf _ = ()