{-# 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.CreateDeployment -- 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 deployment. \'\'CreateDeployment\'\' requests are idempotent -- with respect to the \'\'X-Amzn-Client-Token\'\' token and the request -- parameters. module Amazonka.Greengrass.CreateDeployment ( -- * Creating a Request CreateDeployment (..), newCreateDeployment, -- * Request Lenses createDeployment_amznClientToken, createDeployment_deploymentId, createDeployment_groupVersionId, createDeployment_groupId, createDeployment_deploymentType, -- * Destructuring the Response CreateDeploymentResponse (..), newCreateDeploymentResponse, -- * Response Lenses createDeploymentResponse_deploymentArn, createDeploymentResponse_deploymentId, createDeploymentResponse_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:/ 'newCreateDeployment' smart constructor. data CreateDeployment = CreateDeployment' { -- | A client token used to correlate requests and responses. amznClientToken :: Prelude.Maybe Prelude.Text, -- | The ID of the deployment if you wish to redeploy a previous deployment. deploymentId :: Prelude.Maybe Prelude.Text, -- | The ID of the group version to be deployed. groupVersionId :: Prelude.Maybe Prelude.Text, -- | The ID of the Greengrass group. groupId :: Prelude.Text, -- | The type of deployment. When used for \'\'CreateDeployment\'\', only -- \'\'NewDeployment\'\' and \'\'Redeployment\'\' are valid. deploymentType :: DeploymentType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateDeployment' 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', 'createDeployment_amznClientToken' - A client token used to correlate requests and responses. -- -- 'deploymentId', 'createDeployment_deploymentId' - The ID of the deployment if you wish to redeploy a previous deployment. -- -- 'groupVersionId', 'createDeployment_groupVersionId' - The ID of the group version to be deployed. -- -- 'groupId', 'createDeployment_groupId' - The ID of the Greengrass group. -- -- 'deploymentType', 'createDeployment_deploymentType' - The type of deployment. When used for \'\'CreateDeployment\'\', only -- \'\'NewDeployment\'\' and \'\'Redeployment\'\' are valid. newCreateDeployment :: -- | 'groupId' Prelude.Text -> -- | 'deploymentType' DeploymentType -> CreateDeployment newCreateDeployment pGroupId_ pDeploymentType_ = CreateDeployment' { amznClientToken = Prelude.Nothing, deploymentId = Prelude.Nothing, groupVersionId = Prelude.Nothing, groupId = pGroupId_, deploymentType = pDeploymentType_ } -- | A client token used to correlate requests and responses. createDeployment_amznClientToken :: Lens.Lens' CreateDeployment (Prelude.Maybe Prelude.Text) createDeployment_amznClientToken = Lens.lens (\CreateDeployment' {amznClientToken} -> amznClientToken) (\s@CreateDeployment' {} a -> s {amznClientToken = a} :: CreateDeployment) -- | The ID of the deployment if you wish to redeploy a previous deployment. createDeployment_deploymentId :: Lens.Lens' CreateDeployment (Prelude.Maybe Prelude.Text) createDeployment_deploymentId = Lens.lens (\CreateDeployment' {deploymentId} -> deploymentId) (\s@CreateDeployment' {} a -> s {deploymentId = a} :: CreateDeployment) -- | The ID of the group version to be deployed. createDeployment_groupVersionId :: Lens.Lens' CreateDeployment (Prelude.Maybe Prelude.Text) createDeployment_groupVersionId = Lens.lens (\CreateDeployment' {groupVersionId} -> groupVersionId) (\s@CreateDeployment' {} a -> s {groupVersionId = a} :: CreateDeployment) -- | The ID of the Greengrass group. createDeployment_groupId :: Lens.Lens' CreateDeployment Prelude.Text createDeployment_groupId = Lens.lens (\CreateDeployment' {groupId} -> groupId) (\s@CreateDeployment' {} a -> s {groupId = a} :: CreateDeployment) -- | The type of deployment. When used for \'\'CreateDeployment\'\', only -- \'\'NewDeployment\'\' and \'\'Redeployment\'\' are valid. createDeployment_deploymentType :: Lens.Lens' CreateDeployment DeploymentType createDeployment_deploymentType = Lens.lens (\CreateDeployment' {deploymentType} -> deploymentType) (\s@CreateDeployment' {} a -> s {deploymentType = a} :: CreateDeployment) instance Core.AWSRequest CreateDeployment where type AWSResponse CreateDeployment = CreateDeploymentResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateDeploymentResponse' Prelude.<$> (x Data..?> "DeploymentArn") Prelude.<*> (x Data..?> "DeploymentId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateDeployment where hashWithSalt _salt CreateDeployment' {..} = _salt `Prelude.hashWithSalt` amznClientToken `Prelude.hashWithSalt` deploymentId `Prelude.hashWithSalt` groupVersionId `Prelude.hashWithSalt` groupId `Prelude.hashWithSalt` deploymentType instance Prelude.NFData CreateDeployment where rnf CreateDeployment' {..} = Prelude.rnf amznClientToken `Prelude.seq` Prelude.rnf deploymentId `Prelude.seq` Prelude.rnf groupVersionId `Prelude.seq` Prelude.rnf groupId `Prelude.seq` Prelude.rnf deploymentType instance Data.ToHeaders CreateDeployment where toHeaders CreateDeployment' {..} = Prelude.mconcat [ "X-Amzn-Client-Token" Data.=# amznClientToken, "Content-Type" Data.=# ("application/x-amz-json-1.1" :: Prelude.ByteString) ] instance Data.ToJSON CreateDeployment where toJSON CreateDeployment' {..} = Data.object ( Prelude.catMaybes [ ("DeploymentId" Data..=) Prelude.<$> deploymentId, ("GroupVersionId" Data..=) Prelude.<$> groupVersionId, Prelude.Just ("DeploymentType" Data..= deploymentType) ] ) instance Data.ToPath CreateDeployment where toPath CreateDeployment' {..} = Prelude.mconcat [ "/greengrass/groups/", Data.toBS groupId, "/deployments" ] instance Data.ToQuery CreateDeployment where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateDeploymentResponse' smart constructor. data CreateDeploymentResponse = CreateDeploymentResponse' { -- | The ARN of the deployment. deploymentArn :: Prelude.Maybe Prelude.Text, -- | The ID of the deployment. deploymentId :: 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 'CreateDeploymentResponse' 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: -- -- 'deploymentArn', 'createDeploymentResponse_deploymentArn' - The ARN of the deployment. -- -- 'deploymentId', 'createDeploymentResponse_deploymentId' - The ID of the deployment. -- -- 'httpStatus', 'createDeploymentResponse_httpStatus' - The response's http status code. newCreateDeploymentResponse :: -- | 'httpStatus' Prelude.Int -> CreateDeploymentResponse newCreateDeploymentResponse pHttpStatus_ = CreateDeploymentResponse' { deploymentArn = Prelude.Nothing, deploymentId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN of the deployment. createDeploymentResponse_deploymentArn :: Lens.Lens' CreateDeploymentResponse (Prelude.Maybe Prelude.Text) createDeploymentResponse_deploymentArn = Lens.lens (\CreateDeploymentResponse' {deploymentArn} -> deploymentArn) (\s@CreateDeploymentResponse' {} a -> s {deploymentArn = a} :: CreateDeploymentResponse) -- | The ID of the deployment. createDeploymentResponse_deploymentId :: Lens.Lens' CreateDeploymentResponse (Prelude.Maybe Prelude.Text) createDeploymentResponse_deploymentId = Lens.lens (\CreateDeploymentResponse' {deploymentId} -> deploymentId) (\s@CreateDeploymentResponse' {} a -> s {deploymentId = a} :: CreateDeploymentResponse) -- | The response's http status code. createDeploymentResponse_httpStatus :: Lens.Lens' CreateDeploymentResponse Prelude.Int createDeploymentResponse_httpStatus = Lens.lens (\CreateDeploymentResponse' {httpStatus} -> httpStatus) (\s@CreateDeploymentResponse' {} a -> s {httpStatus = a} :: CreateDeploymentResponse) instance Prelude.NFData CreateDeploymentResponse where rnf CreateDeploymentResponse' {..} = Prelude.rnf deploymentArn `Prelude.seq` Prelude.rnf deploymentId `Prelude.seq` Prelude.rnf httpStatus