{-# 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.IoTFleetWise.DeleteModelManifest -- 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 vehicle model (model manifest). -- -- If the vehicle model is successfully deleted, Amazon Web Services IoT -- FleetWise sends back an HTTP 200 response with an empty body. module Amazonka.IoTFleetWise.DeleteModelManifest ( -- * Creating a Request DeleteModelManifest (..), newDeleteModelManifest, -- * Request Lenses deleteModelManifest_name, -- * Destructuring the Response DeleteModelManifestResponse (..), newDeleteModelManifestResponse, -- * Response Lenses deleteModelManifestResponse_httpStatus, deleteModelManifestResponse_name, deleteModelManifestResponse_arn, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoTFleetWise.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeleteModelManifest' smart constructor. data DeleteModelManifest = DeleteModelManifest' { -- | The name of the model manifest to delete. name :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteModelManifest' 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: -- -- 'name', 'deleteModelManifest_name' - The name of the model manifest to delete. newDeleteModelManifest :: -- | 'name' Prelude.Text -> DeleteModelManifest newDeleteModelManifest pName_ = DeleteModelManifest' {name = pName_} -- | The name of the model manifest to delete. deleteModelManifest_name :: Lens.Lens' DeleteModelManifest Prelude.Text deleteModelManifest_name = Lens.lens (\DeleteModelManifest' {name} -> name) (\s@DeleteModelManifest' {} a -> s {name = a} :: DeleteModelManifest) instance Core.AWSRequest DeleteModelManifest where type AWSResponse DeleteModelManifest = DeleteModelManifestResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeleteModelManifestResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "name") Prelude.<*> (x Data..:> "arn") ) instance Prelude.Hashable DeleteModelManifest where hashWithSalt _salt DeleteModelManifest' {..} = _salt `Prelude.hashWithSalt` name instance Prelude.NFData DeleteModelManifest where rnf DeleteModelManifest' {..} = Prelude.rnf name instance Data.ToHeaders DeleteModelManifest where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "IoTAutobahnControlPlane.DeleteModelManifest" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteModelManifest where toJSON DeleteModelManifest' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("name" Data..= name)] ) instance Data.ToPath DeleteModelManifest where toPath = Prelude.const "/" instance Data.ToQuery DeleteModelManifest where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteModelManifestResponse' smart constructor. data DeleteModelManifestResponse = DeleteModelManifestResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | The name of the deleted model manifest. name :: Prelude.Text, -- | The Amazon Resource Name (ARN) of the deleted model manifest. arn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteModelManifestResponse' 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', 'deleteModelManifestResponse_httpStatus' - The response's http status code. -- -- 'name', 'deleteModelManifestResponse_name' - The name of the deleted model manifest. -- -- 'arn', 'deleteModelManifestResponse_arn' - The Amazon Resource Name (ARN) of the deleted model manifest. newDeleteModelManifestResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'name' Prelude.Text -> -- | 'arn' Prelude.Text -> DeleteModelManifestResponse newDeleteModelManifestResponse pHttpStatus_ pName_ pArn_ = DeleteModelManifestResponse' { httpStatus = pHttpStatus_, name = pName_, arn = pArn_ } -- | The response's http status code. deleteModelManifestResponse_httpStatus :: Lens.Lens' DeleteModelManifestResponse Prelude.Int deleteModelManifestResponse_httpStatus = Lens.lens (\DeleteModelManifestResponse' {httpStatus} -> httpStatus) (\s@DeleteModelManifestResponse' {} a -> s {httpStatus = a} :: DeleteModelManifestResponse) -- | The name of the deleted model manifest. deleteModelManifestResponse_name :: Lens.Lens' DeleteModelManifestResponse Prelude.Text deleteModelManifestResponse_name = Lens.lens (\DeleteModelManifestResponse' {name} -> name) (\s@DeleteModelManifestResponse' {} a -> s {name = a} :: DeleteModelManifestResponse) -- | The Amazon Resource Name (ARN) of the deleted model manifest. deleteModelManifestResponse_arn :: Lens.Lens' DeleteModelManifestResponse Prelude.Text deleteModelManifestResponse_arn = Lens.lens (\DeleteModelManifestResponse' {arn} -> arn) (\s@DeleteModelManifestResponse' {} a -> s {arn = a} :: DeleteModelManifestResponse) instance Prelude.NFData DeleteModelManifestResponse where rnf DeleteModelManifestResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf arn