{-# 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.ProvisionProduct -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Provisions the specified product. -- -- A provisioned product is a resourced instance of a product. For example, -- provisioning a product based on a CloudFormation template launches a -- CloudFormation stack and its underlying resources. You can check the -- status of this request using DescribeRecord. -- -- If the request contains a tag key with an empty list of values, there is -- a tag conflict for that key. Do not include conflicted keys as tags, or -- this causes the error \"Parameter validation failed: Missing required -- parameter in Tags[/N/]:/Value/\". module Amazonka.ServiceCatalog.ProvisionProduct ( -- * Creating a Request ProvisionProduct (..), newProvisionProduct, -- * Request Lenses provisionProduct_acceptLanguage, provisionProduct_notificationArns, provisionProduct_pathId, provisionProduct_pathName, provisionProduct_productId, provisionProduct_productName, provisionProduct_provisioningArtifactId, provisionProduct_provisioningArtifactName, provisionProduct_provisioningParameters, provisionProduct_provisioningPreferences, provisionProduct_tags, provisionProduct_provisionedProductName, provisionProduct_provisionToken, -- * Destructuring the Response ProvisionProductResponse (..), newProvisionProductResponse, -- * Response Lenses provisionProductResponse_recordDetail, provisionProductResponse_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:/ 'newProvisionProduct' smart constructor. data ProvisionProduct = ProvisionProduct' { -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese acceptLanguage :: Prelude.Maybe Prelude.Text, -- | Passed to CloudFormation. The SNS topic ARNs to which to publish -- stack-related events. notificationArns :: Prelude.Maybe [Prelude.Text], -- | The path identifier of the product. This value is optional if the -- product has a default path, and required if the product has more than -- one path. To list the paths for a product, use ListLaunchPaths. You must -- provide the name or ID, but not both. pathId :: Prelude.Maybe Prelude.Text, -- | The name of the path. You must provide the name or ID, but not both. pathName :: Prelude.Maybe Prelude.Text, -- | The product identifier. You must provide the name or ID, but not both. productId :: Prelude.Maybe Prelude.Text, -- | The name of the product. You must provide the name or ID, but not both. productName :: Prelude.Maybe Prelude.Text, -- | The identifier of the provisioning artifact. You must provide the name -- or ID, but not both. provisioningArtifactId :: Prelude.Maybe Prelude.Text, -- | The name of the provisioning artifact. You must provide the name or ID, -- but not both. provisioningArtifactName :: Prelude.Maybe Prelude.Text, -- | Parameters specified by the administrator that are required for -- provisioning the product. provisioningParameters :: Prelude.Maybe [ProvisioningParameter], -- | An object that contains information about the provisioning preferences -- for a stack set. provisioningPreferences :: Prelude.Maybe ProvisioningPreferences, -- | One or more tags. tags :: Prelude.Maybe [Tag], -- | A user-friendly name for the provisioned product. This value must be -- unique for the Amazon Web Services account and cannot be updated after -- the product is provisioned. provisionedProductName :: Prelude.Text, -- | An idempotency token that uniquely identifies the provisioning request. provisionToken :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ProvisionProduct' 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', 'provisionProduct_acceptLanguage' - The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese -- -- 'notificationArns', 'provisionProduct_notificationArns' - Passed to CloudFormation. The SNS topic ARNs to which to publish -- stack-related events. -- -- 'pathId', 'provisionProduct_pathId' - The path identifier of the product. This value is optional if the -- product has a default path, and required if the product has more than -- one path. To list the paths for a product, use ListLaunchPaths. You must -- provide the name or ID, but not both. -- -- 'pathName', 'provisionProduct_pathName' - The name of the path. You must provide the name or ID, but not both. -- -- 'productId', 'provisionProduct_productId' - The product identifier. You must provide the name or ID, but not both. -- -- 'productName', 'provisionProduct_productName' - The name of the product. You must provide the name or ID, but not both. -- -- 'provisioningArtifactId', 'provisionProduct_provisioningArtifactId' - The identifier of the provisioning artifact. You must provide the name -- or ID, but not both. -- -- 'provisioningArtifactName', 'provisionProduct_provisioningArtifactName' - The name of the provisioning artifact. You must provide the name or ID, -- but not both. -- -- 'provisioningParameters', 'provisionProduct_provisioningParameters' - Parameters specified by the administrator that are required for -- provisioning the product. -- -- 'provisioningPreferences', 'provisionProduct_provisioningPreferences' - An object that contains information about the provisioning preferences -- for a stack set. -- -- 'tags', 'provisionProduct_tags' - One or more tags. -- -- 'provisionedProductName', 'provisionProduct_provisionedProductName' - A user-friendly name for the provisioned product. This value must be -- unique for the Amazon Web Services account and cannot be updated after -- the product is provisioned. -- -- 'provisionToken', 'provisionProduct_provisionToken' - An idempotency token that uniquely identifies the provisioning request. newProvisionProduct :: -- | 'provisionedProductName' Prelude.Text -> -- | 'provisionToken' Prelude.Text -> ProvisionProduct newProvisionProduct pProvisionedProductName_ pProvisionToken_ = ProvisionProduct' { acceptLanguage = Prelude.Nothing, notificationArns = Prelude.Nothing, pathId = Prelude.Nothing, pathName = Prelude.Nothing, productId = Prelude.Nothing, productName = Prelude.Nothing, provisioningArtifactId = Prelude.Nothing, provisioningArtifactName = Prelude.Nothing, provisioningParameters = Prelude.Nothing, provisioningPreferences = Prelude.Nothing, tags = Prelude.Nothing, provisionedProductName = pProvisionedProductName_, provisionToken = pProvisionToken_ } -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese provisionProduct_acceptLanguage :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_acceptLanguage = Lens.lens (\ProvisionProduct' {acceptLanguage} -> acceptLanguage) (\s@ProvisionProduct' {} a -> s {acceptLanguage = a} :: ProvisionProduct) -- | Passed to CloudFormation. The SNS topic ARNs to which to publish -- stack-related events. provisionProduct_notificationArns :: Lens.Lens' ProvisionProduct (Prelude.Maybe [Prelude.Text]) provisionProduct_notificationArns = Lens.lens (\ProvisionProduct' {notificationArns} -> notificationArns) (\s@ProvisionProduct' {} a -> s {notificationArns = a} :: ProvisionProduct) Prelude.. Lens.mapping Lens.coerced -- | The path identifier of the product. This value is optional if the -- product has a default path, and required if the product has more than -- one path. To list the paths for a product, use ListLaunchPaths. You must -- provide the name or ID, but not both. provisionProduct_pathId :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_pathId = Lens.lens (\ProvisionProduct' {pathId} -> pathId) (\s@ProvisionProduct' {} a -> s {pathId = a} :: ProvisionProduct) -- | The name of the path. You must provide the name or ID, but not both. provisionProduct_pathName :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_pathName = Lens.lens (\ProvisionProduct' {pathName} -> pathName) (\s@ProvisionProduct' {} a -> s {pathName = a} :: ProvisionProduct) -- | The product identifier. You must provide the name or ID, but not both. provisionProduct_productId :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_productId = Lens.lens (\ProvisionProduct' {productId} -> productId) (\s@ProvisionProduct' {} a -> s {productId = a} :: ProvisionProduct) -- | The name of the product. You must provide the name or ID, but not both. provisionProduct_productName :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_productName = Lens.lens (\ProvisionProduct' {productName} -> productName) (\s@ProvisionProduct' {} a -> s {productName = a} :: ProvisionProduct) -- | The identifier of the provisioning artifact. You must provide the name -- or ID, but not both. provisionProduct_provisioningArtifactId :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_provisioningArtifactId = Lens.lens (\ProvisionProduct' {provisioningArtifactId} -> provisioningArtifactId) (\s@ProvisionProduct' {} a -> s {provisioningArtifactId = a} :: ProvisionProduct) -- | The name of the provisioning artifact. You must provide the name or ID, -- but not both. provisionProduct_provisioningArtifactName :: Lens.Lens' ProvisionProduct (Prelude.Maybe Prelude.Text) provisionProduct_provisioningArtifactName = Lens.lens (\ProvisionProduct' {provisioningArtifactName} -> provisioningArtifactName) (\s@ProvisionProduct' {} a -> s {provisioningArtifactName = a} :: ProvisionProduct) -- | Parameters specified by the administrator that are required for -- provisioning the product. provisionProduct_provisioningParameters :: Lens.Lens' ProvisionProduct (Prelude.Maybe [ProvisioningParameter]) provisionProduct_provisioningParameters = Lens.lens (\ProvisionProduct' {provisioningParameters} -> provisioningParameters) (\s@ProvisionProduct' {} a -> s {provisioningParameters = a} :: ProvisionProduct) Prelude.. Lens.mapping Lens.coerced -- | An object that contains information about the provisioning preferences -- for a stack set. provisionProduct_provisioningPreferences :: Lens.Lens' ProvisionProduct (Prelude.Maybe ProvisioningPreferences) provisionProduct_provisioningPreferences = Lens.lens (\ProvisionProduct' {provisioningPreferences} -> provisioningPreferences) (\s@ProvisionProduct' {} a -> s {provisioningPreferences = a} :: ProvisionProduct) -- | One or more tags. provisionProduct_tags :: Lens.Lens' ProvisionProduct (Prelude.Maybe [Tag]) provisionProduct_tags = Lens.lens (\ProvisionProduct' {tags} -> tags) (\s@ProvisionProduct' {} a -> s {tags = a} :: ProvisionProduct) Prelude.. Lens.mapping Lens.coerced -- | A user-friendly name for the provisioned product. This value must be -- unique for the Amazon Web Services account and cannot be updated after -- the product is provisioned. provisionProduct_provisionedProductName :: Lens.Lens' ProvisionProduct Prelude.Text provisionProduct_provisionedProductName = Lens.lens (\ProvisionProduct' {provisionedProductName} -> provisionedProductName) (\s@ProvisionProduct' {} a -> s {provisionedProductName = a} :: ProvisionProduct) -- | An idempotency token that uniquely identifies the provisioning request. provisionProduct_provisionToken :: Lens.Lens' ProvisionProduct Prelude.Text provisionProduct_provisionToken = Lens.lens (\ProvisionProduct' {provisionToken} -> provisionToken) (\s@ProvisionProduct' {} a -> s {provisionToken = a} :: ProvisionProduct) instance Core.AWSRequest ProvisionProduct where type AWSResponse ProvisionProduct = ProvisionProductResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ProvisionProductResponse' Prelude.<$> (x Data..?> "RecordDetail") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ProvisionProduct where hashWithSalt _salt ProvisionProduct' {..} = _salt `Prelude.hashWithSalt` acceptLanguage `Prelude.hashWithSalt` notificationArns `Prelude.hashWithSalt` pathId `Prelude.hashWithSalt` pathName `Prelude.hashWithSalt` productId `Prelude.hashWithSalt` productName `Prelude.hashWithSalt` provisioningArtifactId `Prelude.hashWithSalt` provisioningArtifactName `Prelude.hashWithSalt` provisioningParameters `Prelude.hashWithSalt` provisioningPreferences `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` provisionedProductName `Prelude.hashWithSalt` provisionToken instance Prelude.NFData ProvisionProduct where rnf ProvisionProduct' {..} = Prelude.rnf acceptLanguage `Prelude.seq` Prelude.rnf notificationArns `Prelude.seq` Prelude.rnf pathId `Prelude.seq` Prelude.rnf pathName `Prelude.seq` Prelude.rnf productId `Prelude.seq` Prelude.rnf productName `Prelude.seq` Prelude.rnf provisioningArtifactId `Prelude.seq` Prelude.rnf provisioningArtifactName `Prelude.seq` Prelude.rnf provisioningParameters `Prelude.seq` Prelude.rnf provisioningPreferences `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf provisionedProductName `Prelude.seq` Prelude.rnf provisionToken instance Data.ToHeaders ProvisionProduct where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWS242ServiceCatalogService.ProvisionProduct" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ProvisionProduct where toJSON ProvisionProduct' {..} = Data.object ( Prelude.catMaybes [ ("AcceptLanguage" Data..=) Prelude.<$> acceptLanguage, ("NotificationArns" Data..=) Prelude.<$> notificationArns, ("PathId" Data..=) Prelude.<$> pathId, ("PathName" Data..=) Prelude.<$> pathName, ("ProductId" Data..=) Prelude.<$> productId, ("ProductName" Data..=) Prelude.<$> productName, ("ProvisioningArtifactId" Data..=) Prelude.<$> provisioningArtifactId, ("ProvisioningArtifactName" Data..=) Prelude.<$> provisioningArtifactName, ("ProvisioningParameters" Data..=) Prelude.<$> provisioningParameters, ("ProvisioningPreferences" Data..=) Prelude.<$> provisioningPreferences, ("Tags" Data..=) Prelude.<$> tags, Prelude.Just ( "ProvisionedProductName" Data..= provisionedProductName ), Prelude.Just ("ProvisionToken" Data..= provisionToken) ] ) instance Data.ToPath ProvisionProduct where toPath = Prelude.const "/" instance Data.ToQuery ProvisionProduct where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newProvisionProductResponse' smart constructor. data ProvisionProductResponse = ProvisionProductResponse' { -- | Information about the result of provisioning the product. recordDetail :: Prelude.Maybe RecordDetail, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ProvisionProductResponse' 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: -- -- 'recordDetail', 'provisionProductResponse_recordDetail' - Information about the result of provisioning the product. -- -- 'httpStatus', 'provisionProductResponse_httpStatus' - The response's http status code. newProvisionProductResponse :: -- | 'httpStatus' Prelude.Int -> ProvisionProductResponse newProvisionProductResponse pHttpStatus_ = ProvisionProductResponse' { recordDetail = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the result of provisioning the product. provisionProductResponse_recordDetail :: Lens.Lens' ProvisionProductResponse (Prelude.Maybe RecordDetail) provisionProductResponse_recordDetail = Lens.lens (\ProvisionProductResponse' {recordDetail} -> recordDetail) (\s@ProvisionProductResponse' {} a -> s {recordDetail = a} :: ProvisionProductResponse) -- | The response's http status code. provisionProductResponse_httpStatus :: Lens.Lens' ProvisionProductResponse Prelude.Int provisionProductResponse_httpStatus = Lens.lens (\ProvisionProductResponse' {httpStatus} -> httpStatus) (\s@ProvisionProductResponse' {} a -> s {httpStatus = a} :: ProvisionProductResponse) instance Prelude.NFData ProvisionProductResponse where rnf ProvisionProductResponse' {..} = Prelude.rnf recordDetail `Prelude.seq` Prelude.rnf httpStatus