{-# 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.MGN.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) -- -- Delete application. module Amazonka.MGN.DeleteApplication ( -- * Creating a Request DeleteApplication (..), newDeleteApplication, -- * Request Lenses 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.MGN.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' { -- | Application ID. 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: -- -- 'applicationID', 'deleteApplication_applicationID' - Application ID. newDeleteApplication :: -- | 'applicationID' Prelude.Text -> DeleteApplication newDeleteApplication pApplicationID_ = DeleteApplication' {applicationID = pApplicationID_} -- | Application ID. 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.postJSON (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` applicationID instance Prelude.NFData DeleteApplication where rnf DeleteApplication' {..} = 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.ToJSON DeleteApplication where toJSON DeleteApplication' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("applicationID" Data..= applicationID) ] ) instance Data.ToPath DeleteApplication where toPath = Prelude.const "/DeleteApplication" instance Data.ToQuery DeleteApplication where toQuery = Prelude.const Prelude.mempty -- | /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