{-# 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.IoTSiteWise.DeleteProject -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes a project from IoT SiteWise Monitor. module Amazonka.IoTSiteWise.DeleteProject ( -- * Creating a Request DeleteProject (..), newDeleteProject, -- * Request Lenses deleteProject_clientToken, deleteProject_projectId, -- * Destructuring the Response DeleteProjectResponse (..), newDeleteProjectResponse, -- * Response Lenses deleteProjectResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTSiteWise.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteProject' smart constructor. data DeleteProject = DeleteProject' { -- | A unique case-sensitive identifier that you can provide to ensure the -- idempotency of the request. Don\'t reuse this client token if a new -- idempotent request is required. clientToken :: Prelude.Maybe Prelude.Text, -- | The ID of the project. projectId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteProject' 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: -- -- 'clientToken', 'deleteProject_clientToken' - A unique case-sensitive identifier that you can provide to ensure the -- idempotency of the request. Don\'t reuse this client token if a new -- idempotent request is required. -- -- 'projectId', 'deleteProject_projectId' - The ID of the project. newDeleteProject :: -- | 'projectId' Prelude.Text -> DeleteProject newDeleteProject pProjectId_ = DeleteProject' { clientToken = Prelude.Nothing, projectId = pProjectId_ } -- | A unique case-sensitive identifier that you can provide to ensure the -- idempotency of the request. Don\'t reuse this client token if a new -- idempotent request is required. deleteProject_clientToken :: Lens.Lens' DeleteProject (Prelude.Maybe Prelude.Text) deleteProject_clientToken = Lens.lens (\DeleteProject' {clientToken} -> clientToken) (\s@DeleteProject' {} a -> s {clientToken = a} :: DeleteProject) -- | The ID of the project. deleteProject_projectId :: Lens.Lens' DeleteProject Prelude.Text deleteProject_projectId = Lens.lens (\DeleteProject' {projectId} -> projectId) (\s@DeleteProject' {} a -> s {projectId = a} :: DeleteProject) instance Core.AWSRequest DeleteProject where type AWSResponse DeleteProject = DeleteProjectResponse request overrides = Request.delete (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteProjectResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteProject where hashWithSalt _salt DeleteProject' {..} = _salt `Prelude.hashWithSalt` clientToken `Prelude.hashWithSalt` projectId instance Prelude.NFData DeleteProject where rnf DeleteProject' {..} = Prelude.rnf clientToken `Prelude.seq` Prelude.rnf projectId instance Data.ToHeaders DeleteProject where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath DeleteProject where toPath DeleteProject' {..} = Prelude.mconcat ["/projects/", Data.toBS projectId] instance Data.ToQuery DeleteProject where toQuery DeleteProject' {..} = Prelude.mconcat ["clientToken" Data.=: clientToken] -- | /See:/ 'newDeleteProjectResponse' smart constructor. data DeleteProjectResponse = DeleteProjectResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteProjectResponse' 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: -- -- 'httpStatus', 'deleteProjectResponse_httpStatus' - The response's http status code. newDeleteProjectResponse :: -- | 'httpStatus' Prelude.Int -> DeleteProjectResponse newDeleteProjectResponse pHttpStatus_ = DeleteProjectResponse' {httpStatus = pHttpStatus_} -- | The response's http status code. deleteProjectResponse_httpStatus :: Lens.Lens' DeleteProjectResponse Prelude.Int deleteProjectResponse_httpStatus = Lens.lens (\DeleteProjectResponse' {httpStatus} -> httpStatus) (\s@DeleteProjectResponse' {} a -> s {httpStatus = a} :: DeleteProjectResponse) instance Prelude.NFData DeleteProjectResponse where rnf DeleteProjectResponse' {..} = Prelude.rnf httpStatus