{-# 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.Greengrass.StartBulkDeployment -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deploys multiple groups in one operation. This action starts the bulk -- deployment of a specified set of group versions. Each group version -- deployment will be triggered with an adaptive rate that has a fixed -- upper limit. We recommend that you include an -- \'\'X-Amzn-Client-Token\'\' token in every \'\'StartBulkDeployment\'\' -- request. These requests are idempotent with respect to the token and the -- request parameters. module Amazonka.Greengrass.StartBulkDeployment ( -- * Creating a Request StartBulkDeployment (..), newStartBulkDeployment, -- * Request Lenses startBulkDeployment_amznClientToken, startBulkDeployment_tags, startBulkDeployment_executionRoleArn, startBulkDeployment_inputFileUri, -- * Destructuring the Response StartBulkDeploymentResponse (..), newStartBulkDeploymentResponse, -- * Response Lenses startBulkDeploymentResponse_bulkDeploymentArn, startBulkDeploymentResponse_bulkDeploymentId, startBulkDeploymentResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Greengrass.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newStartBulkDeployment' smart constructor. data StartBulkDeployment = StartBulkDeployment' { -- | A client token used to correlate requests and responses. amznClientToken :: Prelude.Maybe Prelude.Text, -- | Tag(s) to add to the new resource. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The ARN of the execution role to associate with the bulk deployment -- operation. This IAM role must allow the -- \'\'greengrass:CreateDeployment\'\' action for all group versions that -- are listed in the input file. This IAM role must have access to the S3 -- bucket containing the input file. executionRoleArn :: Prelude.Text, -- | The URI of the input file contained in the S3 bucket. The execution role -- must have \'\'getObject\'\' permissions on this bucket to access the -- input file. The input file is a JSON-serialized, line delimited file -- with UTF-8 encoding that provides a list of group and version IDs and -- the deployment type. This file must be less than 100 MB. Currently, AWS -- IoT Greengrass supports only \'\'NewDeployment\'\' deployment types. inputFileUri :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartBulkDeployment' 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: -- -- 'amznClientToken', 'startBulkDeployment_amznClientToken' - A client token used to correlate requests and responses. -- -- 'tags', 'startBulkDeployment_tags' - Tag(s) to add to the new resource. -- -- 'executionRoleArn', 'startBulkDeployment_executionRoleArn' - The ARN of the execution role to associate with the bulk deployment -- operation. This IAM role must allow the -- \'\'greengrass:CreateDeployment\'\' action for all group versions that -- are listed in the input file. This IAM role must have access to the S3 -- bucket containing the input file. -- -- 'inputFileUri', 'startBulkDeployment_inputFileUri' - The URI of the input file contained in the S3 bucket. The execution role -- must have \'\'getObject\'\' permissions on this bucket to access the -- input file. The input file is a JSON-serialized, line delimited file -- with UTF-8 encoding that provides a list of group and version IDs and -- the deployment type. This file must be less than 100 MB. Currently, AWS -- IoT Greengrass supports only \'\'NewDeployment\'\' deployment types. newStartBulkDeployment :: -- | 'executionRoleArn' Prelude.Text -> -- | 'inputFileUri' Prelude.Text -> StartBulkDeployment newStartBulkDeployment pExecutionRoleArn_ pInputFileUri_ = StartBulkDeployment' { amznClientToken = Prelude.Nothing, tags = Prelude.Nothing, executionRoleArn = pExecutionRoleArn_, inputFileUri = pInputFileUri_ } -- | A client token used to correlate requests and responses. startBulkDeployment_amznClientToken :: Lens.Lens' StartBulkDeployment (Prelude.Maybe Prelude.Text) startBulkDeployment_amznClientToken = Lens.lens (\StartBulkDeployment' {amznClientToken} -> amznClientToken) (\s@StartBulkDeployment' {} a -> s {amznClientToken = a} :: StartBulkDeployment) -- | Tag(s) to add to the new resource. startBulkDeployment_tags :: Lens.Lens' StartBulkDeployment (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) startBulkDeployment_tags = Lens.lens (\StartBulkDeployment' {tags} -> tags) (\s@StartBulkDeployment' {} a -> s {tags = a} :: StartBulkDeployment) Prelude.. Lens.mapping Lens.coerced -- | The ARN of the execution role to associate with the bulk deployment -- operation. This IAM role must allow the -- \'\'greengrass:CreateDeployment\'\' action for all group versions that -- are listed in the input file. This IAM role must have access to the S3 -- bucket containing the input file. startBulkDeployment_executionRoleArn :: Lens.Lens' StartBulkDeployment Prelude.Text startBulkDeployment_executionRoleArn = Lens.lens (\StartBulkDeployment' {executionRoleArn} -> executionRoleArn) (\s@StartBulkDeployment' {} a -> s {executionRoleArn = a} :: StartBulkDeployment) -- | The URI of the input file contained in the S3 bucket. The execution role -- must have \'\'getObject\'\' permissions on this bucket to access the -- input file. The input file is a JSON-serialized, line delimited file -- with UTF-8 encoding that provides a list of group and version IDs and -- the deployment type. This file must be less than 100 MB. Currently, AWS -- IoT Greengrass supports only \'\'NewDeployment\'\' deployment types. startBulkDeployment_inputFileUri :: Lens.Lens' StartBulkDeployment Prelude.Text startBulkDeployment_inputFileUri = Lens.lens (\StartBulkDeployment' {inputFileUri} -> inputFileUri) (\s@StartBulkDeployment' {} a -> s {inputFileUri = a} :: StartBulkDeployment) instance Core.AWSRequest StartBulkDeployment where type AWSResponse StartBulkDeployment = StartBulkDeploymentResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> StartBulkDeploymentResponse' Prelude.<$> (x Data..?> "BulkDeploymentArn") Prelude.<*> (x Data..?> "BulkDeploymentId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StartBulkDeployment where hashWithSalt _salt StartBulkDeployment' {..} = _salt `Prelude.hashWithSalt` amznClientToken `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` executionRoleArn `Prelude.hashWithSalt` inputFileUri instance Prelude.NFData StartBulkDeployment where rnf StartBulkDeployment' {..} = Prelude.rnf amznClientToken `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf executionRoleArn `Prelude.seq` Prelude.rnf inputFileUri instance Data.ToHeaders StartBulkDeployment where toHeaders StartBulkDeployment' {..} = Prelude.mconcat [ "X-Amzn-Client-Token" Data.=# amznClientToken, "Content-Type" Data.=# ("application/x-amz-json-1.1" :: Prelude.ByteString) ] instance Data.ToJSON StartBulkDeployment where toJSON StartBulkDeployment' {..} = Data.object ( Prelude.catMaybes [ ("tags" Data..=) Prelude.<$> tags, Prelude.Just ("ExecutionRoleArn" Data..= executionRoleArn), Prelude.Just ("InputFileUri" Data..= inputFileUri) ] ) instance Data.ToPath StartBulkDeployment where toPath = Prelude.const "/greengrass/bulk/deployments" instance Data.ToQuery StartBulkDeployment where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newStartBulkDeploymentResponse' smart constructor. data StartBulkDeploymentResponse = StartBulkDeploymentResponse' { -- | The ARN of the bulk deployment. bulkDeploymentArn :: Prelude.Maybe Prelude.Text, -- | The ID of the bulk deployment. bulkDeploymentId :: 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 'StartBulkDeploymentResponse' 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: -- -- 'bulkDeploymentArn', 'startBulkDeploymentResponse_bulkDeploymentArn' - The ARN of the bulk deployment. -- -- 'bulkDeploymentId', 'startBulkDeploymentResponse_bulkDeploymentId' - The ID of the bulk deployment. -- -- 'httpStatus', 'startBulkDeploymentResponse_httpStatus' - The response's http status code. newStartBulkDeploymentResponse :: -- | 'httpStatus' Prelude.Int -> StartBulkDeploymentResponse newStartBulkDeploymentResponse pHttpStatus_ = StartBulkDeploymentResponse' { bulkDeploymentArn = Prelude.Nothing, bulkDeploymentId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN of the bulk deployment. startBulkDeploymentResponse_bulkDeploymentArn :: Lens.Lens' StartBulkDeploymentResponse (Prelude.Maybe Prelude.Text) startBulkDeploymentResponse_bulkDeploymentArn = Lens.lens (\StartBulkDeploymentResponse' {bulkDeploymentArn} -> bulkDeploymentArn) (\s@StartBulkDeploymentResponse' {} a -> s {bulkDeploymentArn = a} :: StartBulkDeploymentResponse) -- | The ID of the bulk deployment. startBulkDeploymentResponse_bulkDeploymentId :: Lens.Lens' StartBulkDeploymentResponse (Prelude.Maybe Prelude.Text) startBulkDeploymentResponse_bulkDeploymentId = Lens.lens (\StartBulkDeploymentResponse' {bulkDeploymentId} -> bulkDeploymentId) (\s@StartBulkDeploymentResponse' {} a -> s {bulkDeploymentId = a} :: StartBulkDeploymentResponse) -- | The response's http status code. startBulkDeploymentResponse_httpStatus :: Lens.Lens' StartBulkDeploymentResponse Prelude.Int startBulkDeploymentResponse_httpStatus = Lens.lens (\StartBulkDeploymentResponse' {httpStatus} -> httpStatus) (\s@StartBulkDeploymentResponse' {} a -> s {httpStatus = a} :: StartBulkDeploymentResponse) instance Prelude.NFData StartBulkDeploymentResponse where rnf StartBulkDeploymentResponse' {..} = Prelude.rnf bulkDeploymentArn `Prelude.seq` Prelude.rnf bulkDeploymentId `Prelude.seq` Prelude.rnf httpStatus