{-# 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.IoTFleetHub.DeleteApplication -- 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 Fleet Hub for AWS IoT Device Management web application. -- -- Fleet Hub for AWS IoT Device Management is in public preview and is -- subject to change. module Amazonka.IoTFleetHub.DeleteApplication ( -- * Creating a Request DeleteApplication (..), newDeleteApplication, -- * Request Lenses deleteApplication_clientToken, deleteApplication_applicationId, -- * Destructuring the Response DeleteApplicationResponse (..), newDeleteApplicationResponse, -- * Response Lenses deleteApplicationResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTFleetHub.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteApplication' smart constructor. data DeleteApplication = DeleteApplication' { -- | 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 unique Id of the web application. applicationId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteApplication' 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', 'deleteApplication_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. -- -- 'applicationId', 'deleteApplication_applicationId' - The unique Id of the web application. newDeleteApplication :: -- | 'applicationId' Prelude.Text -> DeleteApplication newDeleteApplication pApplicationId_ = DeleteApplication' { clientToken = Prelude.Nothing, applicationId = pApplicationId_ } -- | 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. deleteApplication_clientToken :: Lens.Lens' DeleteApplication (Prelude.Maybe Prelude.Text) deleteApplication_clientToken = Lens.lens (\DeleteApplication' {clientToken} -> clientToken) (\s@DeleteApplication' {} a -> s {clientToken = a} :: DeleteApplication) -- | The unique Id of the web application. deleteApplication_applicationId :: Lens.Lens' DeleteApplication Prelude.Text deleteApplication_applicationId = Lens.lens (\DeleteApplication' {applicationId} -> applicationId) (\s@DeleteApplication' {} a -> s {applicationId = a} :: DeleteApplication) instance Core.AWSRequest DeleteApplication where type AWSResponse DeleteApplication = DeleteApplicationResponse request overrides = Request.delete (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteApplicationResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteApplication where hashWithSalt _salt DeleteApplication' {..} = _salt `Prelude.hashWithSalt` clientToken `Prelude.hashWithSalt` applicationId instance Prelude.NFData DeleteApplication where rnf DeleteApplication' {..} = Prelude.rnf clientToken `Prelude.seq` Prelude.rnf applicationId instance Data.ToHeaders DeleteApplication where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath DeleteApplication where toPath DeleteApplication' {..} = Prelude.mconcat ["/applications/", Data.toBS applicationId] instance Data.ToQuery DeleteApplication where toQuery DeleteApplication' {..} = Prelude.mconcat ["clientToken" Data.=: clientToken] -- | /See:/ 'newDeleteApplicationResponse' smart constructor. data DeleteApplicationResponse = DeleteApplicationResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteApplicationResponse' 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', 'deleteApplicationResponse_httpStatus' - The response's http status code. newDeleteApplicationResponse :: -- | 'httpStatus' Prelude.Int -> DeleteApplicationResponse newDeleteApplicationResponse pHttpStatus_ = DeleteApplicationResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. deleteApplicationResponse_httpStatus :: Lens.Lens' DeleteApplicationResponse Prelude.Int deleteApplicationResponse_httpStatus = Lens.lens (\DeleteApplicationResponse' {httpStatus} -> httpStatus) (\s@DeleteApplicationResponse' {} a -> s {httpStatus = a} :: DeleteApplicationResponse) instance Prelude.NFData DeleteApplicationResponse where rnf DeleteApplicationResponse' {..} = Prelude.rnf httpStatus