{-# 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.ServiceCatalog.UpdateProvisionedProductProperties -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Requests updates to the properties of the specified provisioned product. module Amazonka.ServiceCatalog.UpdateProvisionedProductProperties ( -- * Creating a Request UpdateProvisionedProductProperties (..), newUpdateProvisionedProductProperties, -- * Request Lenses updateProvisionedProductProperties_acceptLanguage, updateProvisionedProductProperties_provisionedProductId, updateProvisionedProductProperties_provisionedProductProperties, updateProvisionedProductProperties_idempotencyToken, -- * Destructuring the Response UpdateProvisionedProductPropertiesResponse (..), newUpdateProvisionedProductPropertiesResponse, -- * Response Lenses updateProvisionedProductPropertiesResponse_provisionedProductId, updateProvisionedProductPropertiesResponse_provisionedProductProperties, updateProvisionedProductPropertiesResponse_recordId, updateProvisionedProductPropertiesResponse_status, updateProvisionedProductPropertiesResponse_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.ServiceCatalog.Types -- | /See:/ 'newUpdateProvisionedProductProperties' smart constructor. data UpdateProvisionedProductProperties = UpdateProvisionedProductProperties' { -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese acceptLanguage :: Prelude.Maybe Prelude.Text, -- | The identifier of the provisioned product. provisionedProductId :: Prelude.Text, -- | A map that contains the provisioned product properties to be updated. -- -- The @LAUNCH_ROLE@ key accepts role ARNs. This key allows an -- administrator to call @UpdateProvisionedProductProperties@ to update the -- launch role that is associated with a provisioned product. This role is -- used when an end user calls a provisioning operation such as -- @UpdateProvisionedProduct@, @TerminateProvisionedProduct@, or -- @ExecuteProvisionedProductServiceAction@. Only a role ARN is valid. A -- user ARN is invalid. -- -- The @OWNER@ key accepts IAM user ARNs, IAM role ARNs, and STS -- assumed-role ARNs. The owner is the user that has permission to see, -- update, terminate, and execute service actions in the provisioned -- product. -- -- The administrator can change the owner of a provisioned product to -- another IAM or STS entity within the same account. Both end user owners -- and administrators can see ownership history of the provisioned product -- using the @ListRecordHistory@ API. The new owner can describe all past -- records for the provisioned product using the @DescribeRecord@ API. The -- previous owner can no longer use @DescribeRecord@, but can still see the -- product\'s history from when he was an owner using @ListRecordHistory@. -- -- If a provisioned product ownership is assigned to an end user, they can -- see and perform any action through the API or Service Catalog console -- such as update, terminate, and execute service actions. If an end user -- provisions a product and the owner is updated to someone else, they will -- no longer be able to see or perform any actions through API or the -- Service Catalog console on that provisioned product. provisionedProductProperties :: Prelude.HashMap PropertyKey Prelude.Text, -- | The idempotency token that uniquely identifies the provisioning product -- update request. idempotencyToken :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateProvisionedProductProperties' 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: -- -- 'acceptLanguage', 'updateProvisionedProductProperties_acceptLanguage' - The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese -- -- 'provisionedProductId', 'updateProvisionedProductProperties_provisionedProductId' - The identifier of the provisioned product. -- -- 'provisionedProductProperties', 'updateProvisionedProductProperties_provisionedProductProperties' - A map that contains the provisioned product properties to be updated. -- -- The @LAUNCH_ROLE@ key accepts role ARNs. This key allows an -- administrator to call @UpdateProvisionedProductProperties@ to update the -- launch role that is associated with a provisioned product. This role is -- used when an end user calls a provisioning operation such as -- @UpdateProvisionedProduct@, @TerminateProvisionedProduct@, or -- @ExecuteProvisionedProductServiceAction@. Only a role ARN is valid. A -- user ARN is invalid. -- -- The @OWNER@ key accepts IAM user ARNs, IAM role ARNs, and STS -- assumed-role ARNs. The owner is the user that has permission to see, -- update, terminate, and execute service actions in the provisioned -- product. -- -- The administrator can change the owner of a provisioned product to -- another IAM or STS entity within the same account. Both end user owners -- and administrators can see ownership history of the provisioned product -- using the @ListRecordHistory@ API. The new owner can describe all past -- records for the provisioned product using the @DescribeRecord@ API. The -- previous owner can no longer use @DescribeRecord@, but can still see the -- product\'s history from when he was an owner using @ListRecordHistory@. -- -- If a provisioned product ownership is assigned to an end user, they can -- see and perform any action through the API or Service Catalog console -- such as update, terminate, and execute service actions. If an end user -- provisions a product and the owner is updated to someone else, they will -- no longer be able to see or perform any actions through API or the -- Service Catalog console on that provisioned product. -- -- 'idempotencyToken', 'updateProvisionedProductProperties_idempotencyToken' - The idempotency token that uniquely identifies the provisioning product -- update request. newUpdateProvisionedProductProperties :: -- | 'provisionedProductId' Prelude.Text -> -- | 'idempotencyToken' Prelude.Text -> UpdateProvisionedProductProperties newUpdateProvisionedProductProperties pProvisionedProductId_ pIdempotencyToken_ = UpdateProvisionedProductProperties' { acceptLanguage = Prelude.Nothing, provisionedProductId = pProvisionedProductId_, provisionedProductProperties = Prelude.mempty, idempotencyToken = pIdempotencyToken_ } -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese updateProvisionedProductProperties_acceptLanguage :: Lens.Lens' UpdateProvisionedProductProperties (Prelude.Maybe Prelude.Text) updateProvisionedProductProperties_acceptLanguage = Lens.lens (\UpdateProvisionedProductProperties' {acceptLanguage} -> acceptLanguage) (\s@UpdateProvisionedProductProperties' {} a -> s {acceptLanguage = a} :: UpdateProvisionedProductProperties) -- | The identifier of the provisioned product. updateProvisionedProductProperties_provisionedProductId :: Lens.Lens' UpdateProvisionedProductProperties Prelude.Text updateProvisionedProductProperties_provisionedProductId = Lens.lens (\UpdateProvisionedProductProperties' {provisionedProductId} -> provisionedProductId) (\s@UpdateProvisionedProductProperties' {} a -> s {provisionedProductId = a} :: UpdateProvisionedProductProperties) -- | A map that contains the provisioned product properties to be updated. -- -- The @LAUNCH_ROLE@ key accepts role ARNs. This key allows an -- administrator to call @UpdateProvisionedProductProperties@ to update the -- launch role that is associated with a provisioned product. This role is -- used when an end user calls a provisioning operation such as -- @UpdateProvisionedProduct@, @TerminateProvisionedProduct@, or -- @ExecuteProvisionedProductServiceAction@. Only a role ARN is valid. A -- user ARN is invalid. -- -- The @OWNER@ key accepts IAM user ARNs, IAM role ARNs, and STS -- assumed-role ARNs. The owner is the user that has permission to see, -- update, terminate, and execute service actions in the provisioned -- product. -- -- The administrator can change the owner of a provisioned product to -- another IAM or STS entity within the same account. Both end user owners -- and administrators can see ownership history of the provisioned product -- using the @ListRecordHistory@ API. The new owner can describe all past -- records for the provisioned product using the @DescribeRecord@ API. The -- previous owner can no longer use @DescribeRecord@, but can still see the -- product\'s history from when he was an owner using @ListRecordHistory@. -- -- If a provisioned product ownership is assigned to an end user, they can -- see and perform any action through the API or Service Catalog console -- such as update, terminate, and execute service actions. If an end user -- provisions a product and the owner is updated to someone else, they will -- no longer be able to see or perform any actions through API or the -- Service Catalog console on that provisioned product. updateProvisionedProductProperties_provisionedProductProperties :: Lens.Lens' UpdateProvisionedProductProperties (Prelude.HashMap PropertyKey Prelude.Text) updateProvisionedProductProperties_provisionedProductProperties = Lens.lens (\UpdateProvisionedProductProperties' {provisionedProductProperties} -> provisionedProductProperties) (\s@UpdateProvisionedProductProperties' {} a -> s {provisionedProductProperties = a} :: UpdateProvisionedProductProperties) Prelude.. Lens.coerced -- | The idempotency token that uniquely identifies the provisioning product -- update request. updateProvisionedProductProperties_idempotencyToken :: Lens.Lens' UpdateProvisionedProductProperties Prelude.Text updateProvisionedProductProperties_idempotencyToken = Lens.lens (\UpdateProvisionedProductProperties' {idempotencyToken} -> idempotencyToken) (\s@UpdateProvisionedProductProperties' {} a -> s {idempotencyToken = a} :: UpdateProvisionedProductProperties) instance Core.AWSRequest UpdateProvisionedProductProperties where type AWSResponse UpdateProvisionedProductProperties = UpdateProvisionedProductPropertiesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateProvisionedProductPropertiesResponse' Prelude.<$> (x Data..?> "ProvisionedProductId") Prelude.<*> ( x Data..?> "ProvisionedProductProperties" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "RecordId") Prelude.<*> (x Data..?> "Status") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateProvisionedProductProperties where hashWithSalt _salt UpdateProvisionedProductProperties' {..} = _salt `Prelude.hashWithSalt` acceptLanguage `Prelude.hashWithSalt` provisionedProductId `Prelude.hashWithSalt` provisionedProductProperties `Prelude.hashWithSalt` idempotencyToken instance Prelude.NFData UpdateProvisionedProductProperties where rnf UpdateProvisionedProductProperties' {..} = Prelude.rnf acceptLanguage `Prelude.seq` Prelude.rnf provisionedProductId `Prelude.seq` Prelude.rnf provisionedProductProperties `Prelude.seq` Prelude.rnf idempotencyToken instance Data.ToHeaders UpdateProvisionedProductProperties where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWS242ServiceCatalogService.UpdateProvisionedProductProperties" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateProvisionedProductProperties where toJSON UpdateProvisionedProductProperties' {..} = Data.object ( Prelude.catMaybes [ ("AcceptLanguage" Data..=) Prelude.<$> acceptLanguage, Prelude.Just ( "ProvisionedProductId" Data..= provisionedProductId ), Prelude.Just ( "ProvisionedProductProperties" Data..= provisionedProductProperties ), Prelude.Just ("IdempotencyToken" Data..= idempotencyToken) ] ) instance Data.ToPath UpdateProvisionedProductProperties where toPath = Prelude.const "/" instance Data.ToQuery UpdateProvisionedProductProperties where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateProvisionedProductPropertiesResponse' smart constructor. data UpdateProvisionedProductPropertiesResponse = UpdateProvisionedProductPropertiesResponse' { -- | The provisioned product identifier. provisionedProductId :: Prelude.Maybe Prelude.Text, -- | A map that contains the properties updated. provisionedProductProperties :: Prelude.Maybe (Prelude.HashMap PropertyKey Prelude.Text), -- | The identifier of the record. recordId :: Prelude.Maybe Prelude.Text, -- | The status of the request. status :: Prelude.Maybe RecordStatus, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateProvisionedProductPropertiesResponse' 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: -- -- 'provisionedProductId', 'updateProvisionedProductPropertiesResponse_provisionedProductId' - The provisioned product identifier. -- -- 'provisionedProductProperties', 'updateProvisionedProductPropertiesResponse_provisionedProductProperties' - A map that contains the properties updated. -- -- 'recordId', 'updateProvisionedProductPropertiesResponse_recordId' - The identifier of the record. -- -- 'status', 'updateProvisionedProductPropertiesResponse_status' - The status of the request. -- -- 'httpStatus', 'updateProvisionedProductPropertiesResponse_httpStatus' - The response's http status code. newUpdateProvisionedProductPropertiesResponse :: -- | 'httpStatus' Prelude.Int -> UpdateProvisionedProductPropertiesResponse newUpdateProvisionedProductPropertiesResponse pHttpStatus_ = UpdateProvisionedProductPropertiesResponse' { provisionedProductId = Prelude.Nothing, provisionedProductProperties = Prelude.Nothing, recordId = Prelude.Nothing, status = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The provisioned product identifier. updateProvisionedProductPropertiesResponse_provisionedProductId :: Lens.Lens' UpdateProvisionedProductPropertiesResponse (Prelude.Maybe Prelude.Text) updateProvisionedProductPropertiesResponse_provisionedProductId = Lens.lens (\UpdateProvisionedProductPropertiesResponse' {provisionedProductId} -> provisionedProductId) (\s@UpdateProvisionedProductPropertiesResponse' {} a -> s {provisionedProductId = a} :: UpdateProvisionedProductPropertiesResponse) -- | A map that contains the properties updated. updateProvisionedProductPropertiesResponse_provisionedProductProperties :: Lens.Lens' UpdateProvisionedProductPropertiesResponse (Prelude.Maybe (Prelude.HashMap PropertyKey Prelude.Text)) updateProvisionedProductPropertiesResponse_provisionedProductProperties = Lens.lens (\UpdateProvisionedProductPropertiesResponse' {provisionedProductProperties} -> provisionedProductProperties) (\s@UpdateProvisionedProductPropertiesResponse' {} a -> s {provisionedProductProperties = a} :: UpdateProvisionedProductPropertiesResponse) Prelude.. Lens.mapping Lens.coerced -- | The identifier of the record. updateProvisionedProductPropertiesResponse_recordId :: Lens.Lens' UpdateProvisionedProductPropertiesResponse (Prelude.Maybe Prelude.Text) updateProvisionedProductPropertiesResponse_recordId = Lens.lens (\UpdateProvisionedProductPropertiesResponse' {recordId} -> recordId) (\s@UpdateProvisionedProductPropertiesResponse' {} a -> s {recordId = a} :: UpdateProvisionedProductPropertiesResponse) -- | The status of the request. updateProvisionedProductPropertiesResponse_status :: Lens.Lens' UpdateProvisionedProductPropertiesResponse (Prelude.Maybe RecordStatus) updateProvisionedProductPropertiesResponse_status = Lens.lens (\UpdateProvisionedProductPropertiesResponse' {status} -> status) (\s@UpdateProvisionedProductPropertiesResponse' {} a -> s {status = a} :: UpdateProvisionedProductPropertiesResponse) -- | The response's http status code. updateProvisionedProductPropertiesResponse_httpStatus :: Lens.Lens' UpdateProvisionedProductPropertiesResponse Prelude.Int updateProvisionedProductPropertiesResponse_httpStatus = Lens.lens (\UpdateProvisionedProductPropertiesResponse' {httpStatus} -> httpStatus) (\s@UpdateProvisionedProductPropertiesResponse' {} a -> s {httpStatus = a} :: UpdateProvisionedProductPropertiesResponse) instance Prelude.NFData UpdateProvisionedProductPropertiesResponse where rnf UpdateProvisionedProductPropertiesResponse' {..} = Prelude.rnf provisionedProductId `Prelude.seq` Prelude.rnf provisionedProductProperties `Prelude.seq` Prelude.rnf recordId `Prelude.seq` Prelude.rnf status `Prelude.seq` Prelude.rnf httpStatus